aboutsummaryrefslogtreecommitdiffstats
path: root/lib/kernel/doc/src/logger_std_h.xml
blob: 5ed1a2f2109a8ca5dad1249cf3b4f3146fe68e02 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
<?xml version="1.0" encoding="utf-8" ?>
<!DOCTYPE erlref SYSTEM "erlref.dtd">

<erlref>
  <header>
    <copyright>
      <year>2017</year><year>2018</year>
      <holder>Ericsson AB. All Rights Reserved.</holder>
    </copyright>
    <legalnotice>
      Licensed under the Apache License, Version 2.0 (the "License");
      you may not use this file except in compliance with the License.
      You may obtain a copy of the License at

          http://www.apache.org/licenses/LICENSE-2.0

      Unless required by applicable law or agreed to in writing, software
      distributed under the License is distributed on an "AS IS" BASIS,
      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
      See the License for the specific language governing permissions and
      limitations under the License.

    </legalnotice>

    <title>logger_std_h</title>
    <prepared></prepared>
    <responsible></responsible>
    <docno></docno>
    <approved></approved>
    <checked></checked>
    <date></date>
    <rev>A</rev>
    <file>logger_std_h.xml</file>
  </header>
  <module since="OTP 21.0">logger_std_h</module>
  <modulesummary>Standard handler for Logger.</modulesummary>

  <description>
    <p>This is the standard handler for Logger.
      Multiple instances of this handler can be added to
      Logger, and each instance prints logs to <c>standard_io</c>,
      <c>standard_error</c>, or to file.</p>
    <p>The handler has an overload protection mechanism that keeps the handler
      process and the Kernel application alive during high loads of log 
      events. How overload protection works, and how to configure it, is
      described in the
      <seealso marker="logger_chapter#overload_protection"><c>User's Guide</c>
      </seealso>.</p>
    <p>To add a new instance of the standard handler, use
      <seealso marker="logger#add_handler-3"><c>logger:add_handler/3</c>
      </seealso>. The handler configuration argument is a map which can contain
      general configuration parameters, as documented in the
       <seealso marker="logger_chapter#handler_configuration"><c>User's Guide</c>
       </seealso>, and handler specific parameters. The specific data
       is stored in a sub map with the key <c>config</c>, and can contain the
       following parameters:</p>
    <taglist>
      <tag><marker id="type"/><c>type = standard_io | standard_error | file</c></tag>
      <item>
	<p>Specifies the log destination.</p>
	<p>The value is set when the handler is added, and it can not
	  be changed in runtime.</p>
	<p>Defaults to <c>standard_io</c>, unless
	  parameter <seealso marker="#file"><c>file</c></seealso> is
	  given, in which case it defaults to <c>file</c>.</p>
      </item>
      <tag><marker id="file"/><c>file = </c><seealso marker="file#type-filename"><c>file:filename()</c></seealso></tag>
      <item>
	<p>This specifies the name of the log file when the handler is
	  of type <c>file</c>.</p>
	<p>The value is set when the handler is added, and it can not
	  be changed in runtime.</p>
	<p>Defaults to the same name as the handler identity, in the
	  current directory.</p>
      </item>
      <tag><marker id="modes"/><c>modes = [</c><seealso marker="file#type-mode"><c>file:mode()</c></seealso><c>]</c></tag>
      <item>
	<p>This specifies the file modes to use when opening the log
	  file,
	  see <seealso marker="file#open-2"><c>file:open/2</c></seealso>.
	  If <c>modes</c> are not specified, the default list used
	  is <c>[raw,append,delayed_write]</c>. If <c>modes</c> are
	  specified, the list replaces the default modes list with the
	  following adjustments:</p>
	<list>
	  <item>
	    If <c>raw</c> is not found in the list, it is added.
	  </item>
	  <item>
	    If none of <c>write</c>, <c>append</c> or <c>exclusive</c> is
	    found in the list, <c>append</c> is added.</item>
	  <item>If none of <c>delayed_write</c>
	    or <c>{delayed_write,Size,Delay}</c> is found in the
	    list, <c>delayed_write</c> is added.</item>
	</list>
	<p>Log files are always UTF-8 encoded. The encoding can not be
	  changed by setting the mode <c>{encoding,Encoding}</c>.</p>
	<p>The value is set when the handler is added, and it can not
	  be changed in runtime.</p>
	<p>Defaults to <c>[raw,append,delayed_write]</c>.</p>
      </item>
      <tag><marker id="max_no_bytes"/><c>max_no_bytes = pos_integer() | infinity</c></tag>
      <item>
	<p>This parameter specifies if the log file should be rotated
	  or not. The value <c>infinity</c> means the log file will
	  grow indefinitely, while an integer value specifies at which
	  file size (bytes) the file is rotated.</p>
	<p>Defaults to <c>infinity</c>.</p>
      </item>
      <tag><marker id="max_no_files"/><c>max_no_files = non_neg_integer()</c></tag>
      <item>
	<p>This parameter specifies the number of rotated log file
	  archives to keep. This has meaning only
	  if <seealso marker="#max_no_bytes"><c>max_no_bytes</c></seealso>
	  is set to an integer value.</p>
	<p>The log archives are
	  named <c>FileName.0</c>, <c>FileName.1</c>,
	  ... <c>FileName.N</c>, where <c>FileName</c> is the name of
	  the current log file. <c>FileName.0</c> is the newest of the
	  archives. The maximum value for <c>N</c> is the value
	  of <c>max_no_files</c> minus 1.</p>
	<p>Notice that setting this value to <c>0</c> does not turn of
	  rotation. It only specifies that no archives are kept.</p>
	<p>Defaults to <c>0</c>.</p>
      </item>
      <tag><marker id="compress_on_rotate"/><c>compress_on_rotate = boolean()</c></tag>
      <item>
	<p>This parameter specifies if the rotated log file archives
	  shall be compressed or not. If set to <c>true</c>, all
	  archives are compressed with <c>gzip</c>, and renamed
	  to <c>FileName.N.gz</c></p>
	<p><c>compress_on_rotate</c> has no meaning if <seealso
	marker="#max_no_bytes"><c>max_no_bytes</c></seealso> has the
	value <c>infinity</c>.</p>
	<p>Defaults to <c>false</c>.</p>
      </item>
      <tag><marker id="file_check"/><c>file_check = non_neg_integer()</c></tag>
      <item>
	<p>When <c>logger_std_h</c> logs to a file, it reads the file
	  information of the log file prior to each write
	  operation. This is to make sure the file still exists and
	  has the same inode as when it was opened. This implies some
	  performance loss, but ensures that no log events are lost in
	  the case when the file has been removed or renamed by an
	  external actor.</p>
	<p>In order to allow minimizing the performance loss, the
	  <c>file_check</c> parameter can be set to a positive integer
	  value, <c>N</c>. The handler will then skip reading the file
	  information prior to writing, as long as no more
	  than <c>N</c> milliseconds have passed since it was last
	  read.</p>
	<p>Notice that the risk of loosing log events grows when
	  the <c>file_check</c> value grows.</p>
	<p>Defaults to 0.</p>
      </item>
      <tag><c>filesync_repeat_interval = pos_integer() | no_repeat</c></tag>
      <item>
	<p>This value, in milliseconds, specifies how often the handler does
	a file sync operation to write buffered data to disk. The handler attempts
	the operation repeatedly, but only performs a new sync if something has
	actually been logged.</p>
	<p>If <c>no_repeat</c> is set as value, the repeated file sync operation
	is disabled, and it is the operating system settings that determine
	how quickly or slowly data is written to disk. The user can also call
	the <seealso marker="logger_std_h#filesync-1"><c>filesync/1</c></seealso>
        function to perform a file sync.</p>
	<p>Defaults to <c>5000</c> milliseconds.</p>
      </item>
    </taglist>
    <p>Other configuration parameters exist, to be used for customizing
    the overload protection behaviour. The same parameters are used both in the
    standard handler and the disk_log handler, and are documented in the
    <seealso marker="logger_chapter#overload_protection"><c>User's Guide</c>
    </seealso>.</p>
    <p>Notice that if changing the configuration of the handler in
    runtime, the <c>type</c>, <c>file</c>, or <c>modes</c> parameters
    must not be modified.</p>
    <p>Example of adding a standard handler:</p>
    <code type="none">
logger:add_handler(my_standard_h, logger_std_h,
                   #{config => #{file => "./system_info.log",
                                 filesync_repeat_interval => 1000}}).
    </code>
    <p>To set the default handler, that starts initially with
    the Kernel application, to log to file instead of <c>standard_io</c>,
    change the Kernel default logger configuration. Example:</p>
    <code type="none">
erl -kernel logger '[{handler,default,logger_std_h,
                      #{config => #{file => "./log.log"}}}]'
    </code>
    <p>An example of how to replace the standard handler with a disk_log handler
    at startup is found in the
    <seealso marker="logger_disk_log_h"><c>logger_disk_log_h</c></seealso>
    manual.</p>
  </description>

  <funcs>

    <func>
      <name name="filesync" arity="1" clause_i="1" since="OTP 21.0"/>
      <fsummary>Writes buffered data to disk.</fsummary>
      <desc>
        <p>Write buffered data to disk.</p>
      </desc>
    </func>

  </funcs>

  <section>
    <title>See Also</title>
    <p><seealso marker="logger"><c>logger(3)</c></seealso>,
      <seealso marker="logger_disk_log_h">
	<c>logger_disk_log_h(3)</c></seealso></p>
  </section>
</erlref>