当我们有几台服务器时,没问题,可惜通过免密码ssh登录到远程主机上执行命令,但当我们有上百台服务器时,这个工作量是巨大的,而且重复度很高,因此,如何一下搞定呢,就通过远程SSH脚本就可以啦。
![23af9d317ad7655de2b068ec325ad0b3.png](https://img-blog.csdnimg.cn/img_convert/23af9d317ad7655de2b068ec325ad0b3.png)
服务器集群
- 远程ssh执行命令:
1. 执行简单命令,必须有""
ssh -tt 15.16.135.20 "ps -ef|grep redis"
其中 ,-tt的官方解释:
Force pseudo-terminal allocation. This can be used to execute arbitrary screen-based programs on a remote machine, which can be very useful, e.g. when implementing menu services. Multiple -t options force tty allocation, even if ssh has no local tty.
大致就是说,为了远程ssh而存在的参数。
2.执行多个命令
ssh -tt 15.16.135.20 > /dev/null 2>&1<< eeooff
ps -ef|grep redis
exit
eeooff
echo done!
由于以上输出重定向到/dev/null ,因此不显示命令。
ssh -tt 15.16.135.20<< eeooff
ps -ef|grep redis | kill -9
exit
eeooff
echo done!
此处,会显示命令。
Shell 获取进程号并杀掉该进程:
echo "acdes" | sudo -S kill -9 $(ps -ef | grep 'redis-server 15.16.135.20:6379' | grep -v grep | awk '{print $2}')
其中,echo "acdes" 为密码。
远程执行kil命令l:
ssh -tt 15.16.135.20 << eeooff
echo "1" | sudo -S kill -9 $(ps -ef | grep 'redis-server 15.16.135.20:6381' | grep -v grep | awk '{print $2}')
exit
eeooff
echo done!
小提示:有时我们需要设置sudo命令免密码,便于脚本控制,在这里配置:
编辑vim /etc/sudoers文件
messi ALL=(ALL) NOPASSWD: ALL
其中,messi是当前登录的用户, NOPASSWD: ALL为免密码执行sudo命令,但其安全性会降低哦。