golang 实时读取日志文件,windows版本的tail

原创 2016年08月29日 14:19:07
package main

import (
	"flag"
	"fmt"
	"io"
	"os"
	"runtime"
)

import (
	"github.com/axgle/mahonia"
)

type ReadFile struct {
	file    *os.File
	gbkFile *mahonia.Reader
}

func (f *ReadFile) gbkDecode() {
	decoder := mahonia.NewDecoder("gbk")
	f.gbkFile = decoder.NewReader(f.file)
}

func (f *ReadFile) ReadPrint() {
	var n int
	var err error
	data := make([]byte, 1<<16)
	if runtime.GOOS == "windows" {
		f.gbkDecode()
		n, err = f.gbkFile.Read(data)
	} else {
		n, err = f.file.Read(data)
	}
	switch err {
	case nil:
		var lines int
		out := data
		indexs := make(map[int]int)
		for i, d := range out {
			if d == '\n' {
				lines++
				indexs[lines] = i
			}
		}
		lines += 1

		if lines <= line || line <= 0 {
			fmt.Print(string(data[:n]))
		} else {
			index := indexs[lines-line]
			fmt.Print(string(data[index+1 : n]))
		}

	case io.EOF:
	default:
		fmt.Println(err)
		return
	}
}

var (
	follow bool
	line   int
)

func init() {
	flag.BoolVar(&follow, "f", false, "即时输出文件变化后追加的数据。")
	flag.IntVar(&line, "n", 10, "output the last K lines, instead of the last 10")
}

func main() {
	flag.Parse()
	var err error
	var readFile ReadFile
	if len(os.Args) < 2 {
		flag.Usage()
		return
	}

	// readFile.file, err = os.Open(os.Args[len(os.Args)-1])
	readFile.file, err = os.Open(flag.Arg(0))
	if err != nil {
		fmt.Println(err)
		return
	}
	defer readFile.file.Close()

	for {
		readFile.ReadPrint()
		if !follow {
			break
		}
	}
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

golang基础-tailf日志组件使用

git上log日志组件 https://github.com/hpcloud/tail/blob/master/tail.go我们写个test来测试下这个组件package mainimport (...
  • u013210620
  • u013210620
  • 2017年11月18日 19:46
  • 269

win下 查看 catalina.out实时日志

大家都有在linux下使用tail -f catalina.out查看tomcat日志的习惯,在window下可以吗?当然可以下面就介绍一下如何操作。 1、打开bin下面的startup.bat文件...
  • ssssny
  • ssssny
  • 2017年06月06日 16:41
  • 1617

Windows系统 实时查看日志利器

  • 2012年09月05日 15:34
  • 903KB
  • 下载

windows下使用命令动态输出tomcat日志

转自http://www.51testing.com/html/99/478599-843404.html 最近测试遇到一个问题,我们的项目使用windows2003服务器,tomcat+ora...
  • u010113247
  • u010113247
  • 2016年04月11日 10:56
  • 6586

golang日志中心取日志代码分享

package main import ( "archive/zip" "bytes" "encoding/json" "fmt" "io" "io/ioutil" "net" "n...
  • fyxichen
  • fyxichen
  • 2016年03月22日 21:11
  • 1428

实时查看日志文件 tail -f gallerylogs.log

实时查看日志文件 tail -f gallerylogs.log
  • longzhiwen888
  • longzhiwen888
  • 2015年06月19日 15:48
  • 313

golang基础-beego读取配置_输出log日志、tailf组件读取log、配置zookeeper_kafka、发送log至kafka

1加载配置文件loadConf封装结构体 2初始化beego的log组件 3初始化tailf 4初始化kafka 5tailf读取 6发送数据kafka 7启动zookeeperkafka测试 8查看...
  • u013210620
  • u013210620
  • 2017年11月21日 18:33
  • 637

使用GO语言实现的日志集中查看的小功能.

程序分为站点端和中心端(相当于一个proxy). 这个小功能主要是解决,程序经常让我们去拖日志,特别烦.所以做个小程序.使程序可以自己去线上查看. 有个问题是,不能把游戏服务器暴露出来,还有就是不能占...
  • fyxichen
  • fyxichen
  • 2015年07月20日 17:43
  • 1621

go实现的一个监控日志报警程序

package main import ( "compile" "encoding/json" "flag" "fmt" "io/ioutil" "libconf/goini" log...
  • qiuyoujie
  • qiuyoujie
  • 2017年12月29日 15:43
  • 132

golang log日志笔记

golang中将log打印到指定文件
  • teacher20133
  • teacher20133
  • 2017年07月28日 17:38
  • 692
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:golang 实时读取日志文件,windows版本的tail
举报原因:
原因补充:

(最多只允许输入30个字)