TLDR;
在远程主机中运行命令的 shell 语法:$: ssh user@host "commands"
最近的一个项目中,我们前端需要自己发布静态资源到远程目标服务器上,中间需要经过一个跳板机(为什么不用公司内部的 GitLab 方式发布,原因很多,这里就不表述了)。前端如果手动发布的话需要经过以下步骤:
把所有静态资源压缩成一个 tgz 包
把压缩包 scp 到跳板机
ssh 到跳板机
把压缩包从跳板机 scp 到静态资源的目标主机
ssh 到目标主机
解压缩压缩包到指定目录
执行 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 语法,就可以通过自动化脚本节省了大量的时间去泡妹子,好开心。