背景描述
在我们日常开发、运维过程中,基本每天都要查看日志。对于分布式系统而言,日志存储于多个节点,查看起来很不方面。
ELK栈
是很不错的日志采集、追踪、分析方案,但本身组件较多,有一定的使用成本。对于以下场景不太适用:
- 实时追踪多主机日志内容至控制台
- 依赖尽可能的少,小白也能使用
由此催生出这个功能,该功能实现简单,使用也很简单:
- 实现原理:基于
go
通过协程ssh
至目标主机,读取文件内容并输出至控制台,输出内容前标明主机IP地址 - 使用方式:二进制文件,下载后执行授权语句即可使用
功能描述
该功能为easyctl 的一个子功能,实现实时追踪多主机文件内容至控制台功能(类似tail
)
版本&兼容性
-
版本支持
-
兼容性
-
CentOS6
-
CentOS7
-
使用方式
参考以下链接进行安装
生成默认配置文件
$ 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行读取
建议使用默认值key
:whence、offset
注意: 实现原理为通过协程ssh
至目标机读取文件并输出,本身并不会对日志文件内容进行处理,
所以读取历史内容是无序的,如有排序需求建议使用elk
等专业产品。
执行
$ easyctl track tail-log -c config.yaml
网友评论