• shell和ansible自动化运维实例


    目录

    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

    1. #!/bin/bash
    2. echo '正在关闭应用'
    3. name="java"
    4. PID=`ps aux|grep ${name} |grep -v "grep" | awk '{print $2}'`
    5. echo $PID
    6. #判断是否为空 ,为空的判断是 ["$PID"];
    7. #此处注意都需要空格,不然会有语法错误
    8. if [ ! -z "$PID" ]; then
    9. kill -9 $PID
    10. fi

    2、nohup启动jar包,并按日期写入log日志

    1. # 带&的命令行,即使terminal(终端)关闭,或者电脑死机程序依然运行(前提是你把程序递交到服务器上);
    2. # 2>&1的意思
    3. #   这个意思是把标准错误(2)重定向到标准输出中(1),而标准输出又导入文件output里面,所以结果是标准错误和标准输出都导入文件output里面了。 至于为什么需要将标准错误重定向到标准输出的原因,那就归结为标准错误没有缓冲区,而stdout有。这就会导致 >output 2>output 文件output被两次打开,而stdout和stderr将会竞争覆盖,这肯定不是我门想要的.
    4. #   这就是为什么有人会写成: nohup ./command.sh >output 2>output出错的原因了
    5. echo "启动应用"
    6. log_dir="/usr/local/"
    7. 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

     配置远程服务的参数

    1. {
    2. "name": "My Server",
    3. "host": "192.168.1.1",
    4. "protocol": "sftp",
    5. "port": 22,
    6. "username": "root",
    7. "password": "root",
    8. "remotePath": "/usr/local/bin/",
    9. "uploadOnSave": false,
    10. "useTempFile": false,
    11. "openSsh": false
    12. }

    最后需要上传的文件上,右键点击 upload file,就可以上传至服务器了。

    4、ansible-playbook的copy模块

    1. ---
    2. #/etc/ansible/hosts配置sever的ip地址
    3. - hosts: server
    4. remote_user: root
    5. gather_facts: false
    6. tasks:
    7. - name: "复制主机上的文件到目标服务器上"
    8. copy:
    9. src: "/usr/local/bin/restart.sh" #文件或文件夹
    10. dest: "/usr/local/" #文件夹
    11. owner: root
    12. group: root
    13. mode: 755

    ansible的免密配置见ansible入门学习及案例_一个高效工作的家伙的博客-CSDN博客

     5、ansible-playbook的cron模块

    1. - hosts: server
    2. remote_user: root
    3. gather_facts: false
    4. tasks:
    5. - name: cron examples
    6. cron: backup=true name=autobackup minute=0 hour=6 user=root job="/usr/local/java_restart.sh"

    6、ansible将文件批量推送至其他服务器的指定目录

    1. /usr/local/bin# ansible-playbook copy_java_restart.yml
    2. PLAY [server] ****************************************************************************************************************************************
    3. TASK [复制主机上的文件到目标服务器上] *******************************************************************************************************************************
    4. ok: [192.168.1.1]
    5. ok: [192.168.1.2]
    6. ok: [192.168.1.3]
    7. PLAY RECAP *******************************************************************************************************************************************
    8. 192.168.1.1 : ok=1 changed=0 unreachable=0 failed=0
    9. 192.168.1.2 : ok=1 changed=0 unreachable=0 failed=0
    10. 192.168.1.3 : ok=1 changed=0 unreachable=0 failed=0

    至此shell和ansible的配合使用,自动化运维 批量定时重启程序结束。

  • 相关阅读:
    matlab simulink汽车优化设计遍历法
    Android最近的行情到底怎么样了?还能好转吗?
    基于Infineon开发板实现RT-Thread物联网 DEMO
    怎样在PDF上直接编辑文字?这几种编辑方法需要掌握
    1.2 无处不在的进程和线程
    ubuntn 磁盘加载问题 启动阶段修复
    DDR3 controller 之储存器介绍
    水果音乐制作软件FL Studio21.2中文版新功能介绍
    大数据-Storm流式框架(六)---Kafka介绍
    rtmp播放器
  • 原文地址:https://blog.csdn.net/qiuweifan/article/details/130824880