小哥哥我想..把報警日誌發到微信

rapospectre發表於2017-06-09

前言

筆者所在公司專案的報警資訊會通過釘釘傳送到群組或個人,這樣如果服務出現了問題我們都會第一時間收到提醒並進行處理。

某日從釘釘收到報警資訊的我突發奇想,如果自己的專案也能在出現問題的第一時間通過社交工具通知我豈不美 ( sang ) 滋 ( xin )滋( bing ) ( kuang )。

通過微信公眾平臺進行報警很容易,申請公眾平臺後寫個報警後臺或者使用企業微信進行介面資訊傳送。但不管是公眾平臺還是企業微信對於普通使用者的入口太深,而且個人申請還需要提交資料等等一系列事情,顯然不是我想要的結果。

之前 web 版微信的協議已經有大神解析過並封裝了工具,之後又有優秀的作者不斷完善封裝了更好用的微信個人號介面。

利用微信個人號介面只要是個微訊號就能擔當傳送日誌警報的重任,不僅可以傳送到個人同時還能傳送到群組。

但是所有微信機器人都是自己主動執行,註冊會話,沒有辦法接收外部程式的日誌或報警,因此我就依託 wxpy 寫了 wechat_sender。

wechat_sender

wechat_sender 是基於 wxpytornado 實現的一個可以將你的網站、爬蟲、指令碼等其他應用中各種訊息 (日誌、報警、執行結果等) 傳送到微信的工具。

使用 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 將持續執行等待接收外部訊息複製程式碼
  1. 在另一個指令碼中向微信傳送訊息.
   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 小時後的訊息提醒:

#標題:測試標題
#時間:2017-06-07 12:56:16
#內容:延遲訊息測試複製程式碼

其他玩法

作為一隻猿,頸椎神馬的需要保護好,公司提供了理療服務,但無奈名額有限,每次預約都很困難,所以我決定寫個監控指令碼,當有預約名額時通過微信將可預約地址發給我。

寫好監控指令碼,然後部署到伺服器 celery 週期任務中,每隔 1 分鐘進行一次查詢,同時在伺服器上啟動 wechat_sender 服務。

小哥哥我想..把報警日誌發到微信

晚上打完球看手機收到了 阿綠( wechat_sender ) 發來的訊息,果斷去預約一發。

更多可能

掃描二維碼,調戲阿綠。驗證資訊輸入 'wechat_sender' 或 '加群' 進入微信交流群嘗試更多玩法

小哥哥我想..把報警日誌發到微信

關於 Wechat Sender

專案主頁github.com/bluedazzle/…
詳細文件wechat-sender.readthedocs.io/zh_CN/lates…

相關文章