Module log
ballerina/log Ballerina library
Overview
This module provides APIs to log information when running applications.
A sample log message logged from the foo
module would look as follows:
time = 2021-05-12T11:20:29.362+05:30 level = ERROR module = myorg/foo message = "Something went wrong"
Log levels
The log
module provides APIs to log at four levels, which are DEBUG
, ERROR
, INFO
, and WARN
. By default, all log messages are logged to the console at the INFO
level.
The log level can be configured via a Ballerina configuration file.
To set the global log level, place the entry given below in the Config.toml
file:
[ballerina.log] level = "[LOG_LEVEL]"
Each module can also be assigned its own log level. To assign a log level to a module, provide the following entry in the Config.toml
file:
[[ballerina.log.modules]] name = "[ORG_NAME]/[MODULE_NAME]" level = "[LOG_LEVEL]"
Log output
Logs are written to the stderr
stream by default.
To publish the logs to a file, redirect the stderr
stream to a file as follows.
$ bal run program.bal 2> b7a-user.log
By default, logs are printed in the LogFmt
format. To set the output format to JSON, place the entry given below in the Config.toml
file.
[ballerina.log] format = "json"
A sample log message logged from the foo
module in JSON format would look as follows:
{"time":"2021-05-12T11:26:00.021+05:30", "level":"INFO", "module":"myorg/foo", "message":"Authenticating user"}
For information on the operations, which you can perform with the log
module, see the below Functions.
Import
import ballerina/log;