自從用Python給項目寫一個監(jiān)控倦微,少了不少麻煩事情

自從用Python給項目寫一個監(jiān)控,少了不少麻煩事情

在公司里做的一個接口系統(tǒng)正压,主要是對接第三方的系統(tǒng)接口欣福,所以,這個系統(tǒng)里會和很多其他公司的項目交互焦履。隨之而來一個很蛋疼的問題拓劝,這么多公司的接口雏逾,不同公司接口的穩(wěn)定性差別很大,訪問量大的時候郑临,有的不怎么行的接口就各種出錯了栖博。

這個接口系統(tǒng)剛剛開發(fā)不久,整個系統(tǒng)中厢洞,處于比較邊緣的位置仇让,不像其他項目,有日志庫躺翻,還有短信告警丧叽,一旦出問題,很多情況下都是用戶反饋回來公你,所以踊淳,我的想法是,拿起python陕靠,為這個項目寫一個監(jiān)控迂尝。如果在調(diào)用某個第三方接口的過程中,大量出錯了剪芥,說明這個接口有有問題了雹舀,就可以更快的采取措施。

項目的也是有日志庫的粗俱,所有的info,error日志都是每隔一分鐘掃描入庫虚吟,日志庫是用的mysql寸认,表里有幾個特別重要的字段:

evel 日志級別
message 日志內(nèi)容 
file_name Java代碼文件
log_time 日志時間

有日志庫,就不用自己去線上環(huán)境掃日志分析了串慰,直接從日志庫入手偏塞。由于日志庫在線上時每隔1分鐘掃,那我就去日志庫每隔2分鐘掃一次邦鲫,如果掃到有一定數(shù)量的error日志就報警灸叼,如果只有一兩條錯誤就可以無視了,也就是短時間爆發(fā)大量錯誤日志庆捺,就可以斷定系統(tǒng)有問題了古今。報警方式就用發(fā)送郵件,所以滔以,需要做下面幾件事情:

  1. 操作MySql捉腥。
  2. 發(fā)送郵件。
  3. 定時任務(wù)你画。
  4. 日志抵碟。
  5. 運行腳本桃漾。

明確了以上幾件事情,就可以動手了拟逮。

操作數(shù)據(jù)庫

使用MySQLdb這個驅(qū)動撬统,直接操作數(shù)據(jù)庫,主要就是查詢操作敦迄。

獲取數(shù)據(jù)庫的連接:

def get_con(): host = "127.0.0.1" port = 3306 logsdb = "logsdb" user = "root" password = "never tell you" con = MySQLdb.connect(host=host, user=user, passwd=password, db=logsdb, port=port, charset="utf8") return con

從日志庫里獲取數(shù)據(jù)恋追,獲取當(dāng)前時間之前2分鐘的數(shù)據(jù),首先颅崩,根據(jù)當(dāng)前時間進行計算一下時間

def calculate_time(): now = datetime.now() now_min = now.minute if now_min < 2: now_min += 60 - 2 else: now_min -= 2 return now.replace(minute=now_min).strftime("%Y-%m-%d %H:%M:%S")

然后几于,根據(jù)時間和日志級別去日志庫查詢數(shù)據(jù)

def get_data(): select_time = calculate_time() logger.info("select time:"+select_time) sql = "select file_name,message from logsdb.app_logs_record " "where log_time >"+"'"+select_time+"'" "and level="+"'ERROR'" "order by log_time desc" conn = get_con() cursor = conn.cursor() cursor.execute(sql) results = cursor.fetchall() cursor.close() conn.close() return results

發(fā)送郵件

使用python發(fā)送郵件比較簡單,使用標(biāo)準(zhǔn)庫smtplib就可以

這里使用163郵箱進行發(fā)送沿后,你可以使用其他郵箱或者企業(yè)郵箱都行沿彭,不過host和port要設(shè)置正確。

def send_email(content):
 sender = "sender_monitor@163.com" receiver = ["rec01@163.com", "rec02@163.com"] host = 'smtp.163.com' port = 465 msg = MIMEText(content) msg['From'] = "sender_monitor@163.com" msg['To'] = "rec01@163.com,rec02@163.com" msg['Subject'] = "system error warning" try: smtp = smtplib.SMTP_SSL(host, port) smtp.login(sender, '123456') smtp.sendmail(sender, receiver, msg.as_string()) logger.info("send email success") except Exception, e: logger.error(e)

