linux ssh -l 命令运用
ssh是远程登录命令,-l选项是最常用的选项,下面是我的一些总结
远程登录:ssh -l userName ip
# 远程登录到 10.175.23.9
ssh -l root2 10.175.23.9
执行远程命令(不登录):ssh -l userName ip command
# 不远程登录到 10.175.23.9,但通过命令查看10.175.23.9上面的nginx的进程情况
ssh -l root2 10.175.23.9 ps -ef|grep nginx
更多的情况是,command处为一个shell脚本,而配合expect spawn 一起使用,效果是最好的,比如下面这段shell脚本是实现同时刷新两个ip主机的redis缓存的:
#!/bin/sh 
echo "--------------------flushall_all_redis init--------------------"
Server09=("root1" "root1_pwd")
Server10=("root2" "root2_pwd")
function exe()
{
expect -c "
        $1
        set timeout 300
        expect {
                \"*(yes/no)?\"
                {
                        send \"yes\n\"
                        expect \"*assword:\" {
                                send \"$2\n\"
                        }
                }
                \"*password:\"
                {
                        send \"$2\n\"
                }
        }
        expect eof
"
}
echo ""
echo "--------------------start reflush redis from 10.175.23.9--------------------"
exe "spawn ssh -l ${Server09[0]} 10.175.23.9 \"/home/weihu/bin/flushall_redis.sh\"" "${Server09[1]}"
echo ""
echo "--------------------start reflush redis from 10.175.23.10--------------------"
exe "spawn ssh -l ${Server10[0]} 10.175.23.10 \"/home/weihu/bin/flushall_redis.sh\"" "${Server10[1]}"
上面例子中的 /home/weihu/bin/flushall_redis.sh 即为各自主机上面需要执行shell文件(用于刷新各自主机redis缓存的)。例子中的重点就是exe函数、以及ssh -l 两部分。
    未来的自己若是充满勇气,一定会感谢今日的孤独。
 
                    
                     
                    
                 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号