怎樣利用python發(fā)送MySQL慢日志郵件-創(chuàng)新互聯(lián)

這篇文章將為大家詳細講解有關怎樣利用python 發(fā)送MySQL慢日志郵件,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

成都創(chuàng)新互聯(lián)堅持“要么做到,要么別承諾”的工作理念,服務領域包括:成都網(wǎng)站制作、網(wǎng)站建設、外貿(mào)網(wǎng)站建設、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務,滿足客戶于互聯(lián)網(wǎng)時代的杭錦網(wǎng)站設計、移動媒體設計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡建設合作伙伴!

一 需求
    因為開發(fā)針對某系統(tǒng)做穩(wěn)定性建設,需要對數(shù)據(jù)庫系統(tǒng)的慢日志進行審計,檢查優(yōu)化。和開發(fā)溝通選擇定期發(fā)送慢查詢到開發(fā)的郵箱的方式,每日匯總,然后一起評估 優(yōu)化slow query 。

二 工具實現(xiàn)
mail.py  腳本

  1. #!/usr/bin/env python

  2. # -*- coding: utf-8 -*-

  3. # mail.py

  4. import os.path

  5. import time

  6. import sys

  7. import os

  8. import json

  9. import string

  10. import random

  11. import smtplib

  12. import time

  13. from datetime import date

  14. from email.mime.multipart import MIMEMultipart

  15. from email.mime.text import MIMEText

  16. from email.mime.image import MIMEImage

  17. from email.Header import Header

  18. from email.MIMEText import MIMEText

  19. from email.MIMEMultipart import MIMEMultipart

  20. mail_user="xxx@xxxx.com";

  21. mail_pass="xxxxx";

  22. mail_smtp_server="smtp.xxxxx.com";

  23. mail_smtp_port= 25

  24. def sendMail(contents,subject,attach,mail_to):

  25.     lTime=str(time.strftime('%Y%m%d_%H',time.localtime(time.time())))

  26.     msg = MIMEMultipart('related');

  27.     if subject=="":

  28.         subject='test';

  29.     msg['Subject'] = subject+" Time:"+ lTime;

  30.     msg['From'] = mail_user;

  31.     msg['To'] = ";".join(mail_to) ;

  32.     html="";

  33.     for cont in contents:

  34.         html = html+cont[0];

  35.     msgHtml = MIMEMultipart('alternative');

  36.     msgHtml.set_charset('UTF-8');

  37.     msgAtt = MIMEText(open(attach,'rb').read(),'base','gbk');

  38.     msgAtt["Content-Type"] = 'application/octet-stream'

  39.     msgAtt["Content-Disposition"] = 'attachment; filename="'+subject+'"'

  40.     msg.attach(msgAtt);

  41.     try:

  42.         smtp = smtplib.SMTP();

  43.         smtp.connect(mail_smtp_server,mail_smtp_port)

  44.         smtp.login(mail_user,mail_pass);

  45.         smtp.sendmail(mail_user,mail_to,msg.as_string());

  46.         smtp.close();

  47.     except Exception,e:

  48.         print str(e)

 sendSlowlog.py
 

  1. #!/usr/bin/env python

  2. # -*- coding: utf-8 -*-

  3. import mail ##使用了上述腳本

  4. import sys

  5. import time

  6. import os

  7. import datetime

  8. from datetime import date

  9. from os.path import join, getsize

  10. def sendSlowlog(subject_info,attach,mail_to):

  11.     size = os.path.getsize(attach)

  12.     if(size > 1):

  13.        mail.sendMail("",subject_info,attach,mail_to)

  14. if __name__ == '__main__':

  15.    mail_to=["qilong.yangql@xxxx.com"]

  16.    lDate=str(time.strftime('%Y%m%d',time.localtime(time.time())))

  17.    lTime=str(time.strftime('%Y%m%d_%H',time.localtime(time.time())))

  18.    subject_info="Slowlog of  DBname" + lTime

  19.    attach="/u01/my3306/log/slow_"+ lDate +"/slow.log."+lTime

  20.    sendSlowlog(subject_info,attach,mail_to)



   本系統(tǒng)已經(jīng)每小時將slow log 進行分割,關于如何切割,各位可以思考一下。 

關于怎樣利用python 發(fā)送MySQL慢日志郵件就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

當前標題:怎樣利用python發(fā)送MySQL慢日志郵件-創(chuàng)新互聯(lián)
轉載來于:http://muchs.cn/article10/ddhddo.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供移動網(wǎng)站建設、定制網(wǎng)站、營銷型網(wǎng)站建設網(wǎng)站維護、網(wǎng)站制作小程序開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁設計