目录

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

ansible playbook shell 重复执行until_自动化

 配置远程服务的参数

{
    "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

 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/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的配合使用,自动化运维 批量定时重启程序结束。