tail包读取日志文件

在项目根目录创造配置文件 命名xx.log  

package main

import (
   "fmt"
   "github.com/hpcloud/tail"
   "time"
)

func main() {
   filename := `./xx.log`
   config := tail.Config{
      ReOpen:    true,
      Follow:    true,
      Location:  &tail.SeekInfo{Offset: 0, Whence: 2},
      MustExist: false,
      Poll:      true,
   }

   //打开文件开始读取数据
   tails, err := tail.TailFile(filename, config)
   if err != nil {
      fmt.Println("tail %s failed,err:%v", err)
      return
   }

   //开始读取数据
   var (
      msg *tail.Line
      ok  bool
   )
   for {
      msg, ok = <-tails.Lines //chan tail.line
      if !ok {
         fmt.Printf("tail file close reopen,filename:%s\n", tails.Filename)
         time.Sleep(time.Second) //读取出错等一秒
         continue
      }
      fmt.Println("msg", msg.Text)
   }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值