From 6f49591e7d5bf11d8bfc6014a0711ae59e3f3c33 Mon Sep 17 00:00:00 2001
From: Siri Hansen Metadata associated with the message to be logged. Metadata for the log event. Logger adds the following metadata to each log event: When a log macro is used, Logger also inserts location
+ information: You can add custom metadata, either by specifying a map as
+ the last parameter to any of the log macros or the API
+ functions, or by setting process metadata
+ with Logger merges all the metadata maps before forwarding the
+ log event to the handlers. If the same keys occur, values
+ from the log call overwrites process metadata, which in turn
+ overwrites values set by Logger. Configuration data for the logger part of Logger, or for a handler. The following default values apply: See the A unique identifier for a handler instance. A unique identifier for a filter. A filter which can be installed for logger or for a handler. The second argument to the filter fun. The return value from the filter fun. A timestamp produced
+ with All macros expand to a call to logger, where
+
+
+
+
+
+
-#{mfa=>{?MODULE,?FUNCTION_NAME,?FUNCTION_ARITY},
- file=>?FILE,
- line=>?LINE}
-
+ taken from the macro name, and location data is added. See the
+ description of
+ the
The call is wrapped in a case statement and will be evaluated
only if Same as The Display or return all current logger configuration. Return the pretty printed current logger configuration
+ as iodata. Return the current logger configuration as a term. The
+ format of this term may change inbetween releases. For a
+ stable format use
Pretty print all the current logger configuration to + standard out. Example:
logger:i(print).
Current logger configuration:
Level: info
@@ -339,6 +387,39 @@ Current logger configuration:
Add a filter to the logger.
Add a filter to the logger.
+ The filter fun is called with the log event as the first
+ parameter, and the specified filter_args() as the
+ second parameter.
+ The return value of the fun specifies if a log event is to
+ be discarded or forwarded to the handlers:
+
+ log()
+ -
+
The filter passed. The next logger filter, if
+ any, is applied. If no more logger filters exist, the
+ log event is forwarded to the handler part of the
+ logger, where handler filters are applied.
+
+ stop
+ -
+
The filter did not pass, and the log event is
+ immediately discarded.
+
+ ignore
+ -
+
The filter has no knowledge of the log event. The next
+ logger filter, if any, is applied. If no more logger
+ filters exist, the value of the filter_default
+ configuration parameter for the logger specifies if the
+ log event shall be discarded or forwarded to the handler
+ part.
+
+
+ See section
+ Filter in the User's Guide for more information
+ about filters.
+ Some built-in filters exist. These are defined
+ in logger_filters .
@@ -347,6 +428,39 @@ Current logger configuration:
Add a filter to the specified handler.
Add a filter to the specified handler.
+ The filter fun is called with the log event as the first
+ parameter, and the specified filter_args() as the
+ second parameter.
+ The return value of the fun specifies if a log event is to
+ be discarded or forwarded to the handler callback:
+
+ log()
+ -
+
The filter passed. The next handler filter, if
+ any, is applied. If no more filters exist for this
+ handler, the log event is forwarded to the handler
+ callback.
+
+ stop
+ -
+
The filter did not pass, and the log event is
+ immediately discarded.
+
+ ignore
+ -
+
The filter has no knowledge of the log event. The next
+ handler filter, if any, is applied. If no more filters
+ exist for this handler, the value of
+ the filter_default configuration parameter for
+ the handler specifies if the log event shall be
+ discarded or forwarded to the handler callback.
+
+
+ See
+ section Filter
+ in the User's Guide for more information about filters.
+ Some built-in filters exist. These are defined in
+ logger_filters .
@@ -354,7 +468,8 @@ Current logger configuration:
Remove a filter from the logger.
- Remove the filter with the specified identity from the logger.
+ Remove the filter identified
+ by FilterId from the logger.
@@ -362,7 +477,9 @@ Current logger configuration:
Remove a filter from the specified handler.
- Remove the filter with the specified identity from the given handler.
+ Remove the filter identified
+ by FilterId from the handler identified
+ by HandlerId .
@@ -371,6 +488,9 @@ Current logger configuration:
Add a handler with the given configuration.
Add a handler with the given configuration.
+ HandlerId is a unique identifier which
+ must be used in all subsequent calls reffering to this
+ handler.
@@ -378,7 +498,7 @@ Current logger configuration:
Remove the handler with the specified identity.
- Remove the handler with the specified identity.
+ Remove the handler identified by HandlerId .
@@ -386,10 +506,37 @@ Current logger configuration:
Set the log level for the specified module.
- Set the log level for the specified module.
- To change the logging level globally, use
- logger:set_logger_config(level, Level) .
-
+ Set the log level for the
+ specified Module .
+ The log level for a module overrides the global log level
+ of the logger for log event originating from the module in
+ question. Notice, however, that it does not override the
+ level configuration for any handler.
+ For example: Assume that the global log level for the
+ logger is info , and there is one handler, h1 ,
+ with level info and one handler, h2 , with
+ level debug .
+ With this configuration, no debug messages will be logged,
+ since they are all stopped by the global log level.
+ If the level for mymodule is set now set
+ to debug , then debug events from this module will be
+ logged by the handler h2 , but not by
+ handler h1 .
+ Debug events from other modules are still not logged.
+ To change the global log level for the logger, use
+
+ logger:set_logger_config(level,Level) .
+ To change the log level for a handler, use
+
+ logger:set_handler_config(HandlerId,level,Level) .
+
+ The originating module for a log event is only detected
+ if mfa=>{Module,Function,Arity} exists in the
+ metadata. When log macros are used, this association is
+ automatically added to all log events. If the logger API
+ is called directly, without using a macro, the logging
+ client must explicitly add this information.
+
@@ -414,6 +561,8 @@ Current logger configuration:
with get_logger_config/0
, then merge in your added or updated
associations before writing it back.
+ If a key is removed compared to the current configuration,
+ the default value is used.
@@ -423,7 +572,7 @@ Current logger configuration:
Add or update configuration data for the logger. If the
given Key already exists, its associated
- value will be set to Value . If it
+ value will be changed to Value . If it
doesn't exist, it will be added.
@@ -440,6 +589,11 @@ Current logger configuration:
with get_handler_config/1
, then merge in your added or updated
associations before writing it back.
+ If a key is removed compared to the current configuration,
+ and the key is know by Logger, the default value is used. If
+ it is a custom key, then it is up to the handler
+ implementation if the value is removed or a default value is
+ inserted.
@@ -449,10 +603,10 @@ Current logger configuration:
handler.
Add or update configuration data for the specified
- handler. If the
- given Key already exists, its associated
- value will be set to Value . If it
- doesn't exist, it will be added.
+ handler. If the given Key already
+ exists, its associated value will be changed
+ to Value . If it doesn't exist, it will
+ be added.
@@ -471,30 +625,36 @@ Current logger configuration:
Set metadata to use when logging from current process.
- Set metadata which logger automatically inserts in
- all log events produced on the current process. Subsequent
- calls will overwrite previous data set by this function.
- When logging, location data produced by the log macros,
- and/or metadata given as argument to the log call (API
- function or macro), will be merged with the process
- metadata. If the same keys occur, values from the metadata
- argument to the log call will overwrite values in the
- process metadata, which in turn will overwrite values from
- the location data.
+ Set metadata which Logger shall automatically insert in
+ all log events produced on the current process.
+ Location data produced by the log macros, and/or metadata
+ given as argument to the log call (API function or macro),
+ are merged with the process metadata. If the same keys
+ occur, values from the metadata argument to the log call
+ overwrite values from the process metadata, which in turn
+ overwrite values from the location data.
+ Subsequent calls to this function overwrites previous data
+ set. To update existing data instead of overwriting it,
+ see
+ update_process_metadata/1 .
- Update metadata to use when logging from current process.
+ Set or update metadata to use when logging from
+ current process.
- Update metadata to use when logging from current process
- This function behaves as if it was implemented as follows:
+ Set or update metadata to use when logging from current
+ process
+ If process metadata exists for the current process, this
+ function behaves as if it was implemented as follows:
logger:set_process_metadata(maps:merge(logger:get_process_metadata(),Meta))
If no process metadata exists, the function behaves as
- set_process_metadata/1
+
+ set_process_metadata/1
.
@@ -505,7 +665,9 @@ logger:set_process_metadata(maps:merge(logger:get_process_metadata(),Meta))
Retrieve data set
with
- set_process_metadata/1 .
+ set_process_metadata/1 or
+
+ update_process_metadata/1 .
@@ -515,12 +677,103 @@ logger:set_process_metadata(maps:merge(logger:get_process_metadata(),Meta))
Delete data set
with
- set_process_metadata/1 .
+ set_process_metadata/1 or
+
+ update_process_metadata/1 .
+
+
+
+
+
+ Convert a log message on report form to {Format,Args}.
+
+ Convert a log message on report form to {Format,Args} .
+ This is the default report callback used
+ by
+ logger_formatter when no custom report
+ callback is found.
+ The function produces lines of Key: Value from
+ key-value lists. Strings are printed with ~ts and
+ other terms with ~tp .
+ If the Report is a map, it is
+ converted to a key-value list before formatting as such.
+
+ Callback Functions
+ The following functions are to be exported from a handler
+ callback module.
+
+
+
+
+ Module:adding_handler(HandlerId,Config1) -> {ok,Config2} | {error,Reason}
+ An instance of this handler is about to be added.
+
+ HandlerId =
+ handler_id()
+ Config1 = Config2 =
+ config()
+ Reason = term()
+
+
+ This callback function is optional.
+ The function is called when an new handler is about to be
+ added, and the purpose is to verify the configuration and
+ initiate all resourced needed by the handler.
+ If everything succeeds, the callback function can add
+ possible default values or internal state values to the
+ configuration, and return the adjusted map
+ in {ok,Config2} .
+ If the configuration is faulty, or if the initiation fails,
+ the callback function must return {error,Reason} .
+
+
+
+
+ Module:removing_handler(HandlerId,Config) -> ok
+ The given handler is about to be removed.
+
+ HandlerId =
+ handler_id()
+ Config =
+ config()
+
+
+ This callback function is optional.
+ The function is called when a handler is about to be
+ removed, and the purpose is to release all resources used by
+ the handler. The return value is ignored by Logger.
+
+
+
+
+ Module:changing_config(HandlerId,Config1,Config2) -> {ok,Config3} | {error,Reason}
+ The configuration for this handler is about to change.
+
+ HandlerId =
+ handler_id()
+ Config1 = Config2 = Config3 =
+ config()
+ Reason = term()
+
+
+ This callback function is optional.
+ The function is called when the configuration for a handler
+ is about to change, and the purpose is to verify and act on
+ the new configuration.
+ Config1 is the existing configuration
+ and Config2 is the new configuration.
+ If everything succeeds, the callback function must return a
+ possibly adjusted configuration in {ok,Config3} .
+ If the configuration is faulty, the callback function must
+ return {error,Reason} .
+
+
+
diff --git a/lib/kernel/doc/src/logger_filters.xml b/lib/kernel/doc/src/logger_filters.xml
index d742391e35..c34ec7d14c 100644
--- a/lib/kernel/doc/src/logger_filters.xml
+++ b/lib/kernel/doc/src/logger_filters.xml
@@ -33,16 +33,20 @@
logger_filters.xml
logger_filters
- Filters to use with logger.
+ Filters to use with Logger.
- Filters to use with logger. All functions exported from this
- module can be used as logger or handler
+
All functions exported from this module can be used as logger
+ or handler
filters. See
logger:add_logger_filter/2
and
- logger:add_handler_filter/3
- for more information about how filters are added.
+ logger:add_handler_filter/3 for more information
+ about how filters are added.
+ Filters are removed with
+ logger:remove_logger_filter/1
+ and
+ logger:remove_handler_filter/2 .
diff --git a/lib/kernel/doc/src/logger_formatter.xml b/lib/kernel/doc/src/logger_formatter.xml
index a0940100ee..7df4c88f40 100644
--- a/lib/kernel/doc/src/logger_formatter.xml
+++ b/lib/kernel/doc/src/logger_formatter.xml
@@ -33,43 +33,38 @@
logger_formatter.xml
logger_formatter
- Default formatter for the Logger application.
+ Default formatter for Logger.
- Default formatter for the Logger application.
-
+ Each log handler has a configured formatter specified as a
+ module and a configuration term. The purpose of the formatter is
+ to translate the log events to a final printable string
+ (unicode:chardata() ) which can be written to the output
+ device of the handler.
+ logger_formatter is the default formatter used by
+ Logger.
Configuration
- The following configuration parameters can be set
- for logger_formatter :
+ The configuration term for logger_formatter is a map,
+ and the following keys can be set as configuration
+ parameters:
- single_line = boolean()
- -
-
If set to true , all newlines in the message are
- replaced with ", " , and whitespaces following
- directly after newlines are removed. Note that newlines
- added by the formatter template are not replaced.
- Default is true .
-
- legacy_header = boolen()
- -
-
If set to true a header field is added to
- logger_formatter's part of Metadata . The value of
- this field is a string similar to the header created by the
- old error_logger event handlers. It can be included
- in the log event by adding the
- tuple {logger_formatter,header} to the
- template. See Default
- Templates for more information
- Default is false .
-
- report_cb = fun((logger:report()) -> {io:format(),[term()]})
+ chars_limit = pos_integer() | unlimited
-
-
A function with arity 1,
- returning {Format,Args} . This function will replace
- any report_cb found in metadata.
+ A positive integer representing the value of the option
+ with the same name to be used when calling
+ io_lib:format/3 .
+ This value limits the total number of characters printed
+ for each log event. Notice that this is a soft limit. For a
+ hard truncation limit, see option max_size .
+ Default is unlimited .
+
+ chars_limit has no effect on log messages on
+ string form. These are expected to be short, but can still
+ be truncated by the max_size parameter.
+
depth = pos_integer() | unlimited
-
@@ -82,47 +77,79 @@
io:format/2,3
in STDLIB.
Default is unlimited .
-
- chars_limit = pos_integer() | unlimited
- -
-
A positive integer representing the value of the option
- with the same name to be used when calling
- io_lib:format/3 .
- This value limits the total number of characters printed
- for each log event. Note that this is a soft limit. For a
- hard truncation limit, see option max_size .
- Default is unlimited .
+
+ depth has no effect on log messages on string
+ form. These are expected to be short, but can still be
+ truncated by the max_size parameter.
+
max_size = pos_integer() | unlimited
-
-
A positive integer representing the absolute maximum size
- a string returned from this formatter can have. If the
+
A positive integer representing the absolute maximum size a
+ string returned from this formatter can have. If the
formatted string is longer, after possibly being limited
- by depth and/or chars_limit , it will be
- truncated.
+ by chars_limit or depth , it is truncated.
Default is unlimited .
+ single_line = boolean()
+ -
+
If set to true , all newlines in the message are
+ replaced with ", " , and whitespaces following
+ directly after newlines are removed. Note that newlines
+ added by the template parameter are not replaced.
+ Default is true .
+
+ legacy_header = boolen()
+ -
+
If set to true a header field is added to
+ logger_formatter's part of Metadata . The value of
+ this field is a string similar to the header created by the
+ old error_logger event handlers. It can be included
+ in the log event by adding the
+ tuple {logger_formatter,header} to the template. See
+ section Default
+ Templates for more information.
+ Default is false .
+
+ report_cb = fun(( logger:report() ) -> { io:format() ,[term()]})
+ -
+
A report callback is used by the formatter to transform log
+ messages on report form to a format string and
+ arguments. The report callback can be specified in the
+ metadata for the log event. If no report callback exist in
+ metadata, logger_formatter will
+ use
+ logger:format_report/1 as default
+ callback.
+ If this configuration parameter is set, it replaces both
+ the default report callback, and any report callback found
+ in metadata. That is, all reports are converted by this
+ configured function.
+ The value must be a function with arity 1,
+ returning {Format,Args} , and it will be called with a
+ report as only argument.
+
template = template()
-
The template is a list of atoms, tuples and strings. The
atoms level or msg , are treated as
placeholders for the severity level and the log message,
repectively. Other atoms or tuples are interpreted as
- placeholders for metadata, where atoms are expected to
- match top level keys, and tuples represent paths to sub
- keys in a nested map. For example the
- tuple {key1,key2} will be replaced by the value of
+ placeholders for metadata, where atoms are expected to match
+ top level keys, and tuples represent paths to sub keys when
+ the metadata is a nested map. For example the
+ tuple {key1,key2} is replaced by the value of
the key2 field in the nested map below. The
- atom key1 on its own would be replaced by the
- complete value of the key1 field. The values are
- converted to strings.
+ atom key1 on its own is replaced by the complete
+ value of the key1 field. The values are converted to
+ strings.
#{key1=>#{key2=>my_value,
...}
...}
- Strings are printed literally.
+ Strings in the template are printed literally.
The default template differs depending on the values
of legacy_header
and single_line . See Default
@@ -131,7 +158,8 @@
utc = boolean()
-
If set to true , all dates are displayed in Universal
- Coordinated Time. Default is false .
+ Coordinated Time.
+ Default is false .
@@ -139,38 +167,51 @@
Default templates
- The default template when legacy_header=true is
-
- [{logger_formatter,header},"\n",msg,"\n"]
-
- which will cause log entries like this:
-
- =ERROR REPORT==== 29-Dec-2017::13:30:51.245123 ===
- process: <0.74.0>
- exit_reason: "Something went wrong"
-
- Note that all eight levels might occur here, not
- only ERROR , WARNING or INFO . And also that
- micro seconds are added at the end of the timestamp.
-
- The default template when single_line=true is
- [time," ",level,": ",msg,"\n"]
+ The default value for the template configuration
+ parameter depends on the value of single_line
+ and legacy_header as follows.
- which will cause log entries like this:
+ The log event used in the examples is:
+
+?LOG_ERROR("name: ~p~nexit_reason: ~p",[my_reg_name,"It crashed"])
- 2017-12-29 13:31:49.640317 error: process: <0.74.0>, exit_reason: "Something went wrong"
+
+ legacy_header=true
+ -
+
Default template: [{logger_formatter,header},"\n",msg,"\n"]
+
+ Example log entry:
+
+=ERROR REPORT==== 29-Dec-2017::13:30:51.245123 ===
+name: my_reg_name
+exit_reason: "It crashed"
+
+ Notice that all eight levels might occur in the heading,
+ not only ERROR , WARNING or INFO as the
+ old error_logger produced. And microseconds are
+ added at the end of the timestamp.
+
- The default template when both legacy_header and
- single_line are set to false is:
+ single_line=true
+ -
+
Default template: [time," ",level,": ",msg,"\n"]
- [time," ",level,":\n",msg,"\n"]
+ Example log entry:
+ 2017-12-29 13:31:49.640317 error: name: my_reg_name, exit_reason: "It crashed"
+
- which will cause log entries like this:
+ legacy_header=false, single_line=false
+ -
+
Default template: [time," ",level,":\n",msg,"\n"]
- 2017-12-29 13:32:25.191925 error:
- process: <0.74.0>
- exit_reason: "Something went wrong"
+ Example log entry:
+
+2017-12-29 13:32:25.191925 error:
+name: my_reg_name
+exit_reason: "It crashed"
+
+
@@ -186,8 +227,22 @@
Formats the given message.
- This the callback function to be called from handlers. It
- formats the given messages.
+ This the formatter callback function to be called from
+ handlers. The log event is processed as follows:
+
+ - If the message is on report form, it is converted to
+
{Format,Args} by calling the report
+ callback.
+ - The size is limited according to the values of
+ configuration parameters
chars_limit
+ and depth . Notice that this does not apply to
+ messages on string form.
+ - The full log entry is composed according to
+ the
template .
+ - If the final string is too long, it is truncated
+ according to the value of configuration
+ parameter
max_size .
+
--
cgit v1.2.3