Skip to content

Latest commit

 

History

History
33 lines (27 loc) · 1.2 KB

README.md

File metadata and controls

33 lines (27 loc) · 1.2 KB

rfw(simple rotate file writer)

Warning: this project has been moved to https://github.com/gokits/rfw .

What is rfw

Package rfw is a simple rotate file writer that can rotate file dayly and be configured how many rotated files to remain. It implements io.WriteCloser and can be used with many logger package easyly.

Why to use rfw

There are many logger package in golang ecosystem, but few provide ability to rotate log file. Though we can use logrotate to rotate log file, but it has some drawbacks

  1. when logrotate working, load of io increasing too(few of programs implements a custom signal to reopen log file)
  2. risk of lost some lines of log content
  3. difficult to use

How to use

See code sample below

    // file name of rotated log file will be ./logfile-20190101 ...
    logpath := "./logfile"
    remaindays := 7
	lw, err = rfw.NewWithOptions(logpath, rfw.WithCleanUp(remaindays))
	if err != nil {
        //...
    }
    
    //now you have a io.WriteCloser lw, you can use it with std logger
    log.SetOutput(lw)

Status of this package

This package has been used in production for more than two years. It is ready for production use.

Roadmap

  1. [TODO] async log writing