ansible分发日志清理脚本
日志清理目前覆盖58台服务器如下
此处省略
BS003获取被控制端的备份日志
[root@BS003 backup]# ansible 192.168.16.211 -m fetch -a 'src=/data/home/deploy/output/logs/backup_MC005.tar.gz dest=/tmp/backup'
BS003删除被控端的备份日志
[root@BS003 log]# ansible 192.168.16.211 -m file -a 'path=/data/home/deploy/output/logs/backup_MC005.tar.gz state=absent'
被控端定时清理log
0 2 * * * /bin/sh /server/scripts/log.sh 每天凌晨2点进行清理日志和备份
ansible服务端每天3点pull 被控端的tar.gz 每天凌晨4点进行删除控制端的tar.gz
0 3 * * * /bin/bash /server/scripts/cront_pull.sh
0 4 * * * /bin/bash /server/scripts/cront_delete.sh
批量操作流程实现:
ansible-ploybook
- ansible服务端先推送shell 脚本到被控端的/server/scripts目录下和执行权限
- 定义被控端定时任务清理(每天凌晨2点备份及清理)
- ansible服务端定时拉取被控端备份tar(每天凌晨3点)
- ansible 服务端删除被控端备份的tag
- hosts: log
tasks:
- name: copy file shell
copy:
src: /server/scripts/probject/log.sh
dest: /server/scripts
mode: 0755
- name: Delete log regularly
cron:
minute: 0
hour: 2
day: \*
month: \*
weekday: \*
name: Delete log regularly
job: /bin/bash /server/scripts/log.sh
从远端拉取tar包到本地
ansible 192.168.16.210 -m fetch -a 'src=/home/deploy/backup_MC004.tar.gz dest=/tmp/backup'
删除远端tar包
ansible 192.168.16.210 -m file -a 'path=/data/home/deploy/output/logs/backup_MC004.tar.gz state=absent'