leque / fluent-logger-gauche

A structured logger for Fluentd implemented in Gauche

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

fluent-logger-gauche Build Status

A structured logger for Fluentd implemented in Gauche.

LICENSE

MIT

Requirement

  • Gauche 0.9.5 or later

Installation

$ autoconf
$ ./configure
$ make check
$ sudo make install

API

Module: fluent-logger

Class: <fluent-logger>

Instance Variable of <fluent-logger>: tag

The tag prefix string used for this logger.

Instance Variable of <fluent-logger>: sender

The <fluent-logger-sender> instance used to send logs.

Procedure: fluent-logger-log logger label :rest key value …​

Procedure: fluent-logger-log logger label timestamp :rest key value …​

Sends a log message.

logger

The <fluent-logger> instance.

label

The string label for the log message. The tag of the log will be tag.label.

timestamp

The optional timestamp <time> or unixtime integer in seconds. If omitted or #f is supplied, (current-time) is used.

key value …​

key-value pairs of the log record fields. keys must be <keyword> and values must be able to be converted to JSON by construct-json-string procedure.

For example, the code below

(define sender (make-fluent-logger-inet-socket-sender))
(define logger (make <fluent-logger> :sender sender :tag "tag"))

(fluent-logger-log logger "name" :message "bar")

sends a log message such as

[
  "tag.name",
  1441588984,
  {"message": "bar"}
]

Procedure: fluent-logger-flush logger

Flushes logger's buffer.

Procedure: fluent-logger-close logger

Closes logger. Also flushes logger's buffer.

Module: fluent-logger.sender

Class: <fluent-logger-sender>

Abstract class representing a log sender.

Module: fluent-logger.sender.socket-sender

Procedure: make-fluent-logger-inet-socket-sender :key host port log-drain timeout buffer-capaticy buffer-overflow-handler

Create a sender which sends log messages via an inet socket. This sender connect/reconnect to the host as needed. If you do not send log messages, the sender does not connect to the host.

host

the hostname string. The default is "localhost".

port

the port number. The default is 24224.

log-drain

the <log-drain> for internal logging. The default log-drain does not record any internal logs.

timeout

timeout for send, in seconds. The default timeout is 3000 sec.

buffer-capacity

the size in bytes of the internal buffer which contains pending log messages. A size of each log messages must be less than or equal to this value. The default is 8MB.

buffer-overflow-handler

when the internal buffer overflows, this procedure is called with 3 arguments: the sender, the buffer port created by open-output-uvector, and the message string that is being put into the buffer. The default handler simply ignore overflows.

Procedure: make-fluent-logger-unix-domain-socket-sender :key path log-drain timeout buffer-capaticy buffer-overflow-handler

Similar to make-fluent-logger-inet-socket-sender, but sends logs via a unix domain socket.

path

the path to the unix domain socket.

log-drain

see make-fluent-logger-inet-socket-sender

timeout

see make-fluent-logger-inet-socket-sender

buffer-capacity

see make-fluent-logger-inet-socket-sender

buffer-overflow-handler

see make-fluent-logger-inet-socket-sender

About

A structured logger for Fluentd implemented in Gauche

License:MIT License


Languages

Language:Scheme 79.2%Language:M4 12.3%Language:Makefile 7.6%Language:Shell 1.0%