16.3. Область применения | Популярный Linux

Опубликовано Bash в Ср, 23/12/2009 — 20:59


Как один из вариантов грамотного применения перенаправления ввода/вывода, можно назвать разбор и «сшивание» вывода от команд (см. Пример 11-6). Это позволяет создавать файлы отчетов и журналов регистрации событий.

Пример 16-11. Регистрация событий

  1. #!/bin/bash
  2. # logevents.sh, автор: Stephane Chazelas.
  3. # Регистрация событий в файле.
  4. # Сценарий должен запускаться с привилегиями root (что бы иметь право на запись в /var/log).
  5. ROOT_UID=0     # Привилегии root имеет только пользователь с $UID = 0.
  6. E_NOTROOT=67   # Код завершения, если не root.
  7. if [ «$UID« -ne «$ROOT_UID« ]
  8. then
  9.   echo «Сценарий должен запускаться с привилегиями root.»
  10.   exit $E_NOTROOT
  11. fi
  12. FD_DEBUG1=3
  13. FD_DEBUG2=4
  14. FD_DEBUG3=5
  15. # Раскомментарьте одну из двух строк, ниже, для активизации сценария.
  16. # LOG_EVENTS=1
  17. # LOG_VARS=1
  18. log()  # Запись даты и времени в файл.
  19. {
  20. echo «$(date)  $*» >&7     # Добавляет в конец файла.
  21.                               # См. ниже.
  22. }
  23. case $LOG_LEVEL in
  24.  1) exec 3>&2         4> /dev/null 5> /dev/null;;
  25.  2) exec 3>&2         4>&2         5> /dev/null;;
  26.  3) exec 3>&2         4>&2         5>&2;;
  27.  *) exec 3> /dev/null 4> /dev/null 5> /dev/null;;
  28. esac
  29. FD_LOGVARS=6
  30. if [[ $LOG_VARS ]]
  31. then exec 6>> /var/log/vars.log
  32. else exec 6> /dev/null               # Подавить вывод.
  33. fi
  34. FD_LOGEVENTS=7
  35. if [[ $LOG_EVENTS ]]
  36. then
  37.   # then exec 7 >(exec gawk ‘{print strftime(), $0}’ >> /var/log/event.log)
  38.   # Строка, выше, не работает в Bash, версии 2.04.
  39.   exec 7>> /var/log/event.log        # Добавление в конец «event.log».
  40.   log                                      # Записать дату и время.
  41. else exec 7> /dev/null                  # Подавить вывод.
  42. fi
  43. echo «DEBUG3: beginning» >&${FD_DEBUG3}
  44. ls -l >&5 2>&4                       # command1 >&5 2>&4
  45. echo «Done»                                # command2
  46. echo «sending mail» >&${FD_LOGEVENTS}   # Написать «sending mail» в дескр. #7.
  47. exit 0

Запись опубликована в рубрике Без рубрики. Добавьте в закладки постоянную ссылку.