試試把報警日誌發到微信上
一、前言
筆者所在公司項目的報警信息會通過釘釘發送到群組或個人,這樣如果服務出現了問題我們都會第一時間收到提醒並進行處理。
某日從釘釘收到報警信息的我突發奇想,如果自己的項目也能在出現問題的第一時間通過社交工具通知我豈不美 ( sang ) 滋 ( xin )滋( bing ) ( kuang )。
通過微信公眾平臺進行報警很容易,申請公眾平臺後寫個報警後臺或者使用企業微信進行接口信息發送。
但不管是公眾平臺還是企業微信對於普通用戶的入口太深,而且個人申請還需要提交資料等等一系列事情,顯然不是我想要的結果。
之前 web 版微信的協議已經有大神解析過並封裝了工具,之後又有優秀的作者不斷完善封裝了更好用的微信個人號接口。
利用微信個人號接口只要是個微信號就能擔當發送日誌警報的重任,不僅可以發送到個人同時還能發送到群組。
但是所有微信機器人都是自己主動運行,註冊會話,沒有辦法接收外部程序的日誌或報警,因此我就依托 wxpy 寫了 wechat_sender。
二、wechat_sender
wechat_sender 是基於 wxpy (https://github.com/youfou/wxpy)和 tornado 實現的一個可以將你的網站、爬蟲、腳本等其他應用中各種消息 (日誌、報警、運行結果等) 發送到微信的工具。
使用 wechat_sender 很簡單,只需要有個人微信號,然後用個人微信號啟動 wechat_sender 服務。
pip install wechat_sender
1、登錄微信並啟動 wechat_sender 服務.
from wxpy import * from wechat_sender import * bot = Bot() # 這裏會掃碼登錄,如果在服務器中請使用 console_qr 參數 listen(bot) # 之後 wechat_sender 將持續運行等待接收外部消息
2、在另一個腳本中向微信發送消息.
from wechat_sender import Sender Sender().send(‘Hello From Wechat Sender‘) # Hello From Wechat Sender 這條消息將通過 1 中登錄微信的文件助手發送給你
當然,wechat_sender 支持 添加 logging handler 的方式直接繼承進已有的項目中,例如我的個人的網站、爬蟲腳本等,不必修改以前的代碼,只需要在 logger 中增加一個 wechat_sender 的 loghandler 就可以把相關日誌直接發送到微信中。
舉個栗子:
# spider.py # 假如在一個爬蟲腳本,我們想讓此腳本的警告信息直接發到微信 # 記得要先用 listen 運行 wechat_sender 服務 import logging from wechat_sender import LoggingSenderHandler logger = logging.getLogger(__name__) # spider code here def test_spider(): ... logger.exception("EXCEPTION: XXX") def init_logger(): sender_logger = LoggingSenderHandler(‘spider‘, level=logging.EXCEPTION) logger.addHandler(sender_logger) if __name__ == ‘__main__‘: init_logger() test_spider()
最後類似效果是這樣滴:
當然,wechat_sender 不僅可以用來發送日誌和警報,你也可以把他當做日程、會議提醒的利器。
wechat_sender 提供了周期消息和延時消息的功能:
# coding: utf-8 import datetime from wechat_sender import Sender sender = Sender() time = datetime.datetime.now()+datetime.timedelta(hours=1) sender.delay_send(content="測試內容", time=time, title="測試標題", remind=datetime.timedelta(minutes=59))
如果返回正常,1 分鐘後你將收到這條消息時間是 1 小時後的消息提醒:
作者丨rapospectre
來源丨segmentfault
原文地址:https://segmentfault.com/a/1190000009717078
Python學習群:238757010
試試把報警日誌發到微信上