NodeJS file stream rotator
To provide an automated rotation of Express/Connect logs or anything else that writes to a log on a regular basis that needs to be rotated based on date. It can also be rotated based on a size limit and remove old log files based on count or elapsed days.
npm install file-stream-rotator
filename: Filename including full path used by the stream
frequency: How often to rotate. Options are 'daily', 'custom' and 'test'. 'test' rotates every minute. If frequency is set to none of the above, a YYYYMMDD string will be added to the end of the filename.
verbose: If set, it will log to STDOUT when it rotates files and name of log file. Default is TRUE.
date_format: Format as used in moment.js http://momentjs.com/docs/#/displaying/format/. The result is used to replace the '%DATE%' placeholder in the filename. If using 'custom' frequency, it is used to trigger file rotation when the string representation changes.
size: Max size of the file after which it will rotate. It can be combined with frequency or date format. The size units are 'k', 'm' and 'g'. Units need to directly follow a number e.g. 1g, 100m, 20k.
max_logs Max number of logs to keep. If not set, it won't remove past logs. It uses its own log audit file to keep track of the log files in a json format. It won't delete any file not contained in it. It can be a number of files or number of days. If using days, add 'd' as the suffix.
audit_file Location to store the log audit file. If not set, it will be stored in the root of the application.
// Default date added at the end of the filevar rotatingLogStream = ;// Default date added using file patternvar rotatingLogStream = ;// Custom date added using file pattern using moment.js formatsvar rotatingLogStream = ;// Rotate when the date format as calculated by momentjs is different (e.g monthly)var rotatingLogStream = ;// Rotate when the date format as calculated by momentjs is different (e.g weekly)var rotatingLogStream = ;// Rotate when the date format as calculated by momentjs is different (e.g AM/PM)var rotatingLogStream = ;// Rotate on given minutes using the 'm' option i.e. 5m or 30mvar rotatingLogStream = ;// Rotate on the hour or any specified number of hoursvar rotatingLogStream = ;// Rotate on the hour or any specified number of hours and keep 10 filesvar rotatingLogStream = ;// Rotate on the hour or any specified number of hours and keep 10 daysvar rotatingLogStream = ;// Rotate on the hour or any specified number of hours and keep 10 days and store the audit file in /tmp/log-audit.jsonvar rotatingLogStream = ;//.....// Use new stream in expressapp;//.....
You can listen to the open, close, error and finish events generated by the open stream. You can also listen for custom events:
You can also limit the size of each file by adding the size option using "k", "m" and "g" to specify the size of the file in kiloybytes, megabytes or gigabytes. When it rotates a file based on size, it will add a number to the end and increment it for every time the file rotates in the given period as shown below.
3078 7 Mar 13:09:58 2017 testlog-2017-03-07.13.09.log.20 2052 7 Mar 13:10:00 2017 testlog-2017-03-07.13.09.log.21 3078 7 Mar 13:10:05 2017 testlog-2017-03-07.13.10.log.1 3078 7 Mar 13:10:08 2017 testlog-2017-03-07.13.10.log.2 3078 7 Mar 13:10:11 2017 testlog-2017-03-07.13.10.log.3 3078 7 Mar 13:10:14 2017 testlog-2017-03-07.13.10.log.4
The example below will rotate files daily but each file will be limited to 5MB.
// Rotate every day or every 5 megabytes, whatever comes first.var rotatingLogStream =;rotatingLogStream
The npm module for this library will be maintained by:
file-stream-rotator is licensed under the MIT license.