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

背景描述

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

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

  • 实时追踪多主机日志内容至控制台
  • 依赖尽可能的少,小白也能使用

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

  • 实现原理:基于go通过协程ssh至目标主机,读取文件内容并输出至控制台,输出内容前标明主机IP地址
  • 使用方式:二进制文件,下载后执行授权语句即可使用

功能描述

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

版本&兼容性

使用方式

1.参考以下链接进行安装

2.生成默认配置文件

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

3.修改配置文件

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等专业产品。

4.执行

$ easyctl track tail-log -c config.yaml
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值