go 第三方包 tail 使用

tail 是惠普云开发的 用于日志跟随

简单使用

package tail

import (
	"fmt"
	"time"

	"github.com/hpcloud/tail"
)

func Tailinit() {
	filename := "./file.log"
	config := tail.Config{
		ReOpen:    true,  // 重新打开
		MustExist: false, // 文件不存在不报错
		Poll:      true,
		Follow:    true, //是否跟随
		Location: &tail.SeekInfo{ //从文件的哪个地方开始读
			Offset: 0,
			Whence: 2,
		},
	}
	tails, err := tail.TailFile(filename, config)
	if err != nil {
		fmt.Println("tail file failed,err:", err)
		return
	}
	var (
		line *tail.Line
		ok   bool
	)
	for {
		line, ok = <-tails.Lines
		if !ok {
			fmt.Printf("tail file close reopen,filename:%s\n", tails.Filename)
			time.Sleep(time.Second)
			continue
		}
		fmt.Println("msg:", line.Text)
	}

}

 

posted @   到此灬一游丿  阅读(164)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 葡萄城 AI 搜索升级:DeepSeek 加持,客户体验更智能
· 什么是nginx的强缓存和协商缓存
· 一文读懂知识蒸馏
点击右上角即可分享
微信分享提示