Skip to content

YueHonghui/rfw

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 

Repository files navigation

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

About

simple rotate file writer

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages