zwhu / blog

嘛,写 blog 也要遵守基本法。
MIT License
66 stars 2 forks source link

ssh 执行远程主机命令的自动化 bash 脚本 #27

Open zwhu opened 8 years ago

zwhu commented 8 years ago

TLDR; 在远程主机中运行命令的 shell 语法:

$: ssh user@host "commands"

最近的一个项目中,我们前端需要自己发布静态资源到远程目标服务器上,中间需要经过一个跳板机(为什么不用公司内部的 GitLab 方式发布,原因很多,这里就不表述了)。前端如果手动发布的话需要经过以下步骤:

  1. 把所有静态资源压缩成一个 tgz 包
  2. 把压缩包 scp 到跳板机
  3. ssh 到跳板机
  4. 把压缩包从跳板机 scp 到静态资源的目标主机
  5. ssh 到目标主机
  6. 解压缩压缩包到指定目录
  7. 执行 py 脚本,发布到 cdn

从上面的步骤可以看出如果手动发布一个服务器,大概需要经过7个步骤,每次发布都需要至少 4-5 分钟时间等待(我们有 12 台需要发布的机器,每次发布都需要 4(从第 3 步开始重复 12 次) * 12 分钟),而且如果网络不太好的话,等待的时间就更长了;更不要说手动发布的时候会经常忘了步骤且更容易出错了,每次发布都好像回到了原始时代。

万幸的是 ssh 本身支持在远程主机中运行命令的,语法就是

$: ssh user@host "command1; command2; command3; ...."

此处的 command 应该用 "" 包起来,避免 ; 被本地主机当做定界符处理。 ok,知道 ssh 的用法,我们写个 bash 处理一下上面 7 个步骤:

# 打压缩包并上传到跳板机的指定目录
function compress() {
    tar -zcvf sc.tgz -C build . && scp -r sc.tgz root@xxx.xxx.xxx.xxx:~/oss_download/demo/
}

# 通过 ssh 登录跳板机执行 3 - 7 步
# 注意在跳板机跳登录到目标服务器的时候需要 ssh -tt ,可以在远程机器上 ssh 到其他的远程主机并执行。详细的解释通过 man ssh 查看
# mkidr -p 是如果目标机器不存在这个目录,就先创建这个目录,保证 cd 或者 tar 的时候不会因为目标目录不存在而引起报错

function send() {
    ssh root@xxx.xxx.xxx.xxx "scp -r oss_download/demo/sc.tgz alibaba@${1}:~/ossdowload/data/demo/ ; ssh -tt alibaba@${1} 'mkdir -p ossdowload; cd ossdowload; mkdir -p data/demo/sc/${version}; tar -zvxf data/demo/sc.tgz  -C data/demo/sc/${version}  && rm -rf data/demo/sc.tgz &&  ./ceph_tmp.py'"
}

# 执行 compress 和 send 函数
function deploy() {
    compress
    send ${1}
}

# 发送到目标服务器
deploy yyy.yyy.yyy.yy

这是发布到一个远程主机的命令的脚本,是不是很简单?之后如果想发布到多个远程主机,只要通过简单的 while 语句就可以搞定;到这里就算结束了,大多数时候前端只需要掌握简单的 bash 语法,就可以通过自动化脚本节省了大量的时间去泡妹子,好开心。

scutuyu commented 6 years ago

“就可以通过自动化脚本节省了大量的时间去泡妹子,好开心。” 6666