12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- # -*- coding: utf-8 -*-
- import argparse
- import datetime
- import json
- import requests
- server_robot = {
- 'webhook': 'https://open.feishu.cn/open-apis/bot/v2/hook/926982f5-e7af-40f5-81fd-27d8f42718e4',
- 'key_word': '定时任务告警'
- }
- level_header_template_map = {
- "info": "turquoise",
- "error": "red",
- "warn": "yellow"
- }
- level_header_title_content_map = {
- "info": "广告模型自动更新通知",
- "error": "广告模型自动更新告警",
- "warn": "广告模型自动更新告警"
- }
- def send_msg_to_feishu(webhook, key_word, msg_text):
- """发送消息到飞书"""
- print(f"推送飞书消息内容: {msg_text}")
- headers = {'Content-Type': 'application/json'}
- payload_message = {
- "msg_type": "text",
- "content": {
- "text": '{}: {}'.format(key_word, msg_text)
- }
- }
- # response = requests.request('POST', url=webhook, headers=headers, data=json.dumps(payload_message))
- # print(response.text)
- def seconds_convert(seconds):
- hours = seconds // 3600
- minutes = (seconds % 3600) // 60
- seconds = seconds % 60
- return f"{hours}小时 {minutes}分钟 {seconds}秒"
- def _monitor(level, msg, start, elapsed):
- """消息推送"""
- now = datetime.datetime.now()
- if now.hour > 6:
- mgs_text = f"- 当前时间: {now.strftime('%Y-%m-%d %H:%M:%S')}" \
- f"\n- 任务开始时间: {start}" \
- f"\n- 任务耗时: {seconds_convert(elapsed)}" \
- f"\n- 任务描述: {msg}"
- card_json = {
- "config": {
- "wide_screen_mode": "true"
- },
- "elements": [
- {
- "tag": "div",
- "text": {
- "content": mgs_text,
- "tag": "lark_md"
- }
- }
- ],
- "header": {
- "template": level_header_template_map[level],
- "title": {
- "content": level_header_title_content_map[level],
- "tag": "plain_text"
- }
- }
- }
- send_msg_to_feishu(
- webhook=server_robot.get('webhook'),
- key_word=server_robot.get('key_word'),
- msg_text=json.dumps(card_json)
- )
- if __name__ == '__main__':
- parser = argparse.ArgumentParser(description='告警Utils')
- parser.add_argument('--level', type=str, help='通知级别, info, warn, error', required=True)
- parser.add_argument('--msg', type=str, help='消息', required=True)
- parser.add_argument('--start', type=str, help='任务开始时间', required=True)
- parser.add_argument('--elapsed', type=int, help='任务耗时【秒】', required=True)
- args = parser.parse_args()
- _monitor(
- level=args.level,
- msg=args.msg,
- start=args.start,
- elapsed=args.elapsed
- )
|