-
Notifications
You must be signed in to change notification settings - Fork 13
Receiver reference
Function: Writes received messages to a file
Element name: file
Allowed attributes:
- formatid - format that will be used by this receiver
- path - path to the log file
Example:
<seelog>
<outputs>
<file path="log.log"/>
</outputs>
</seelog>
Function: writes received messages to std out
Element name: Console
Allowed attributes:
- formatid - format that will be used by this receiver
Example:
<seelog>
<outputs>
<console/>
</outputs>
</seelog>
Function: Writes received messages to a file, until date changes or file exceeds a specified limit. After that the current log file is renamed and writer starts to log into a new file. If you roll by size, you can set a limit for such renamed files count, if you want, and then the rolling writer would delete older ones when the files count exceed the specified limit.
Element name: rollingfile
Allowed attributes:
-
formatid - format that will be used by this receiver
-
filename - path to the log file. On creation, this path is split into folder path and actual file name. The latter will be used as a common part for all files, that act in rolling:
- In case of 'date' rolling, the file names will be formed this way:
time.LocalTime().Format(rollFileWriter.datePattern)+" "+rollFileWriter.fileName)
- In case of 'size' rolling, the file names will be formed this way: "filename.#". For example: app.log, app.log.1, app.log.2, app.log.3, ...
-
type - rotation type: "date" or "size"
-
maxrolls - an attribute used only with type="size". Maximal count of renamed files. When this limit is exceeded, older rolls are removed. Should be >= zero.
-
maxsize - an attribute used only with type="size". This is the size limit (in bytes) exceeding which results in a roll.
-
datepattern - an attribute used only with type="date". This is the pattern that would be used in 'time.LocalTime().Format' to form a file name. The "date" (actually, this means both date & time) rolling occurs when 'time.LocalTime().Format(rollFileWriter.datePattern)' returns something different than the current file name. This means that you create daily rotation using a format with a day identifier like "02.01.2006". Or you can create an hourly rotation using a format with an hour identifier like "02.01.2006.15".
Important: Do not use any special symbols that are not allowed in filenames.
Example:
<seelog>
<outputs>
<rollingfile type="size" filename="logs/roll.log" maxsize="1000" maxrolls="5" />
</outputs>
</seelog>
<seelog>
<outputs>
<rollingfile type="date" filename="logs/roll.log" datepattern="02.01.2006" />
</outputs>
</seelog>
Function: Acts like a buffer wrapping other writer. Buffered writer stores data in memory and flushes it every flush period or when buffer is full.
Element name: buffered
Allowed attributes:
- formatid - format that will be used by this receiver
- size - buffer size (in bytes)
- flushperiod - interval between buffer flushes (in milliseconds)
Example:
<seelog>
<outputs>
<buffered size="10000" flushperiod="1000">
<file path="bufFile.log"/>
</buffered>
</outputs>
</seelog>
<seelog>
<outputs>
<buffered size="10000" flushperiod="1000" formatid="someFormat">
<rollingfile type="date" filename="logs/roll.log" datepattern="02.01.2006" />
</buffered>
</outputs>
<formats>
...
</formats>
</seelog>
NOTE: This writer accumulates data written using a specific format and then flushes it into the inner writer. So inner writers couldn't have its own format: set 'formatid' only for buffered element, like in the last example.
Function: Sends emails to the specified recipients using a password-protected (but generally unsecured) email account at a given post server.
Element name: smtp
Allowed attributes:
- senderaddress - email address of the sender
- sendername - name of the sender
- hostname - host name of a post server (typically - mail.XXX.YYY)
- hostport - TCP port of the post server (typically - 587)
- username - user name used to login to the post server
- password - password to the post server
Allowed attributes:
- address - email address of the recipient (who receives messages from notifiers)
Example:
<seelog>
<outputs>
<smtp senderaddress="[email protected]" sendername="Automatic notification service" hostname="mail.none.org" hostport="587" username="nns" password="123">
<recipient address="[email protected]"/>
<recipient address="[email protected]"/>
</smtp>
</outputs>
</seelog>
<seelog>
<outputs>
<filter levels="error,critical">
<smtp senderaddress="[email protected]" sendername="ANS" hostname="mail.none.org" hostport="587" username="nns" password="123">
<recipient address="[email protected]"/>
</smtp>
</filter>
</outputs>
</seelog>
NOTE 1: Look at the first above example to get an idea of how to use SMTP writer. Keep in mind that email [email protected] must not be considered as security reliable. It's potentially exposed to hacking attacks due to explicit password publication in configs and we strongly recommend you not to use personal or corporate post accounts for SMTP writer. The best practice suggests dedicating an isolated post account especially for email notification service.
NOTE 2: The second example demonstrates the most sensible way to use this writer - notifications from the application on (rare) extraordinary situations. Technically, you can set other filter levels, yet get ready for being flooded with diagnostic emails.