基本能完成常用的对于远程节点的管理了,几个注意的点:
格式: ssh user@ip command
远程执行的内容在<< eof
至eof
之间,在远程机器上的操作就位于其中,注意的点:
格式:
ssh user@ip << "eof"
# shell程序
exit
eof
格式:su - user -c command
执行的内容在<< eof
至eof
之间,在远程机器上的操作就位于其中,注意的点:
<< eof
,ssh后直到遇到eof这样的内容结束,eof可以随便修改成其他形式。exit
退出用户格式:
su - user@ip << "eof"
# shell程序
exit
eof
上述的使用eof格式时在父shell的控制台会输出一下提示
Pseudo-terminal will not be allocated because stdin is not a terminal.
最好在子shell中写到其他日志文件中。在父shell就不进行输出了。
ssh格式:
ssh user@ip > /dev/null 2>&1 << "eof"
# shell程序
exit
eof
su格式:
su - user@ip > /dev/null 2>&1 << "eof"
# shell程序
exit
eof
#!/bin/bash
# shell远程用户执行脚本
# ssh user@ip command
ssh -p222 root@192.168.1.2 "echo \"hello world\""
# 脚本执行-对于命令行太多的采用eof方式支持多行命令
ssh -p222 root@192.168.1.2 << "eof"
h="param value is hello world!"
echo "param value is ${h}"
exit
eof
# shell切换用户执行脚本
# 简单执行
# su - user -c command
su - es -c "echo \`whoami\` \" hello world\""
# 脚本执行-对于命令行太多的采用eof方式支持多行命令
su - es <<'EOF'
echo `whoami` "hello world!"
exit
EOF