go语言并发实战——日志收集系统(五) 基于go-ini包读取日志收集服务的配置文件

实现日志收集服务的客户端

前言

从这篇文章开始我们就正式进入了日志收集系统的编写,后面几篇文章我们将学习到如何编写日志收集服务的客户端,话不多说,让我们进入今天的内容吧!

需要实现的功能

我们要收集指定目录下的日志文件,将它们发送到Kafka中

实现的步骤

  • 读取配置文件,寻找日志路径
  • 初始化服务
  • 根据日志路径去利用tail来收集日志
  • 将收集到的日志利用sarama发送到Kafka中

读取配置文件

go-ini包

  • go-ini包的安装

    包的地址为"github.com/go-ini/ini",安装可以基于go mod来使用go mod tidy或者go get github.com/go-ini/ini来进行安装

  • 包的使用

    由于篇幅有限,这里对于包的实现不做过多赘述,可以参考矿方文档,文档里面作者将该包的使用方法讲解的非常好,博主这里就不班门弄斧了,官方文档的地址如

    下:

    超赞的 Go 语言 INI 文件操作

  • 代码示例:

    首先我们定义一个config.ini的配置文件,如下:

text 复制代码
[kafka]
address=127.0.0.1:9092

然后我们尝试提取出Kafka的address:

go 复制代码
package main

import (
	"fmt"
	"github.com/go-ini/ini"
	"github.com/sirupsen/logrus"
)

func main() {
	cfg, err := ini.Load("G:\\goproject\\-goroutine-\\log-agent\\conf\\config.ini")//读取配置文件
	if err != nil {
		logrus.Error("load config.ini error!,err:", err) //日志中打印错误信息
	}
	fmt.Println(cfg.Section("kafka").Key("address").String())
}

输出结果为:

当然我们还可以将配置文件的配置有谁到结构体中,首先还是我们的配置文件:

text 复制代码
[kafka]
address=127.0.0.1:9092

[collect]
logfile_path:G:\goproject\-goroutine-\log-agent\log\log1

示例代码:

go 复制代码
package main

import (
	"fmt"
	"github.com/go-ini/ini"
)

type Config struct {
	Kafakaddress Kafkaddress `ini:"kafka"`
	LogFilePath  LogFilePath `ini:"collect"`
}

type Kafkaddress struct {
	Addr string `ini:"address""`
}

type LogFilePath struct {
	Path string `ini:"logfile_path"`
}

func main() {
	var configObj = new(Config) //生成指针便于参数传递
	err := ini.MapTo(configObj, "G:\\goproject\\-goroutine-\\log-agent\\conf\\config.ini")
	if err != nil {
		fmt.Println("log config failed,err:", err)
	}
	fmt.Println(configObj.LogFilePath, configObj.Kafakaddress)
}

输出结果为:

结语

对读取配置文件就讲到这里了。下一篇文章我们就开始探寻如何初始化Kafka和tail的服务,以及介绍什么是etcd,以及它在项目中所起到的作用,下篇见!

相关推荐
马尔代夫哈哈哈8 分钟前
Spring 事务处理
java·后端·spring
清水白石00811 分钟前
缓存的艺术:Python 高性能编程中的策略选择与全景实战
开发语言·数据库·python
逆境不可逃23 分钟前
【从零入门23种设计模式02】创建型之单例模式(5种实现形式)
java·spring boot·后端·单例模式·设计模式·职场和发展
JienDa26 分钟前
Haio · 海鸥 - 企业级插件化应用平台
开发语言·php
Toormi27 分钟前
Go 1.26在性能方面做了哪些提升?
开发语言·后端·golang
CHANG_THE_WORLD28 分钟前
深入理解C语言指针运算与数据搜索
c语言·开发语言
大尚来也30 分钟前
Spring Boot 集成 Nacos 完全指南:从配置中心到服务发现一站式实战
spring boot·后端·服务发现
逆境不可逃34 分钟前
【从零入门23种设计模式04】创建型之原型模式
java·后端·算法·设计模式·职场和发展·开发·原型模式
DokiDoki之父36 分钟前
边写软件边学kotlin(二)——语法推进
开发语言·微信·kotlin
清水白石0089 小时前
突破并行瓶颈:Python 多进程开销全解析与 IPC 优化实战
开发语言·网络·python