分布式部署脚本

需求:把一个java程序部署到多台测试服务器上,每台服务器的文件路径、文件名等完全一致。

     为了不重复操作,写了以下脚本,只需要操作一次即可(1.停止程序 2.上传jar包 3.开启程序)

1.开启脚本(启动jar命令,写pid到文件)
每台机器:/home/b/start.sh:

nohup java -jar test-1.0.0-SNAPSHOT.jar > test.log 2>&1 &
echo $! > /home/b/test.pid

2.关闭脚本(读文件中pid,杀掉进程)
每台机器:/home/b/stop.sh:

pid=$(cat /home/b/test.pid)
kill -9 $pid

3.主机的批量开启脚本
主机:/home/b/batch_start.sh:

sshpass -p password rsync /home/b/test-1.0.0-SNAPSHOT.jar root@192.168.78.102:/home/b/
sshpass -p password rsync /home/b/test-1.0.0-SNAPSHOT.jar root@192.168.78.103:/home/b/
./start.sh
sshpass -p password ssh root@192.168.78.103 "cd /home/b && ./start.sh"
sshpass -p password ssh root@192.168.78.102 "cd /home/b && ./start.sh"

4.主机的批量关闭脚本
主机:/home/b/batch_stop.sh:

./stop.sh
sshpass -p password ssh root@192.168.78.103 "cd /home/b && ./stop.sh"
sshpass -p password ssh root@192.168.78.102 "cd /home/b && ./stop.sh"

注:

sshpass命令用于免输入密码,若机器上没有就从网上下载一个安装上。缺点:密码写在脚本里了,有风险。

rsync命令用于向其他机器传输文件。

转载于:https://www.cnblogs.com/bsds/p/6907221.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值