polysh 是一个交互式命令,能够在一台服务器上批量的对一批服务器进行处理,运行交互式命令。官方的简介以下:python
Polysh is a tool to aggregate several remote shells into one. Itis used to launch an interactive remote shellon many machines at once. It is written in Python and requires Python ≥ 2.4.
注: Polysh 是一个由几个远程脚本集合而成的工具,它被用于在许多服务器上运行一个交互式的远程脚本,由 Python 编写,最低要求为 Python 2.4shell
当须要查看一个服务(部署在多台机器上)的日志的时候,可使用ploysh在一台机器查看多台机器的日志,而不须要一台机器一台机器的登陆查看,方便了问题的排查和定位。 vim
先在一台机器上执行以下命令安装polysh:服务器
一、选择一个目录,下载解压文件:less
wget http://guichaz.free.fr/polysh/files/polysh-0.4.tar.gz tar -zxvf polysh-0.4.tar.gz
二、新建polysh的使用脚本,而后经过 chmod命令 赋予可执行权限:ssh
vim polysh.sh 脚本内容以下:将须要访问的机器列表填写在最后 python /home/安装目录.../polysh-0.4/polysh.py {name1, name2, name3}
{}大括号里填写的是机器的名称,以逗号 "," 分隔。polysh也支持多种机器名的格式,假如机器不少的话,也能够写为:name<1-3>工具
三、若是出现以下提示信息:机器's passpord,则须要配置机器之间无密码访问。性能
① 经过 ssh-keygen -t rsa 生成本机器的密钥和公钥ui
② cat /用户目录.../.ssh/id_rsa.pub 获取公钥spa
③ 将公钥追加到所须要无密码访问目标机器(例如上面的name<1-3>的3台机器)的受权文件中(受权文件的路径为:/用户目录.../.ssh/authorized_keys)
运行刚刚新建的 ./polysh.sh 脚本
ready (3) 表示 3台机器已经链接完毕,能够执行查询命令。exit或Crtl+z均可以退出。
查看3台机器上面的日志信息:less test.log,如图所示,颜色不一样的3行分别是3台机器输出的日志内容:
经过在一台机器上,实现对多个机器进行操做,不再须要去记复杂的机器名称了,也不须要每一个机器来回登陆去执行重复指令,解放本身,减小了重复工做。最方便的场景就是查日志、查看机器信息(CPU、磁盘)这些小操做。
若是机器很是多的话(10台以上),就不建议使用了,还有对机器性能有影响的命令也不建议执行。