RemoteTail 是一款支持同步显示多台远程服务器的日志文件内容更新的工具,使用它可以让你同时监控多台服务器中某个(某些)日志文件的变更,将多台服务器的tail -f xxx.log
命令的输出合并展示。
使用场景
假设公司有两台web服务器A和B,由于初期没有专业运维进行配置集中式的日志服务系统,两台服务器上分别部署了两套相同的代码提供web服务,使用nginx作为负载均衡,请求根据设定的策略转发的这两台web服务器上。
AB两台服务器中的项目均将日志写到文件系统的/home/data/logs/laravel.log
文件。这种情况下如果我们需要查看web日志是否正常,一般情况下就需要分别登陆两台服务器,然后分别执行tail -f /home/data/logs/laravel.log
查看日志文件的最新内容,这在排查问题的时候是非常不方便的。RemoteTail就是为了解决这种问题的,开发人员可以使用它同步显示两台(多台)服务器的日志信息。
安装
下载项目bin/
下对应的remote-tail-平台
可执行文件,将该文件加入到系统的PATH
环境变量指定的目录中即可。
比如,Centos下可以放到/usr/local/bin
目录。
mv remote-tail-linux /usr/local/bin/remote-tail
使用方法
使用前需要宿主机建立与远程主机之间的ssh公钥免密码登陆。
remote-tail -hosts 'watcher@192.168.1.226,watcher@192.168.1.225' \
-file '/usr/local/openresty/nginx/logs/access.log'
指定配置文件
通过使用-conf
参数可以为命令指定读取的配置文件,配置文件为TOML格式,请参考example.toml
文件。
配置文件example.toml
:
# 全局配置,所有的servers中tail_file配置的默认值
tail_file="/data/logs/laravel.log"
# 服务器配置,可以配置多个
# 如果不提供password,则使用当前用户的ssh公钥,建议采用该方式,使用密码方式不安全
# server_name, hostname, user 配置为必选,其它可选
[servers]
[servers.1]
server_name="测试服务器1"
hostname="test1.server.aicode.cc"
user="root"
tail_file="/var/log/messages"
[servers.2]
server_name="测试服务器2"
hostname="test2.server.aicode.cc"
user="root"
tail_file="/var/log/messages"
[servers.3]
server_name="测试服务器3"
hostname="test2.server.aicode.cc"
user="demo"
password="123456"
执行命令:
remote-tail -conf=example.toml
如果对本项目感兴趣,欢迎关注 https://github.com/mylxsw/remote-tail。
有疑问加站长微信联系(非本文作者)