sshpass用法介绍
参考文章:http://www.mamicode.com/info-detail-1105345.html
https://www.jianshu.com/p/a2aaa02f57dd
1.ssh与sshpass的区别
- ssh登录需要与用户进行交互,需要用户输入密码
- sshpass 用于非交互的ssh密码验证,允许使用-p参数指定明文密码
2.sshpass的用法
使用-p参数指定密码 |
|
1.使用ssh第一次登录某台服务器时,会有提示“Are you sure you want to continue connecting (yes/no)”,这时用sshpass会不好使 解决办法:可以在ssh命令后面加上 -o StrictHostKeyChecking=no来解决 eg:sshpass -p password ssh -o StrictHostKeyChecking=no user@ip 除此之外还可以修改ssh的配置文件,在所有机器上修改/etc/ssh/ssh_config (mac中为/etc/ssh_config)文件中设置StrictHostKeyChecking no即可(默认为 #StrictHostKeyChecking ask ) 2.设置ssh连接超时时间 ssh -o ConnectTimeout=3 192.168.0.10 |
使用-f参数从指定文件中读取密码 |
echo 'password' >mypasswd sshpass -f mypasswd ssh user@ip |
|
使用-e参数从环境变量中获取ssh密码 |
export SSHPASS= "password " sshpass -e ssh user@ip |
案例:
功能 | 脚本 | 知识点 | ||||||
验证服务器是够能够成功登录 |
cat check_passwd.sh #!/bin/bash ips=`cat server_list.txt` for ip in $ips do echo ==========$ip=========== sshpass -p "server_password" ssh root@$ip ":" [ $? -eq 0 ] && echo -e "\033[32m ==$ip==password is ok... \033[0m" || echo -e "\033[31m ==$ip==Password is error!!! \033[0m" done |
1.server_list.txt是存放server IP的list 2.验证是否能登陆时,使用命令ssh root@$ip ":" ,其中":"代表要在登陆到的服务器中执行的命令,如果没有这个命令,使用该命令就直接登录到远程机器中,而不会执行后续步骤 3.shell中设置颜的格式为格式: echo -e "\033[字背景颜色;字体颜色m 字符串 \033[0m" 其中其他属性与字体颜色同时使用时用时,格式为 echo -e "\033[5m \033[字背景颜色;字体颜色m 字符串 \033[0m" ,其中两者顺序可以调换
|
||||||
#!/bin/bash ip=$1 rm -rf ./log/* log_dir="/LocalRun/sct/auto_test/scripts/sct_scripts/test_integration/log/system_sdk_log" #get log dirs |