logurs是一个支持日志文件轮转的Go语言日志库。它使用了lumberjack库来实现日志文件轮转。
使用logurs进行日志记录时,可以指定一个文件作为输出目标。例如:
import (
"github.com/logrusorgru/logrus"
"github.com/logrusorgru/logurs"
)
func main() {
logger := logrus.New()
file, err := os.OpenFile("app.log", os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)
if err != nil {
log.Fatal(err)
}
defer file.Close()
logger.SetOutput(&logurs.RotateWriter{
Filename: file.Name(),
MaxSize: 10 * 1024 * 1024, // 每个日志文件最大10MB
MaxBackups: 5, // 最多保存5个旧日志文件
MaxAge: 30, // 日志文件最多保存30天
LocalTime: true,
})
logger.Info("Hello, world!")
}
在以上示例中,我们使用logrus.New()创建了一个新的logger实例,并将其输出目标设置为RotateWriter实例。RotateWriter的构造函数接收以下参数:
- Filename:日志文件名。
- MaxSize:每个日志文件最大大小(单位:字节)。如果日志文件大小超过此值,将会被轮转。
- MaxBackups:最多保存的旧日志文件数量。
- MaxAge:日志文件最大保存时间(单位:天)。
- LocalTime:是否启用本地时间。如果为true,则文件名中包含日期和时间;否则,只包含日期。
使用以上配置,日志文件会以以下格式进行命名:
app.log # 最新的日志文件
app.log.20210510 # 旧的日志文件(2021年5月10日创建)
app.log.20210509
app.log.20210508
app.log.20210507
当日志文件大小超过10MB时,最新的日志文件会被重命名为.app.log.1,并生成一个新的空日志文件。
当最多保存的旧日志文件数量超过5个或者最老的日志文件超过30天时,它们会被删除。