不用批量运维工具时,如何用ssh命令远程执行命令,执行和采集信息?
1、当可以免密登录服务器时:采用linux自带的ssh命令。
root ssh -o BatchMode=yes -o StrictHostKeyChecking=no root@172.0.0.19 "hostname"
通过SSH连接到IP地址为172.0.0.19的远程服务器,并执行hostname命令来显示该服务器的主机名。下面是命令的具体解析:
root ssh: 使用root用户进行SSH连接。
-o BatchMode=yes: 这个选项防止SSH在出现公钥认证失败的情况下中断。在批量模式下,如果密钥认证失败,SSH不会终止,而是会提示输入密码。
-o StrictHostKeyChecking=no: 这个选项禁用了对远程主机公钥的检查,这在自动化脚本中很有用,但在生产环境中可能会降低安全性。
root@172.0.0.19: 指定要连接的远程服务器的IP地址,并以root用户身份登录。
"hostname": 在远程服务器上执行hostname命令。
2、当无法免密登录服务器时,使用sshpass命令实现
sshpass -p 'your_password' ssh -o BatchMode=yes -o StrictHostKeyChecking=no root@172.0.0.19 "hostname"
3、多行命令一起执行
root@Ubuntu18_04_6-1:~# echo "-------""192.168.56.202" ";" $(date) "------" | tee -a test.log ; sshpass -p '183' ssh -o BatchMode=yes -o StrictHostKeyChecking=no root@192.168.56.202 "hostname ;cat /etc/netplan/00-installer-config.yaml" | tee -a test.log
#####执行后效果
-------192.168.56.202 ; Wed Oct 9 05:15:59 UTC 2024 ------
Ubuntu18_04_6-2
# This is the network config written by 'subiquity'
network:
version: 2
# renderer: NetworkManager
ethernets:
enp0s3:
dhcp4: true
enp0s8:
dhcp4: false
addresses: [192.168.56.202/24]
#version: 2
root@Ubuntu18_04_6-1:~#