[Вопросы для собеседования](README.md) # Журналирование + [Какие существуют типы логов?](#Какие-существуют-типы-логов) + [Из каких частей состоит система журналирования log4j?](#Из-каких-частей-состоит-система-журналирования-log4j) + [Что такое _Logger_ в log4j?](#Что-такое-logger-в-log4j) + [Что такое _Appender_ в log4j?](#Что-такое-appender-в-log4j) + [Что такое _Layout_ в log4j?](#Что-такое-layout-в-log4j) + [Перечислите уровни журналирования в log4j? Назовите порядок их приоритетности.](#Перечислите-уровни-журналирования-в-log4j-Назовите-порядок-их-приоритетности) + [Какие существуют способы конфигурирования log4j?](#Какие-существуют-способы-конфигурирования-log4j) ## Какие существуют типы логов? + системы (System); + безопасности (Security); + приложения (Application, Buisness). > Пользователь входит в приложение, проверяется пароль. Это действие относится к безопасности (Security). Дальше он запускает какой-нибудь модуль. Это событие уровня приложения (Application). Модуль при старте обращается к другому модулю за какими-то дополнительными данными, производит какие-либо еще вызовы – это уже системные действия (System). [к оглавлению](#Журналирование) ## Из каких частей состоит система журналирования log4j? Система журналирования состоит из трёх основных частей: + управляющей журналированием - __logger__; + добавляющей в журнал - __appender__; + определяющей формат добавления - __layout__. [к оглавлению](#Журналирование) ## Что такое _Logger_ в log4j? __Logger__ представляет собой объект класса `org.apache.log4j.Logger`, который используется как управляющий интерфейс для журналирования сообщений с возможностью задавать уровень детализации. Именно logger проверяет нужно ли обрабатывать сообщение и если журналирование необходимо, то сообщение передаётся в appender, если нет - система завершает обработку данного сообщения. [к оглавлению](#Журналирование) ## Что такое _Appender_ в log4j? __Appender__ - это именованный объект журнала событий, реализующий интерфейс `org.apache.log4j.Appender` и добавляющий события в журнал. Appender вызывает разные вспомогательные инструменты - компоновщик, фильтр, обработчик ошибок (если они определены и необходимы). В ходе этой работы окончательно устанавливается необходимость записи сообщения, сообщению придаются окончательные содержание и форма. В log4j журнал может представлять: + консоль; + файл; + сокет; + объект класса реализующего `java.io.Writer` или `java.io.OutputStream`; + JDBC хранилище; + тему (topic) JMS; + NT Event Log; + SMTP; + Syslog; + Telnet. Наиболее часто используемые log4j appender-ы: + `org.apache.log4j.ConsoleAppender` - вывод в консоль; + `org.apache.log4j.FileAppender` - добавление в файл; + `org.apache.log4j.DailyRollingFileAppender` - добавление в файл с обновлением файла через заданный промежуток времени; + `org.apache.log4j.RollingFileAppender` - добавление в файл с обновлением файла по достижению определенного размера; + `org.apache.log4j.varia.ExternallyRolledFileAppender` - расширение _RollingFileAppender_ обновляющее файл по команде принятой с заданного порта; + `org.apache.log4j.net.SMTPAppender` - сообщение по SMTP; + `org.apache.log4j.AsyncAppender` - позволяет, используя отдельный поток, организовать асинхронную работу, когда сообщения фиксируются лишь при достижении определенного уровня заполненности промежуточного буфера. + `org.apache.log4j.nt.NTEventLogAppender` - добавление в NT Event Log; + `org.apache.log4j.net.SyslogAppender` - добавление в Syslog; + `org.apache.log4j.jdbc.JDBCAppender` - запись в хранилище JDBC; + `org.apache.log4j.lf5.LF5Appender` - сообщение передаётся в специальный GUI интерфейс LogFactor5 + `org.apache.log4j.net.SocketAppender` - трансляция сообщения по указанному адресу и порту; + `org.apache.log4j.net.SocketHubAppender` - рассылка сообщения сразу нескольким удалённым серверам, соединённым по заданному порту; + `org.apache.log4j.net.TelnetAppender` - отсылка сообщения по протоколу Telenet; + `org.apache.log4j.net.JMSAppender` - добавление сообщения в JMS. [к оглавлению](#Журналирование) ## Что такое _Layout_ в log4j? __Layout__ - наследник класса `org.apache.log4j.Layout` предоставляющий возможность форматирования сообщения перед добавлением в журнал. В log4j существуют следующие типы layout-ов: + `org.apache.log4j.SimpleLayout` - на выходе получается строка содержащая лишь уровень вывода и сообщение; + `org.apache.log4j.HTMLLayout` - форматирует сообщение в виде элемента HTML-таблицы; + `org.apache.log4j.xml.XMLLayout` - компонует сообщение в виде XML формате; + `org.apache.log4j.TTCCLayout` - на выходе сообщение дополняется информацией о времени, потоке, имени логгера и вложенном диагностическом контексте; + `org.apache.log4j.PatternLayout` / `org.apache.log4j.EnhancedPatternLayout` - настройка форматирования сообщения при помощи шаблона заданного пользователем. [к оглавлению](#Журналирование) ## Перечислите уровни журналирования в log4j? Назовите порядок их приоритетности. + __OFF__ - отсутствие журналирования; + __FATAL__ - фатальная ошибка; + __ERROR__ - ошибка; + __WARN__ - предупреждение; + __INFO__ - информация; + __DEBUG__ - детальная информация для отладки; + __TRACE__ – трассировка всех сообщений. Между уровнями логирования установлен следующий порядок приоритетов: `ALL < TRACE < DEBUG < INFO < WARN < ERROR < FATAL < OFF` [к оглавлению](#Журналирование) ## Какие существуют способы конфигурирования log4j? Для того, чтобы log4j начал работать нужно предоставить ему конфигурацию. Это можно сделать несколькими путями: + Создать конфигурацию программно, т.е. получить logger, определить уровень журналирования, прикрепить appender и задать способ форматирования. + Указать файл или URL как аргумент при запуске java-машины `-Dlog4j.configuration=путь/к/файлу/конфигурации`, а затем прочитать его в программе при помощи `PropertyConfigurator.configure(...)`/ `DOMConfigurator.configure(...)` для формата `.properties` или `XML` соответственно. + Загрузить конфигурацию из файла в формате `XML` или `.properties`: log4j ищет файл конфигурации в classpath. Сначала ищется файл `log4j.xml` и, если таковой не найден, - файл `log4j.properties`. [к оглавлению](#Журналирование) # Источники + [Quizful](http://www.quizful.net/) + [Skipy](http://skipy.ru/useful/logging.html#log4j_concepts_logger) [Вопросы для собеседования](README.md)