使用easyctl实现跨主机tail日志文件

2021-10-01  本文已影响0人  微凉哇

背景描述

在我们日常开发、运维过程中,基本每天都要查看日志。对于分布式系统而言,日志存储于多个节点,查看起来很不方面。

ELK栈是很不错的日志采集、追踪、分析方案,但本身组件较多,有一定的使用成本。对于以下场景不太适用:

由此催生出这个功能,该功能实现简单,使用也很简单:

功能描述

该功能为easyctl 的一个子功能,实现实时追踪多主机文件内容至控制台功能(类似tail

版本&兼容性

使用方式

参考以下链接进行安装

生成默认配置文件

$ easyctl track tail-log
I1001 11:13:06.384839  126576 track.go:50] 检测到配置文件参数为空,生成配置文件样例 -> config.yaml

修改配置文件

config.yaml,修改server列表,日志文件path

server:
  - host: 10.10.10.[1:3]
    username: root
    password: "123456"
    port: 22
excludes:
  - 192.168.235.132
tail-log:
  log-path: "/opt/nginx/logs/access.log" # 日志文件路径
  whence: 2   # 读取位置: 0为从文件开头读取 1为相对当前位置 2为从文件结尾开始读取
  offset: 200 # 当whence为1时生效,offset表示从文件第200行读取

建议使用默认值keywhence、offset

注意: 实现原理为通过协程ssh至目标机读取文件并输出,本身并不会对日志文件内容进行处理,
所以读取历史内容是无序的,如有排序需求建议使用elk等专业产品。

执行

$ easyctl track tail-log -c config.yaml
上一篇 下一篇

猜你喜欢

热点阅读