go语言中动态读取日志
package main
//tail命令用途是依照要求将指定的文件的最后部分输出到标准设备,通常是终端,
//通俗讲来,就是把某个档案文件的最后几行显示到终端上,假设该档案有更新,tail会自己主动刷新,确保你看到最新的档案内容 ,在日志收集中可以实时的监测日志的变化,Log需要换行才可以表现
import (
"fmt"
"time"
"github.com/hpcloud/tail"
)
func main() {
fileName := "app.log"
config := tail.Config{
ReOpen: true, // 重新打开
Follow: true, // 是否跟随
Location: &tail.SeekInfo{Offset: 0, Whence: 2}, // 从文件的哪个地方开始读
//Offset: 0 表示偏移量为0,这意味着从文件末尾开始阅读。
//Whence: 2 表示寻找开始位置的方式。1 表示从文件的头开始读去 2 表示以相对于文件末尾的方式进行寻找
MustExist: false, // 文件不存在不报错
Poll: true, //轮询
}
tails, err := tail.TailFile(fileName, config)
if err != nil {
fmt.Println("err:", err)
return
}
// 开始读取数据
var (
msg *tail.Line
ok bool
)
for {
msg, ok = <-tails.Lines //遍历chan,读取日志内容
if !ok {
fmt.Printf("tail file close reopen,fileName:%s\n",
tails.Filename)
time.Sleep(time.Second)
continue
}
fmt.Println("msg:", msg.Text)
}
}
本文来自博客园,作者:厚礼蝎,转载请注明原文链接:https://www.cnblogs.com/guangdelw/p/17562109.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· DeepSeek在M芯片Mac上本地化部署
· 葡萄城 AI 搜索升级:DeepSeek 加持,客户体验更智能