1logger_std_h(3) Erlang Module Definition logger_std_h(3)
2
3
4
6 logger_std_h - Standard handler for Logger.
7
9 This is the standard handler for Logger. Multiple instances of this
10 handler can be added to Logger, and each instance prints logs to stan‐
11 dard_io, standard_error, or to file.
12
13 The handler has an overload protection mechanism that keeps the handler
14 process and the Kernel application alive during high loads of log
15 events. How overload protection works, and how to configure it, is de‐
16 scribed in the User's Guide.
17
18 To add a new instance of the standard handler, use logger:add_han‐
19 dler/3. The handler configuration argument is a map which can contain
20 general configuration parameters, as documented in the User's Guide,
21 and handler specific parameters. The specific data is stored in a sub
22 map with the key config, and can contain the following parameters:
23
24 type = standard_io | standard_error | file | {device, io:device()}:
25 Specifies the log destination.
26
27 The value is set when the handler is added, and it cannot be
28 changed in runtime.
29
30 Defaults to standard_io, unless parameter file is given, in which
31 case it defaults to file.
32
33 file = file:filename():
34 This specifies the name of the log file when the handler is of type
35 file.
36
37 The value is set when the handler is added, and it cannot be
38 changed in runtime.
39
40 Defaults to the same name as the handler identity, in the current
41 directory.
42
43 modes = [file:mode()]:
44 This specifies the file modes to use when opening the log file, see
45 file:open/2. If modes are not specified, the default list used is
46 [raw,append,delayed_write]. If modes are specified, the list re‐
47 places the default modes list with the following adjustments:
48
49 *
50 If raw is not found in the list, it is added.
51
52 *
53 If none of write, append or exclusive is found in the list, ap‐
54 pend is added.
55
56 * If none of delayed_write or {delayed_write,Size,Delay} is found
57 in the list, delayed_write is added.
58
59 Log files are always UTF-8 encoded. The encoding cannot be changed
60 by setting the mode {encoding,Encoding}.
61
62 The value is set when the handler is added, and it cannot be
63 changed in runtime.
64
65 Defaults to [raw,append,delayed_write].
66
67 max_no_bytes = pos_integer() | infinity:
68 This parameter specifies if the log file should be rotated or not.
69 The value infinity means the log file will grow indefinitely, while
70 an integer value specifies at which file size (bytes) the file is
71 rotated.
72
73 Defaults to infinity.
74
75 max_no_files = non_neg_integer():
76 This parameter specifies the number of rotated log file archives to
77 keep. This has meaning only if max_no_bytes is set to an integer
78 value.
79
80 The log archives are named FileName.0, FileName.1, ... FileName.N,
81 where FileName is the name of the current log file. FileName.0 is
82 the newest of the archives. The maximum value for N is the value of
83 max_no_files minus 1.
84
85 Notice that setting this value to 0 does not turn off rotation. It
86 only specifies that no archives are kept.
87
88 Defaults to 0.
89
90 compress_on_rotate = boolean():
91 This parameter specifies if the rotated log file archives shall be
92 compressed or not. If set to true, all archives are compressed with
93 gzip, and renamed to FileName.N.gz
94
95 compress_on_rotate has no meaning if max_no_bytes has the value in‐
96 finity.
97
98 Defaults to false.
99
100 file_check = non_neg_integer():
101 When logger_std_h logs to a file, it reads the file information of
102 the log file prior to each write operation. This is to make sure
103 the file still exists and has the same inode as when it was opened.
104 This implies some performance loss, but ensures that no log events
105 are lost in the case when the file has been removed or renamed by
106 an external actor.
107
108 In order to allow minimizing the performance loss, the file_check
109 parameter can be set to a positive integer value, N. The handler
110 will then skip reading the file information prior to writing, as
111 long as no more than N milliseconds have passed since it was last
112 read.
113
114 Notice that the risk of losing log events grows when the file_check
115 value grows.
116
117 Defaults to 0.
118
119 filesync_repeat_interval = pos_integer() | no_repeat:
120 This value, in milliseconds, specifies how often the handler does a
121 file sync operation to write buffered data to disk. The handler at‐
122 tempts the operation repeatedly, but only performs a new sync if
123 something has actually been logged.
124
125 If no_repeat is set as value, the repeated file sync operation is
126 disabled, and it is the operating system settings that determine
127 how quickly or slowly data is written to disk. The user can also
128 call the filesync/1 function to perform a file sync.
129
130 Defaults to 5000 milliseconds.
131
132 Other configuration parameters exist, to be used for customizing the
133 overload protection behaviour. The same parameters are used both in the
134 standard handler and the disk_log handler, and are documented in the
135 User's Guide.
136
137 Notice that if changing the configuration of the handler in runtime,
138 the type, file, or modes parameters must not be modified.
139
140 Example of adding a standard handler:
141
142 logger:add_handler(my_standard_h, logger_std_h,
143 #{config => #{file => "./system_info.log",
144 filesync_repeat_interval => 1000}}).
145
146
147 To set the default handler, that starts initially with the Kernel ap‐
148 plication, to log to file instead of standard_io, change the Kernel de‐
149 fault logger configuration. Example:
150
151 erl -kernel logger '[{handler,default,logger_std_h,
152 #{config => #{file => "./log.log"}}}]'
153
154
155 An example of how to replace the standard handler with a disk_log han‐
156 dler at startup is found in the logger_disk_log_h manual.
157
159 filesync(Name) -> ok | {error, Reason}
160
161 Types:
162
163 Name = atom()
164 Reason = handler_busy | {badarg, term()}
165
166 Write buffered data to disk.
167
169 logger(3), logger_disk_log_h(3)
170
171
172
173Ericsson AB kernel 8.5.3 logger_std_h(3)