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

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

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

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

二 工具實(shí)現(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)每小時(shí)將slow log 進(jìn)行分割,關(guān)于如何切割,各位可以思考一下。 

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

當(dāng)前標(biāo)題:怎樣利用python發(fā)送MySQL慢日志郵件-創(chuàng)新互聯(lián)
轉(zhuǎn)載來(lái)于:http://bm7419.com/article10/ddhddo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供移動(dòng)網(wǎng)站建設(shè)、定制網(wǎng)站、營(yíng)銷(xiāo)型網(wǎng)站建設(shè)、網(wǎng)站維護(hù)網(wǎng)站制作、小程序開(kāi)發(fā)

廣告

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

成都定制網(wǎng)站網(wǎng)頁(yè)設(shè)計(jì)