試試把報警日志發到微信上

前言

筆者所在公司項目的報警信息會通過釘釘發送到群組或個人,這樣如果服務出現了問題我們都會第一時間收到提醒并進行處理。

某日從釘釘收到報警信息的我突發奇想,如果自己的項目也能在出現問題的第一時間通過社交工具通知我豈不美 ( 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 小時后的消息提醒:

#標題:測試標題
#時間:2017-06-07 12:56:16
#內容:延遲消息測試
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,431評論 6 544
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,637評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 178,555評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,900評論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,629評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,976評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,976評論 3 448
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,139評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,686評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,411評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,641評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,129評論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,820評論 3 350
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,233評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,567評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,362評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,604評論 2 380

推薦閱讀更多精彩內容

  • Spring Cloud為開發人員提供了快速構建分布式系統中一些常見模式的工具(例如配置管理,服務發現,斷路器,智...
    卡卡羅2017閱讀 134,828評論 18 139
  • 點擊查看原文 Web SDK 開發手冊 SDK 概述 網易云信 SDK 為 Web 應用提供一個完善的 IM 系統...
    layjoy閱讀 13,854評論 0 15
  • 咯哦omn
    劉茹嵐閱讀 164評論 0 0
  • 我有一壺酒,足以慰風塵 飲盡酒樽處,不見故人痕 我有一壺酒,足以慰風塵 雨落幽寒冷,花落紅香沉 我有一壺酒,足以慰...
    北洋三杰閱讀 246評論 0 0
  • 其實今日里都不知道為什么要寫這樣的標題,難道不應該是跟著昨天軍訓之后的程序記錄我的上課了嗎?不過我沒有,只是隨感而...
    姜醬犟君閱讀 472評論 0 0