Ansible Role: os-check¶
针对linux系统进行资源巡检,生成巡检报告后通过邮件发送给接收人
要求¶
此角色仅在linux系统上执行。
测试环境¶
ansible 2.7.0
os Centos 7 X64
python 2.7.5
角色变量¶
check_day: "{{ '%Y-%m-%d' | strftime }}"
# 设置报告存储的目录
check_report_path: /tmp
check_report_file_suffix: "-{{ check_day }}"
# 设置smtp账号信息
check_mail_host: ""
check_mail_port: ""
check_mail_username: ""
check_mail_password: ""
check_mail_to: []
check_mail_subject: "System Check Report [{{ check_day }}]"
依赖¶
- 过滤器插件
filter_plugins/os-check.py [get_check_data]
- 目标机
bash
Github地址¶
https://github.com/lework/Ansible-roles/tree/master/os-check
Example Playbook¶
---
- hosts: all
gather_facts: false
vars:
check_report_path: /tmp
check_mail_host: "smtp.lework.com"
check_mail_port: "465"
check_mail_username: "ops@lework.com"
check_mail_password: "le123456"
check_mail_to: ["ops@lework.com"]
roles:
- os-check
这里注意下,check_mail_*的配置,这里使用的是ssl加密的配置方式,如果要其他的方式配置请使用
ansible-doc mail
查看使用方法,针对自身情况配置mail。
执行流程¶
- 使用脚本
files\check_linux.sh
在远端执行获取资源数据,并以json结构体返回。 - 使用
jinja2
模板将获取的数据渲染到模板文件中templates\report-cssinline.html
,生成的文件存放在指定的目录中。report-cssinline.html
是将css设置以inline
的方式存储的html文件,report.html
才是源模板文件,修改完源模板文件后,使用Responsive Email CSS Inliner进行转换下,才能更好的兼容邮件显示。- 其中模板中使用的
get_check_data
过滤器是从hostvars
中获取每台主机的脚本执行结果,进行分析整理传递给模板,使用传递回来的数据进行渲染。
- 获取生成的模板文件内容,并通过smtp发送给接收人。
统计的系统资源¶
- Hostname
- Main IP
- OS
- CPU Used
- CPU LoadAvg
- Mem Used
- Swap Used
- Disk Size Used
- Disk Inode Used
- Tcp Connection Used
- Timestamp
最后更新: 2020-12-03 08:40:01