云飞监控 主程序:负责每分钟自动读取配置文件,将监控目录下符合要求的文件自动加入supervisor 异常警告事件监控脚本:supervisor程序异常中止时候自动发送异常警告消息到redis中 内置监控程序: redis监控:监控redis运行 钉钉推送:从redis中获取信息,并自动推送到钉钉 系统监控:监控服务器运行状态,内存,磁盘,每间隔1秒,自动存储到redis中 配置文件: 配置文件采用 ymal格式的文本文件 development_env 测试环境配置文件目录 production_env 正式环境配置文件目录 两个目录中的文件名称和格式都一致,如下 monitor.yml 负责配置指定监控目录配置 格式如下: # 所监控的目录名称,目录下所有符合 filter 和 exclude规则的文件都自动加入supervisord管理器中 '/root/project/yufei_supervisord/monitor_test': # 需要后台执行的python脚本的解释器绝对路径 name: '本地测试' # 此参数必须存在 executable: '/root/project/yufei_supervisord/venv/bin/python' # 此参数必须存在 filter: # 只匹配.py *.monitor.py后缀的文件, 此参数必须存在 - '*.py' - '*.monitor.py' exclude: # 排除以__, ex_开头的文件, 此参数为可选,可以不需要 - '__*' - 'ex_*' redis.yml 负责配置redis相关配置 格式如下: connection: host: '127.0.0.1' port: 6379 db: 6 password: null # 没有密码填写 null dingding.yml 负责配置钉钉机器配置 格式如下: webhook: 'https://oapi.dingtalk.com/robot/send?access_token=11532b3909549951f493087e873ae603fda52011940da33c2a33992a4674bb20' secret: 'SECf2d2b723c60120b1dcd66da866423e33977d1bda555124b00505067e8282b1e2' 1. 首先需要安装redis数据库,配置文件存在/etc/redis.conf 如果已有redis,则需要停止已有redis,云飞监控将托管redis,负责监控redis的运行状态与异常自动重启 redis负责存储需要推送到钉钉的消息 redis库采用 默认采用6号数据库 key名 数据类型 描述信息 需要跟随主题同时发送的系统监控信息。 yf_dingding list 负责存储需要发送到钉钉的消息信息 储存内容为json.dump后的对象 {'content': '消息主体', 'monitor_list': ['disk', 'memory']} yf_sys_monitor hash 负责储存系统监控信息,其中 disk key名 表示 磁盘监控信息, memory key名 表示 内存监控信息 2. 在python虚拟环境中安装依赖库 3. 配置对应的配置文件 development_env 测试环境配置文件目录 production_env 正式环境配置文件目录 4. 查看使用帮助 python start.py --help 4. 使用刚才配置好的虚拟环境中的python运行start.py 启动监控 5. 需要推送到钉钉群的其他程序 其他程序如果需要推送钉钉群,只需要将需要推送的消息按照指定格式存入redis,即可实时推送。 content : 消息主题 monitor_list: 表示发送钉钉消息时候,自动获取对应的系统监控信息, 不需要的话可以填写 空列表 [] disk 表示磁盘信息 memory 表示内存信息 例如: content = {'content': '消息主体', 'monitor_list': ['disk', 'memory']} data = json.dumps(content) con = redis.Redis(host=host, port=port, db=db, password=password, decode_responses=True) con.rpush('yf_dingding', data) decode_responses=True 一定要开!!!!!