定時任務(wù)

使用一個單獨的線程尖滚,每2分鐘掃描一次喉刘,如果ERROR級別的日志條數(shù)超過5條,就發(fā)郵件通知漆弄。

def task(): while True: logger.info("monitor running") results = get_data() if results is not None and len(results) > 5: content = "recharge error:" logger.info("a lot of error,so send mail") for r in results: content += r[1]+'
' send_email(content) sleep(2*60)

日志

為這個小小的腳本配置一下日志log.py睦裳,讓日志可以輸出到文件和控制臺中。

自從用Python給項目寫一個監(jiān)控撼唾,少了不少麻煩事情

所以廉邑,最后,這個監(jiān)控小程序就是這樣的app_monitor.py

自從用Python給項目寫一個監(jiān)控倒谷,少了不少麻煩事情

運行腳本

腳本在服務(wù)器上運行蛛蒙,使用supervisor進行管理。

在服務(wù)器(centos6)上安裝supervisor渤愁,然后在/etc/supervisor.conf中加入一下配置

[program:app-monitor]command = python /root/monitor/app_monitor.pydirectory = /root/monitoruser = root

然后在終端中運行supervisord啟動supervisor牵祟。

在終端中運行supervisorctl,進入shell抖格,運行status查看腳本的運行狀態(tài)诺苹。

總結(jié)

這個小監(jiān)控思路很清晰,還可以繼續(xù)修改雹拄,比如:監(jiān)控特定的接口收奔,發(fā)送短信通知等等。

因為有日志庫滓玖,就少了去線上正式環(huán)境掃描日志的麻煩筹淫,所以,如果沒有日志庫,就要自己上線上環(huán)境掃描损姜,在正式線上環(huán)境一定要小心哇~

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末饰剥,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子摧阅,更是在濱河造成了極大的恐慌汰蓉,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,509評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件棒卷,死亡現(xiàn)場離奇詭異顾孽,居然都是意外死亡,警方通過查閱死者的電腦和手機比规,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評論 3 394
  • 文/潘曉璐 我一進店門若厚,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人蜒什,你說我怎么就攤上這事测秸。” “怎么了灾常?”我有些...
    開封第一講書人閱讀 163,875評論 0 354
  • 文/不壞的土叔 我叫張陵霎冯,是天一觀的道長。 經(jīng)常有香客問我钞瀑,道長沈撞,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,441評論 1 293
  • 正文 為了忘掉前任雕什,我火速辦了婚禮缠俺,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘贷岸。我一直安慰自己晋修,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,488評論 6 392
  • 文/花漫 我一把揭開白布凰盔。 她就那樣靜靜地躺著,像睡著了一般倦春。 火紅的嫁衣襯著肌膚如雪户敬。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,365評論 1 302
  • 那天睁本,我揣著相機與錄音尿庐,去河邊找鬼。 笑死呢堰,一個胖子當(dāng)著我的面吹牛抄瑟,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播枉疼,決...
    沈念sama閱讀 40,190評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼皮假,長吁一口氣:“原來是場噩夢啊……” “哼鞋拟!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起惹资,我...
    開封第一講書人閱讀 39,062評論 0 276
  • 序言:老撾萬榮一對情侶失蹤贺纲,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后褪测,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體猴誊,經(jīng)...
    沈念sama閱讀 45,500評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,706評論 3 335
  • 正文 我和宋清朗相戀三年侮措,在試婚紗的時候發(fā)現(xiàn)自己被綠了懈叹。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,834評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡分扎,死狀恐怖澄成,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情笆包,我是刑警寧澤环揽,帶...
    沈念sama閱讀 35,559評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站庵佣,受9級特大地震影響歉胶,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜巴粪,卻給世界環(huán)境...
    茶點故事閱讀 41,167評論 3 328
  • 文/蒙蒙 一通今、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧肛根,春花似錦辫塌、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,779評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至芭届,卻和暖如春储矩,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背褂乍。 一陣腳步聲響...
    開封第一講書人閱讀 32,912評論 1 269
  • 我被黑心中介騙來泰國打工持隧, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人逃片。 一個月前我還...
    沈念sama閱讀 47,958評論 2 370
  • 正文 我出身青樓屡拨,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子呀狼,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,779評論 2 354

推薦閱讀更多精彩內(nèi)容