当前位置: 首页 > news >正文

【实用工具】使用飞书机器人监控工程日志

1.创建一个飞书群聊,设置-->群机器人-->添加机器人-->自定义机器人-->修改机器人名称-->添加

 2.复制webhook地址

3.编写日志请求代码

import logging
import requests
import json
import os
from datetime import datetime
import time
import subprocess# curl -X POST -H "Content-Type: application/json" \
#     -d '{"msg_type":"text","content":{"text":"request example"}}' \
#     webhook地址def get_local_ip():try:# 执行系统命令获取本地 IP 地址result = subprocess.check_output(['ip', 'addr']).decode('utf-8')# 解析输出,找到本地 IP 地址lines = result.split('\n')for line in lines:if 'inet ' in line and '127.0.0.1' not in line:local_ip = line.strip().split(' ')[1]return local_ip.split('/')[0]  # 返回不带掩码的 IP 地址return Noneexcept Exception as e:print("无法获取本地IP地址:", e)class send_mes:def __init__(self):self.data = {"msg_type": "text","content": {# "text": "pid:%s,ip_addr:%s" % (current_process_id, ip_addr[0])"text": ""}}self.url = "webhook地址"self.headers = {"Content-Type": "application/json"}self.pid = os.getpid()self.ip_addr = get_local_ip()# sef send_message()def send_message(self, data):current_time = datetime.now()# 将当前时间转换为字符串格式current_time_str = current_time.strftime("%Y-%m-%d %H:%M:%S")data_li = [current_time_str, self.ip_addr, self.pid, data]data_li_str = [str(item) for item in data_li]self.log_ = "|".join(data_li_str)self.data["content"]["text"] = self.log_try:response = requests.post(self.url, json=self.data, headers=self.headers)if response.status_code == 200:print("消息发送成功:", response.json())else:print("消息发送失败:", response.text)except Exception as e:print("发送请求时出错:", e)if __name__ == "__main__":#实例化发送信息类send_mes_ = send_mes()#发送消息send_mes_.send_message("这是一条日志消息")

4.测试

日志信息将包括日期、执行程序的进程和ip,最后加上日志信息

  • 将error,info,debug放在三个机器人上,平时可以查看,等到真正使用时,把info和debug界别日志去掉,避免发送日志影响性能。

http://www.lryc.cn/news/335128.html

相关文章:

  • NIKKE胜利女神PC怎么设置中文 手把手教你设置中文教程
  • 【leetcode面试经典150题】2.移除元素(C++)
  • 实现几何对象按照一定距离向外缓冲
  • 现代深度学习模型和技术
  • go的orm框架-Gorm
  • 嵌入式开发学习---(部分)数据结构(无代码)
  • ChatGPT 之联盟营销
  • 1.k8s简介
  • go包下载时报proxyconnect tcp: dial tcp 127.0.0.1:80: connectex错误的解决方案
  • Vaadin框架是如何处理前后端交互的?列举几个Vaadin中常用的UI组件,并描述它们的作用。如何使用Vaadin的布局管理器来构建复杂的用户界面?
  • 动态属性的响应式问题和行内编辑的问题
  • 微信小程序第六次课(模块化和绑定事件)
  • 【Unity添加远程桌面】使用Unity账号远程控制N台电脑
  • maven的settings.xml、pom.xml配置文件
  • 使用MQTT.fx接入新版ONENet(24.4.8)
  • Selenium 自动化遇见 shadow-root 元素怎么处理?
  • 软件系统质量属性_2.面向架构评估的质量属性
  • 设计模式:抽象工厂
  • 【环境搭建】ubuntu工作站搭建全流程(显卡4090)
  • 蓝桥杯每日一题:有序分数(递归)
  • SpringBoot学习之Kibana下载安装和启动(Mac版)(三十二)
  • Mac下Docker Desktop starting的解决方法
  • Leetcode面试经典150_Q80删除有序数组中的重复项 II
  • android 使用ollvm混淆so
  • Swift:在 Win10 上编程入门
  • Linux多进程通信(4)——消息队列从入门到实战!
  • [Flutter]导入singular_flutter_sdk后运行到Android报错
  • ChatGPT新手指南:如何用AI写出专业学术论文
  • 【ZZULIOJ】1047: 对数表(Java)
  • thinkphp6使用阿里云SDK发送短信