Модуль log
Tarantool provides a set of options used to configure logging
in various ways: you can set a level of logging, specify where to send the log’s output,
configure a log format, and so on.
The log
module allows you to configure logging in your application and
provides additional capabilities, for example, logging custom messages and
rotating log files.
Ниже приведен перечень всех функций и элементов модуля log
.
Имя | Назначение |
---|---|
log.cfg({}) | Configure a logger |
log.error() log.warn() log.info() log.verbose() log.debug() |
Log a message with the specified level |
log.pid() | Получение PID регистратора записи в журнале |
log.rotate() | Ротация файла журнала |
log.new() | Create a new logger with the specified name |
-
log.
cfg
({})¶ Configure logging options. The following options are available:
level
: Specifies the level of detail the log has.Learn more: log_level.
log
: Specifies where to send the log’s output, for example, to a file, pipe, or system logger.Learn more: log.
nonblock
: If true, Tarantool does not block during logging when the system is not ready for writing, and drops the message instead.Learn more: log_nonblock.
format
: Specifies the log format: „plain“ or „json“.Learn more: log_format.
modules
: Configures the specified log levels for different modules.Learn more: log_modules.
The example below shows how to set the log level to „debug“ and how to send the resulting log to the „tarantool.log“ file:
log = require('log') log.cfg{ level='debug', log='tarantool.log'}
Примечание
Note that calling
log.cfg()
beforebox.cfg()
takes into account logging options specified using environment variables, such asTT_LOG
andTT_LOG_LEVEL
.
-
log.
error
(message)¶ -
log.
warn
(message)¶ -
log.
info
(message)¶ -
log.
verbose
(message)¶ -
log.
debug
(message)¶ Log a message with the specified logging level. You can learn more about the available levels from the log_level property description.
The example below shows how to log a message with the
info
level:log = require('log') -- Prints 'warn' messages -- log.warn('Warning message') --[[ 2023-07-20 11:03:57.029 [16300] main/103/interactive/tarantool [C]:-1 W> Warning message --- ... --]]
Параметры: - message (
any
) –A log message.
- A message can be a string.
- A message may contain C-style format specifiers
%d
or%s
. Example:box.cfg{} log = require('log') log.info('Info %s', box.info.version)
- A message may be a scalar data type or a table. Example:
log = require('log') log.error({500,'Internal error'})
возвращает: nil
Выходное значение будет представлять собой строку в журнале, которая содержит следующее:
- the current timestamp
- a module name
- „E“, „W“, „I“, „V“ or „D“ depending on the called function
message
Note that the message will not be logged if the severity level corresponding to the called function is less than log_level.
- message (
-
log.
pid
()¶ возвращает: A PID of a logger. You can use this PID to send a signal to a log rotation program, so it can rotate logs.
-
log.
rotate
()¶ Rotate the log. For example, you need to call this function to continue logging after a log rotation program renames or moves a file with the latest logs.
возвращает: nil
-
log.
new
(name)¶ Since: 2.11.0
Create a new logger with the specified name. You can configure a specific log level for a new logger using the log_modules configuration property.
Параметры: - name (
string
) – a logger name
возвращает: a logger instance
Example:
The code snippet below shows how to set the
verbose
level formodule1
and theerror
level formodule2
:box_cfg = { log_level = 'warn', log_modules = { module1 = 'verbose', module2 = 'error' } }
To create the
module1
andmodule2
loggers, call thenew()
function:-- Creates new loggers -- module1_log = require('log').new('module1') module2_log = require('log').new('module2')
Then, you can call functions corresponding to different logging levels to make sure that events with severities above or equal to the given levels are shown:
-- Prints 'info' messages -- module1_log.info('Info message from module1') --[[ [16300] main/103/interactive/module1 I> Info message from module1 --- ... --]] -- Swallows 'debug' messages -- module1_log.debug('Debug message from module1') --[[ --- ... --]] -- Swallows 'info' messages -- module2_log.info('Info message from module2') --[[ --- ... --]]
At the same time, the events with severities below the specified levels are swallowed.
- name (