Open zwhu opened 8 years ago
TLDR; 在远程主机中运行命令的 shell 语法: $: ssh user@host "commands"
TLDR; 在远程主机中运行命令的 shell 语法:
$: ssh user@host "commands"
最近的一个项目中,我们前端需要自己发布静态资源到远程目标服务器上,中间需要经过一个跳板机(为什么不用公司内部的 GitLab 方式发布,原因很多,这里就不表述了)。前端如果手动发布的话需要经过以下步骤:
从上面的步骤可以看出如果手动发布一个服务器,大概需要经过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 语法,就可以通过自动化脚本节省了大量的时间去泡妹子,好开心。
“就可以通过自动化脚本节省了大量的时间去泡妹子,好开心。” 6666
最近的一个项目中,我们前端需要自己发布静态资源到远程目标服务器上,中间需要经过一个跳板机(为什么不用公司内部的 GitLab 方式发布,原因很多,这里就不表述了)。前端如果手动发布的话需要经过以下步骤:
从上面的步骤可以看出如果手动发布一个服务器,大概需要经过7个步骤,每次发布都需要至少 4-5 分钟时间等待(我们有 12 台需要发布的机器,每次发布都需要 4(从第 3 步开始重复 12 次) * 12 分钟),而且如果网络不太好的话,等待的时间就更长了;更不要说手动发布的时候会经常忘了步骤且更容易出错了,每次发布都好像回到了原始时代。
万幸的是 ssh 本身支持在远程主机中运行命令的,语法就是
此处的 command 应该用
""
包起来,避免;
被本地主机当做定界符处理。 ok,知道 ssh 的用法,我们写个 bash 处理一下上面 7 个步骤:这是发布到一个远程主机的命令的脚本,是不是很简单?之后如果想发布到多个远程主机,只要通过简单的 while 语句就可以搞定;到这里就算结束了,大多数时候前端只需要掌握简单的 bash 语法,就可以通过自动化脚本节省了大量的时间去泡妹子,好开心。