# Date Rolling File Appender
This is a file appender that rolls log files based on a configurable time, rather than the file size. When using the date file appender, you should also call logger.shutdown() when your application terminates, to ensure that any remaining asynchronous writes have finished. Although the date file appender uses the streamroller (opens new window) library, this is included as a dependency of log4js so you do not need to include it yourself.
# Configuration
- type -
file
- filename -
string
- the path of the file where you want your logs written. - pattern -
string
(optional, defaults to.yyyy-MM-dd
) - the pattern to use to determine when to roll the logs. - layout - (optional, defaults to basic layout) - see layouts
Any other configuration parameters will be passed to the underlying streamroller (opens new window) implementation (see also node.js core file streams):
- encoding -
string
(default "utf-8") - mode-
integer
(default 0o644 - node.js file modes (opens new window)) - flags -
string
(default 'a') - compress -
boolean
(default false) - compress the backup files during rolling (backup files will have.gz
extension) - alwaysIncludePattern -
boolean
(default false) - include the pattern in the name of the current log file as well as the backups. - daysToKeep -
integer
(default 0) - if this value is greater than zero, then files older than that many days will be deleted during log rolling. - keepFileExt -
boolean
(default false) - preserve the file extension when rotating log files (file.log
becomesfile.2017-05-30.log
instead offile.log.2017-05-30
).
The pattern
is used to determine when the current log file should be renamed and a new log file created. For example, with a filename of 'cheese.log', and the default pattern of .yyyy-MM-dd
- on startup this will result in a file called cheese.log
being created and written to until the next write after midnight. When this happens, cheese.log
will be renamed to cheese.log.2017-04-30
and a new cheese.log
file created. The appender uses the date-format (opens new window) library to parse the pattern
, and any of the valid formats can be used. Also note that there is no timer controlling the log rolling - changes in the pattern are determined on every log write. If no writes occur, then no log rolling will happen. If your application logs infrequently this could result in no log file being written for a particular time period.
# Example (default daily log rolling)
import {Logger} from "@tsed/logger";
const logger = new Logger("loggerName");
logger.appenders.set("everything", {
type: "file",
filename: "all-the-logs.log",
pattern: ".yyyy-MM-dd"
});
logger.debug("I will be logged in all-the-logs.log");
2
3
4
5
6
7
8
9
10
11
This example will result in files being rolled every day. The initial file will be all-the-logs.log
, with the daily backups being all-the-logs.log.2017-04-30
, etc.
# Example with hourly log rolling (and compressed backups)
import {Logger} from "@tsed/logger";
const logger = new Logger("loggerName");
logger.appenders.set("everything", {
type: "file",
filename: "all-the-logs.log",
pattern: ".yyyy-MM-dd-hh",
compress: true
});
2
3
4
5
6
7
8
9
10
This will result in one current log file (all-the-logs.log
). Every hour this file will be compressed and renamed to all-the-logs.log.2017-04-30-08.gz
(for example) and a new all-the-logs.log
created.
Other topics
- Console Appender
- File Appender
- Date Rolling File Appender
- Connect Appender
- Standard Out Appender
- Standard Error Appender
- Insight Appender
- LogEntries Appender
- LogStash HTTP Appender
- LogStash UDP Appender
- Loggly Appender
- RabbitMQ Appender
- Seq Appender
- Slack Appender
- SMTP Appender
- Basic layout
- Colored layout
- Dummy layout
- Message Pass-Through layout
- Object layout
- Json layout
- Pattern layout