go语言收集nginx容器日志(二、读取模块实现)

昨天大致流程已经实现,今天我们按照模块化实现功能
首先是读取模块的实现

package main
import (
	"bufio"
	"fmt"
	"io"
	"log"
	"os"
	"strings"
	"time"
)

type LogProcess struct {
	//定义了两个管道,一个读取,一个写入
	rc chan string
	wc chan string

	//文件路径
	path string
}

func (l *LogProcess) ReadFromFile() {
	//打开文件返回一个reader
	file, err := os.Open(l.path)
	if err != nil {
		log.Fatal(err)
	}
	//(0,2)是指向文件最后一行
	file.Seek(0, 2)
	//新建一个reader,读取打开的文件
	read := bufio.NewReader(file)
	for {
		//循环读取文件返回一个bute的一个切片参数意思为换行
		bytes, err := read.ReadBytes('\n')
		//如果错误为io.EOF代表这是文件末尾,休眠500毫秒跳过本次读取
		if err == io.EOF {
			time.Sleep(500 * time.Millisecond)
			continue
		} else if err != nil {
			log.Fatal(err)
		}
		//把读取的数据转换为string放入读取管道
		l.rc <- string(bytes)
	}

}
func (l *LogProcess) Process() {
	//处理方法从读取管道中拿到数据进行处理,我们进行最简单的处理
	for {
		data := <-l.rc
		//strings.ToUppser方法为把字母全部转换为大写
		res := strings.ToUpper(data)
		//把处理结果放入写入管道
		l.wc <- res
	}

}
func (l *LogProcess) Write() {
	//从写入管道中拿到数据,进行写入,因为现在为调测,我们进行最简单的fmt操作
	for {
		fmt.Print(<-l.wc)
	}

}

func main() {
    //这里我们实现结构体的时候新增了文件路径为当前目录下的log文件
	l := &LogProcess{
		rc:   make(chan string),
		wc:   make(chan string),
		path: "log",
	}
	go l.ReadFromFile()
	go l.Process()
	go l.Write()

	time.Sleep(30 * time.Second)
}

下面是一个测试数据生成代码
dataCreate.go

package main

import (
	"log"
	"os"
	"time"
)

func main() {
   //创建一个文件,
	file, err := os.Create("/Users/huhongbin/go/src/nginxLog/log")
	if err != nil {
		log.Fatal(err)
	}
	for{
	   //在文件写入数据
		file.Write([]byte("hello world\n"))
		time.Sleep(500 * time.Millisecond)
	}
}

执行两份代码看到我们的写入模块已经完成了。下面要完成处理模块的实现。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值