2023-02-27 01:31:40 +01:00
---
title: 'Logging Configuration'
2023-03-02 23:44:11 -07:00
license: 'Apache-2.0'
2024-04-21 15:56:01 +02:00
origin_url: 'https://github.com/go-gitea/gitea/blob/e865de1e9d65dc09797d165a51c8e705d2a86030/docs/content/administration/logging-config.en-us.md'
2023-02-27 01:31:40 +01:00
---
2023-02-27 01:34:05 +01:00
The logging configuration of Forgejo mainly consists of 3 types of components:
2023-02-27 01:31:40 +01:00
- The `[log]` section for general configuration
2023-06-05 18:24:04 +02:00
- `[log.<mode-name>]` sections for the configuration of different log writers to output logs, aka: "writer mode", the mode name is also used as "writer name".
- The `[log]` section can also contain sub-logger configurations following the key schema `logger.<logger-name>.<CONFIG-KEY>`
2023-02-27 01:31:40 +01:00
2023-06-05 18:24:04 +02:00
There is a fully functional log output by default, so it is not necessary to define one.
2023-02-27 01:31:40 +01:00
## The `[log]` section
2023-06-05 18:24:04 +02:00
Configuration of logging facilities in Forgejo happen in the `[log]` section and its subsections.
2023-02-27 01:31:40 +01:00
In the top level `[log]` section the following configurations can be placed:
2023-06-05 18:24:04 +02:00
- `ROOT_PATH` : (Default: ** %(GITEA_WORK_DIR)/log**): Base path for log files
2023-02-27 01:31:40 +01:00
- `MODE` : (Default: **console** ) List of log outputs to use for the Default logger.
2023-06-05 18:24:04 +02:00
- `LEVEL` : (Default: **Info** ) Least severe log events to persist, case-insensitive. Possible values are: `Trace` , `Debug` , `Info` , `Warn` , `Error` , `Fatal` .
- `STACKTRACE_LEVEL` : (Default: **None** ) For this and more severe events the stacktrace will be printed upon getting logged.
2023-02-27 01:31:40 +01:00
2023-06-05 18:24:04 +02:00
And it can contain the following sub-loggers:
2023-02-27 01:31:40 +01:00
2024-03-21 06:53:40 -05:00
- `logger.default.MODE` : (Default: ** ,**): List of log outputs to use for the default logger.
2023-06-05 18:24:04 +02:00
- `logger.router.MODE` : (Default: ** ,**): List of log outputs to use for the Router logger.
- `logger.access.MODE` : (Default: ** \<empty\>**) List of log outputs to use for the Access logger. By default, the access logger is disabled.
- `logger.xorm.MODE` : (Default: ** ,**) List of log outputs to use for the XORM logger.
2023-02-27 01:31:40 +01:00
2023-06-05 18:24:04 +02:00
Setting a comma (`,` ) to sub-logger's mode means making it use the default global `MODE` .
2023-02-27 01:31:40 +01:00
2023-06-05 18:24:04 +02:00
## Quick samples
### Default (empty) Configuration
The empty configuration is equivalent to default:
```ini
[log]
ROOT_PATH = %(GITEA_WORK_DIR)/log
MODE = console
LEVEL = Info
STACKTRACE_LEVEL = None
2024-03-21 06:53:40 -05:00
logger.default.MODE = ,
2023-06-05 18:24:04 +02:00
logger.router.MODE = ,
logger.xorm.MODE = ,
logger.access.MODE =
2023-02-27 01:31:40 +01:00
2023-06-05 18:24:04 +02:00
; this is the config options of "console" mode (used by MODE=console above)
[log.console]
MODE = console
FLAGS = stdflags
PREFIX =
COLORIZE = true
```
2023-02-27 01:31:40 +01:00
2023-06-05 18:24:04 +02:00
This is equivalent to sending all logs to the console, with default Golang log being sent to the console log too.
2023-02-27 01:31:40 +01:00
2023-06-05 18:24:04 +02:00
This is only a sample, and it is the default, do not need to write it into your configuration file.
2023-02-27 01:31:40 +01:00
2023-06-05 18:24:04 +02:00
### Disable Router logs and record some access logs to file
2023-02-27 01:31:40 +01:00
2023-06-05 18:24:04 +02:00
The Router logger is disabled, the access logs (>=Warn) goes into `access.log` :
2023-02-27 01:31:40 +01:00
2023-06-05 18:24:04 +02:00
```ini
[log]
logger.router.MODE =
logger.access.MODE = access-file
[log.access-file]
MODE = file
LEVEL = Warn
FILE_NAME = access.log
```
### Set different log levels for different modes
2024-03-21 06:53:40 -05:00
Default logs (>=Warn) goes into `gitea.log` , while Error logs goes into `file-error.log` :
2023-06-05 18:24:04 +02:00
```ini
[log]
LEVEL = Warn
MODE = file, file-error
2024-03-21 06:53:40 -05:00
; by default, the "file" mode will record logs to %(log.ROOT_PATH)/gitea.log, so we don't need to set it
2023-06-05 18:24:04 +02:00
; [log.file]
2023-08-22 18:42:41 +02:00
; by default, the MODE (actually it's the output writer of this logger) is taken from the section name, so we don't need to set it either
; MODE = file
2023-06-05 18:24:04 +02:00
[log.file-error]
2023-08-22 18:42:41 +02:00
MODE = file
2023-06-05 18:24:04 +02:00
LEVEL = Error
FILE_NAME = file-error.log
```
## Log outputs (mode and writer)
Forgejo provides the following log output writers:
- `console` - Log to `stdout` (or `stderr` if it is set in the config)
2023-02-27 01:31:40 +01:00
- `file` - Log to a file
- `conn` - Log to a socket (network or unix)
### Common configuration
Certain configuration is common to all modes of log output:
2023-06-05 18:24:04 +02:00
- `MODE` is the mode of the log output writer. It will default to the mode name in the ini section. Thus `[log.console]` will default to `MODE = console` .
- `LEVEL` is the lowest level that this output will log.
- `STACKTRACE_LEVEL` is the lowest level that this output will print a stacktrace.
2024-08-09 11:26:02 +02:00
- `COLORIZE` will default to `true` for `console` if writing to the terminal
(see below), otherwise it will default to `false` .
2023-02-27 01:31:40 +01:00
#### `EXPRESSION`
2023-06-05 18:24:04 +02:00
`EXPRESSION` represents a regular expression that log events must match to be logged by the output writer.
Either the log message, (with colors removed), must match or the `longfilename:linenumber:functionname` must match.
NB: the whole message or string doesn't need to completely match.
2023-02-27 01:31:40 +01:00
2023-06-05 18:24:04 +02:00
Please note this expression will be run in the writer's goroutine but not the logging event goroutine.
2023-02-27 01:31:40 +01:00
#### `FLAGS`
`FLAGS` represents the preceding logging context information that is
printed before each message. It is a comma-separated string set. The order of values does not matter.
2024-03-21 06:53:40 -05:00
It defaults to `stdflags` (= `date,time,medfile,shortfuncname,levelinitial` ). Except for the access log which defaults to `none`
2023-06-05 18:24:04 +02:00
2023-02-27 01:31:40 +01:00
Possible values are:
- `none` or `,` - No flags.
- `date` - the date in the local time zone: `2009/01/23` .
- `time` - the time in the local time zone: `01:23:23` .
2023-06-05 18:24:04 +02:00
- `microseconds` - microsecond resolution: `01:23:23.123123` . Assumes time.
2023-02-27 01:31:40 +01:00
- `longfile` - full file name and line number: `/a/b/c/d.go:23` .
- `shortfile` - final file name element and line number: `d.go:23` .
- `funcname` - function name of the caller: `runtime.Caller()` .
2023-06-05 18:24:04 +02:00
- `shortfuncname` - last part of the function name. Overrides `funcname` .
- `utc` - if date or time is set, use UTC rather than the local time zone.
- `levelinitial` - initial character of the provided level in brackets eg. `[I]` for info.
- `level` - level in brackets `[INFO]` .
2024-03-29 02:41:13 +01:00
- `levelprefix` - journald-style log level prefix, such as `<5>` for "info".
2023-06-05 18:24:04 +02:00
- `gopid` - the Goroutine-PID of the context.
- `medfile` - last 20 characters of the filename - equivalent to `shortfile,longfile` .
- `stdflags` - equivalent to `date,time,medfile,shortfuncname,levelinitial` .
2024-03-29 02:41:13 +01:00
- `journaldflags` - equivalent to `levelprefix` .
2023-02-27 01:31:40 +01:00
### Console mode
In this mode the logger will forward log messages to the stdout and
2023-02-27 01:34:05 +01:00
stderr streams attached to the Forgejo process.
2023-02-27 01:31:40 +01:00
2024-08-09 11:26:02 +02:00
For loggers in console mode, `COLORIZE` will default to `true` when appropriate:
- not on Windows, if the output is connected to a tty;
- on Windows, if the output is connected to either a Windows terminal
that can be switched into ANSI mode (Windows 10+), or a Cygwin/MSYS terminal.
2023-02-27 01:31:40 +01:00
Settings:
- `STDERR` : **false** : Whether the logger should print to `stderr` instead of `stdout` .
2024-03-29 02:41:13 +01:00
### journald mode
As an extension to the console mode, if Forgejo detects that stdout and/or stderr
are connected to systemd-journald (which will happen automatically when Forgejo
is running under systemd), the defaults will change:
- `STDERR` will default to **true** if stderr is connected to systemd-journald;
- `FLAGS` will default to `journaldflags` if the chosen stream is connected to
systemd-journald.
When `FLAGS = journaldflags` is used, instead of decorating log entries with
color or a textual representation of severity (e.g. `[INFO]` or `[ERROR]` ),
Forgejo will annotate each log entry with a machine-readable log level prefix
that is captured by journald, enabling native filtering capabilities
(e.g. run `journalctl -u forgejo -p err` to only show errors or worse).
In short, if Forgejo is running under systemd, it is recommended to leave the
logging configuration at their defaults, which will use `MODE = console` and
adjust formatting to reduce clutter and enable native log level filtering.
2023-02-27 01:31:40 +01:00
### File mode
In this mode the logger will save log messages to a file.
Settings:
2024-03-21 06:53:40 -05:00
- `FILE_NAME` : The file to write the log events to, relative to `ROOT_PATH` , Default to `%(ROOT_PATH)/gitea.log` . Exception: access log will default to `%(ROOT_PATH)/access.log` .
2023-02-27 01:31:40 +01:00
- `MAX_SIZE_SHIFT` : **28** : Maximum size shift of a single file. 28 represents 256Mb. For details see below.
2024-03-21 06:53:40 -05:00
- `LOG_ROTATE` **true** : Whether to rotate the log files. If `false` , log files will always be appended.
2023-02-27 01:31:40 +01:00
- `DAILY_ROTATE` : **true** : Whether to rotate logs daily.
- `MAX_DAYS` : **7** : Delete rotated log files after this number of days.
- `COMPRESS` : **true** : Whether to compress old log files by default with gzip.
- `COMPRESSION_LEVEL` : ** -1**: Compression level. For details see below.
`MAX_SIZE_SHIFT` defines the maximum size of a file by left shifting 1 the given number of times (`1 << x` ).
The useful values of `COMPRESSION_LEVEL` are from 1 to (and including) 9, where higher numbers mean better compression.
Beware that better compression might come with higher resource usage.
Must be preceded with a `-` sign.
### Conn mode
In this mode the logger will send log messages over a network socket.
Settings:
- `ADDR` : ** :7020**: Sets the address to connect to.
- `PROTOCOL` : **tcp** : Set the protocol, either "tcp", "unix" or "udp".
- `RECONNECT` : **false** : Try to reconnect when connection is lost.
- `RECONNECT_ON_MSG` : **false** : Reconnect host for every single message.
### The "Router" logger
2023-06-05 18:24:04 +02:00
The Router logger logs the following message types when Forgejo's route handlers work:
2023-02-27 01:31:40 +01:00
- `started` messages will be logged at TRACE level
2023-06-05 18:24:04 +02:00
- `polling` /`completed` routers will be logged at INFO. Exception: "/assets" static resource requests are also logged at TRACE.
2023-02-27 01:31:40 +01:00
- `slow` routers will be logged at WARN
- `failed` routers will be logged at WARN
2023-06-05 18:24:04 +02:00
### The "XORM" logger
2023-02-27 01:31:40 +01:00
2023-06-05 18:24:04 +02:00
To make XORM outputs SQL logs, the `LOG_SQL` in `[database]` section should also be set to `true` .
2023-02-27 01:31:40 +01:00
### The "Access" logger
2023-06-05 18:24:04 +02:00
The Access logger provides a NCSA
2023-02-27 01:31:40 +01:00
Common Log compliant log format. It's highly configurable but caution
should be taken when changing its template. The main benefit of this
2023-02-27 01:34:05 +01:00
logger is that Forgejo can now log accesses in a standard log format so
2023-02-27 01:31:40 +01:00
standard tools may be used.
2023-06-05 18:24:04 +02:00
You can enable this logger using `logger.access.MODE = ...` .
2023-02-27 01:31:40 +01:00
If desired the format of the Access logger can be changed by changing
the value of the `ACCESS_LOG_TEMPLATE` .
Please note, the access logger will log at `INFO` level, setting the
`LEVEL` of this logger to `WARN` or above will result in no access logs.
#### The ACCESS_LOG_TEMPLATE
2023-06-05 18:24:04 +02:00
This value represents a go template. Its default value is
2023-02-27 01:31:40 +01:00
2023-11-02 22:31:45 +01:00
```handlebars
2023-06-05 18:24:04 +02:00
{{.Ctx.RemoteHost}} - {{.Identity}} {{.Start.Format "[02/Jan/2006:15:04:05 -0700]" }} "{{.Ctx.Req.Method}} {{.Ctx.Req.URL.RequestURI}} {{.Ctx.Req.Proto}}" {{.ResponseWriter.Status}} {{.ResponseWriter.Size}} "{{.Ctx.Req.Referer}}" "{{.Ctx.Req.UserAgent}}"`
```
2023-02-27 01:31:40 +01:00
The template is passed following options:
- `Ctx` is the `context.Context`
2023-06-05 18:24:04 +02:00
- `Identity` is the `SignedUserName` or `"-"` if the user is not logged in
2023-02-27 01:31:40 +01:00
- `Start` is the start time of the request
- `ResponseWriter` is the `http.ResponseWriter`
Caution must be taken when changing this template as it runs outside of
the standard panic recovery trap. The template should also be as simple
as it runs for every request.
## Releasing-and-Reopening, Pausing and Resuming logging
If you are running on Unix you may wish to release-and-reopen logs in order to use `logrotate` or other tools.
2023-02-27 01:34:05 +01:00
It is possible force Forgejo to release and reopen it's logging files and connections by sending `SIGUSR1` to the
running process, or running `forgejo manager logging release-and-reopen` .
2023-02-27 01:31:40 +01:00
Alternatively, you may wish to pause and resume logging - this can be accomplished through the use of the
2023-02-27 01:34:05 +01:00
`forgejo manager logging pause` and `forgejo manager logging resume` commands. Please note that whilst logging
2023-02-27 01:31:40 +01:00
is paused log events below INFO level will not be stored and only a limited number of events will be stored.
2023-02-27 01:34:05 +01:00
Logging may block, albeit temporarily, slowing Forgejo considerably whilst paused - therefore it is
2023-02-27 01:31:40 +01:00
recommended that pausing only done for a very short period of time.
2023-02-27 01:34:05 +01:00
## Adding and removing logging whilst Forgejo is running
2023-02-27 01:31:40 +01:00
2023-02-27 01:34:05 +01:00
It is possible to add and remove logging whilst Forgejo is running using the `forgejo manager logging add` and `remove` subcommands.
2023-02-27 01:31:40 +01:00
This functionality can only adjust running log systems and cannot be used to start the access or router loggers if they
were not already initialized. If you wish to start these systems you are advised to adjust the app.ini and (gracefully) restart
2023-02-27 01:34:05 +01:00
the Forgejo service.
2023-02-27 01:31:40 +01:00
The main intention of these commands is to easily add a temporary logger to investigate problems on running systems where a restart
may cause the issue to disappear.
## Using `logrotate` instead of built-in log rotation
2023-02-27 01:34:05 +01:00
Forgejo includes built-in log rotation, which should be enough for most deployments. However, if you instead want to use the `logrotate` utility:
2023-02-27 01:31:40 +01:00
- Disable built-in log rotation by setting `LOG_ROTATE` to `false` in your `app.ini` .
- Install `logrotate` .
2023-06-05 18:24:04 +02:00
- Configure `logrotate` to match your deployment requirements, see `man 8 logrotate` for configuration syntax details.
In the `postrotate/endscript` block send Forgejo a `USR1` signal via `kill -USR1` or `kill -10` to the `forgejo` process itself,
or run `forgejo manager logging release-and-reopen` (with the appropriate environment).
Ensure that your configurations apply to all files emitted by Forgejo loggers as described in the above sections.
2023-02-27 01:31:40 +01:00
- Always do `logrotate /etc/logrotate.conf --debug` to test your configurations.
2023-06-05 18:24:04 +02:00
- If you are using docker and are running from outside the container you can use
`docker exec -u $OS_USER $CONTAINER_NAME sh -c 'forgejo manager logging release-and-reopen'`
or `docker exec $CONTAINER_NAME sh -c '/bin/s6-svc -1 /etc/s6/gitea/'` or send `USR1` directly to the Forgejo process itself.
2023-02-27 01:31:40 +01:00
2023-06-05 18:24:04 +02:00
The next `logrotate` jobs will include your configurations, so no restart is needed.
You can also immediately reload `logrotate` with `logrotate /etc/logrotate.conf --force` .