目录
1、找到java进程并kill
2、nohup启动jar包,并按日期写入log日志
3、vscode上传服务器
4、ansible-playbook的copy模块
5、ansible-playbook的cron模块
6、ansible将文件批量推送至其他服务器的指定目录
将N台电脑上的java程序定时重启,不用每隔一段时间手工重启jar程序,同时减少在多台电脑多次部署,我使用shell和ansible配合使用,实现批量定时重启程序的自动给运维。
1、找到java进程并kill
#!/bin/bash
echo '正在关闭应用'
name="java"
PID=`ps aux|grep ${name} |grep -v "grep" | awk '{print $2}'`
echo $PID
#判断是否为空 ,为空的判断是 ["$PID"];
#此处注意都需要空格,不然会有语法错误
if [ ! -z "$PID" ]; then
kill -9 $PID
fi
2、nohup启动jar包,并按日期写入log日志
# 带&的命令行,即使terminal(终端)关闭,或者电脑死机程序依然运行(前提是你把程序递交到服务器上);
# 2>&1的意思
# 这个意思是把标准错误(2)重定向到标准输出中(1),而标准输出又导入文件output里面,所以结果是标准错误和标准输出都导入文件output里面了。 至于为什么需要将标准错误重定向到标准输出的原因,那就归结为标准错误没有缓冲区,而stdout有。这就会导致 >output 2>output 文件output被两次打开,而stdout和stderr将会竞争覆盖,这肯定不是我门想要的.
# 这就是为什么有人会写成: nohup ./command.sh >output 2>output出错的原因了
echo "启动应用"
log_dir="/usr/local/"
nohup java -jar $log_dir/api-mysql.jar > $log_dir/nohup`date -d yesterday +%Y%m%d`.log 2>&1 &
3、vscode上传服务器
注:vscode安装sftp插件。ctrl+shift+p键,打开面板,并选择sftp.config
配置远程服务的参数
{
"name": "My Server",
"host": "192.168.1.1",
"protocol": "sftp",
"port": 22,
"username": "root",
"password": "root",
"remotePath": "/usr/local/bin/",
"uploadOnSave": false,
"useTempFile": false,
"openSsh": false
}
最后需要上传的文件上,右键点击 upload file,就可以上传至服务器了。
4、ansible-playbook的copy模块
---
#/etc/ansible/hosts配置sever的ip地址
- hosts: server
remote_user: root
gather_facts: false
tasks:
- name: "复制主机上的文件到目标服务器上"
copy:
src: "/usr/local/bin/restart.sh" #文件或文件夹
dest: "/usr/local/" #文件夹
owner: root
group: root
mode: 755
ansible的免密配置见ansible入门学习及案例_一个高效工作的家伙的博客-CSDN博客
5、ansible-playbook的cron模块
- hosts: server
remote_user: root
gather_facts: false
tasks:
- name: cron examples
cron: backup=true name=autobackup minute=0 hour=6 user=root job="/usr/local/magicapi/java_restart.sh"
6、ansible将文件批量推送至其他服务器的指定目录
/usr/local/bin# ansible-playbook copy_java_restart.yml
PLAY [server] ****************************************************************************************************************************************
TASK [复制主机上的文件到目标服务器上] *******************************************************************************************************************************
ok: [192.168.1.1]
ok: [192.168.1.2]
ok: [192.168.1.3]
PLAY RECAP *******************************************************************************************************************************************
192.168.1.1 : ok=1 changed=0 unreachable=0 failed=0
192.168.1.2 : ok=1 changed=0 unreachable=0 failed=0
192.168.1.3 : ok=1 changed=0 unreachable=0 failed=0
至此shell和ansible的配合使用,自动化运维 批量定时重启程序结束。