Python 数据库备份脚本(邮件通知+日志记录)

简介:

 在原来的基础上添加了日志管理模块,输出屏幕的同时也记录文件,方便查看日志信息:

dbbackup.py

 
  1. #!/usr/bin/python 
  2. #coding:utf-8 
  3.  
  4. import subprocess 
  5. import time 
  6. import os 
  7. import sys 
  8. import sendEmail 
  9. import getip 
  10. import logging  
  11.   
  12. #create logger  
  13. logger = logging.getLogger("dbbackup")  
  14. logger.setLevel(logging.DEBUG)  
  15. #create console handler and set level to error  
  16. ch = logging.StreamHandler()  
  17. ch.setLevel(logging.ERROR)  
  18. #create file handler and set level to debug  
  19. fh = logging.FileHandler("dbbackup.log")  
  20. fh.setLevel(logging.DEBUG)  
  21. #create formatter  
  22. formatter = logging.Formatter("%(asctime)s - %(name)s - %(levelname)s - %(message)s")  
  23. #add formatter to ch and fh  
  24. ch.setFormatter(formatter)  
  25. fh.setFormatter(formatter)  
  26. #add ch and fh to logger  
  27. logger.addHandler(ch)  
  28. logger.addHandler(fh)  
  29.   
  30.  
  31. mail_to_list = ['lihuipeng@xxx.com',] 
  32.  
  33. def backup(user='root', password='123456', host='localhost', dbname='mysql'): 
  34.     start_time = time.clock() 
  35.     ip = getip.get_ip_address('eth0'
  36.     today = time.strftime("%Y%m%d", time.localtime()) 
  37.     backup_dir = '/data/dbbackup/%s' % today 
  38.     if not os.path.isdir(backup_dir): 
  39.         os.makedirs(backup_dir) 
  40.     os.chdir(backup_dir) 
  41.     cmd = "/usr/local/mysql/bin/mysqldump --opt -u%s -p%s -h%s %s | gzip > %s-%s-%s.sql.gz" \ 
  42.                 % (user,password,host,dbname,today,ip,dbname) 
  43.     logger.debug(dbname + ':' + cmd) 
  44.     result = subprocess.Popen(cmd, shell=True,stdout=subprocess.PIPE,stderr=subprocess.STDOUT) 
  45.     content = result.stdout.read() 
  46.     if content: 
  47.         logger.error(dbname + ':' + content) 
  48.         subject = "%s - %s backup error" % (ip,dbname) 
  49.         sendEmail.send_mail(mail_to_list,subject,content) 
  50.     end_time = time.clock() 
  51.     use_time = end_time - start_time 
  52.     logger.debug(dbname + " backup use: %s" % use_time) 
  53.      
  54. def help(): 
  55.     print '''''Usage: %s dbname'''  % sys.argv[0
  56.     sys.exit(1
  57.          
  58. if __name__ == "__main__"
  59.     if len(sys.argv) != 2
  60.         help() 
  61.     backup(dbname=sys.argv[1]) 
  62.      
  63.      
  64.      

sendEmail.py

 
  1. #!/usr/bin/python 
  2. #coding:utf-8 
  3.  
  4. import smtplib 
  5. from email.mime.text import MIMEText 
  6.  
  7. mail_to_list = ['xxxxxx@qq.com',] 
  8. mail_host = 'smtp.163.com' 
  9. mail_user = 'lihuipeng007' 
  10. mail_pass = 'xxxxxxx' 
  11. mail_postfix = '163.com' 
  12.  
  13. def send_mail(to_list,subject,content): 
  14.     me = mail_user+"<"+mail_user+"@"+mail_postfix+">" 
  15.     msg = MIMEText(content) 
  16.     msg['Subject'] = subject 
  17.     msg['From'] = me 
  18.     msg['to'] = ";".join(mail_to_list) 
  19.      
  20.     try
  21.         s = smtplib.SMTP() 
  22.         s.connect(mail_host) 
  23.         s.login(mail_user,mail_pass) 
  24.         s.sendmail(me,to_list,msg.as_string()) 
  25.         s.close() 
  26.         return True 
  27.     except Exception,e: 
  28.         print str(e) 
  29.         return False 
  30.      
  31. if __name__ == "__main__"
  32.     if send_mail(mail_to_list, 'Test for python_mail'"aaaaaaaaaaaaaaa"): 
  33.         print "send success!" 
  34.     else
  35.         print "send fail!"  

getip.py

 
  1. #!/usr/bin/python 
  2. #coding:utf-8 
  3.  
  4. import socket 
  5. import fcntl 
  6. import struct 
  7. def get_ip_address(ifname): 
  8.     s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) 
  9.     return socket.inet_ntoa(fcntl.ioctl( 
  10.         s.fileno(), 
  11.         0x8915,  # SIOCGIFADDR 
  12.         struct.pack('256s', ifname[:15]) 
  13.     )[20:24]) 
  14.      
  15. if __name__ == "__main__"
  16.     print get_ip_address('eth0'
  17.     print get_ip_address('lo'
本文转自运维笔记博客51CTO博客,原文链接 http://blog.51cto.com/lihuipeng/1061307如需转载请自行联系原作者

lihuipeng
相关文章
|
5月前
|
监控 安全 程序员
Python日志模块配置:从print到logging的优雅升级指南
从 `print` 到 `logging` 是 Python 开发的必经之路。`print` 调试简单却难维护,日志混乱、无法分级、缺乏上下文;而 `logging` 支持级别控制、多输出、结构化记录,助力项目可维护性升级。本文详解痛点、优势、迁移方案与最佳实践,助你构建专业日志系统,让程序“有记忆”。
432 0
|
7月前
|
JSON 算法 API
深度分析小红书城API接口,用Python脚本实现
小红书作为以UGC内容为核心的生活方式平台,其非官方API主要通过移动端抓包解析获得,涵盖内容推荐、搜索、笔记详情、用户信息和互动操作等功能。本文分析了其接口体系、认证机制及请求规范,并提供基于Python的调用框架,涉及签名生成、登录态管理与数据解析。需注意非官方接口存在稳定性与合规风险,使用时应遵守平台协议及法律法规。
|
7月前
|
JSON API 数据格式
深度分析大麦网API接口,用Python脚本实现
大麦网为国内领先演出票务平台,提供演唱会、话剧、体育赛事等票务服务。本文基于抓包分析其非官方接口,并提供Python调用方案,涵盖演出列表查询、详情获取及城市列表获取。需注意非官方接口存在稳定性风险,使用时应遵守平台规则,控制请求频率,防范封禁与法律风险。适用于个人学习、演出信息监控等场景。
|
5月前
|
SQL 存储 监控
SQL日志优化策略:提升数据库日志记录效率
通过以上方法结合起来运行调整方案, 可以显著地提升SQL环境下面向各种搜索引擎服务平台所需要满足标准条件下之数据库登记作业流程综合表现; 同时还能确保系统稳健运行并满越用户体验预期目标.
324 6
|
6月前
|
缓存 Java 应用服务中间件
Spring Boot配置优化:Tomcat+数据库+缓存+日志,全场景教程
本文详解Spring Boot十大核心配置优化技巧,涵盖Tomcat连接池、数据库连接池、Jackson时区、日志管理、缓存策略、异步线程池等关键配置,结合代码示例与通俗解释,助你轻松掌握高并发场景下的性能调优方法,适用于实际项目落地。
1108 5
|
7月前
|
JSON API 开发者
深度分析阿里妈妈API接口,用Python脚本实现
阿里妈妈是阿里巴巴旗下营销平台,提供淘宝联盟、直通车等服务,支持推广位管理、商品查询等API功能。本文详解其API调用方法,重点实现商品推广信息(佣金、优惠券)获取,并提供Python实现方案。
|
7月前
|
JSON API 数据安全/隐私保护
深度分析虾皮城API接口,用Python脚本实现
虾皮开放平台提供丰富的API接口,支持商品管理、订单处理及促销信息查询等功能。本文详解API认证机制与调用方法,基于Python实现商品价格及到手价获取方案,适用于电商数据分析与运营。
|
7月前
|
API 数据安全/隐私保护 开发者
深度分析苏宁API接口,用Python脚本实现
深度分析苏宁API接口,用Python脚本实现
|
7月前
|
前端开发 Shell API
深度分析58同城API接口,用Python脚本实现
58同城为国内知名分类信息平台,涵盖房产、招聘、二手车等多领域。本文基于网页抓包与解析,分享其非官方接口的Python实现方案,分析核心接口特性与反爬应对策略,适用于数据学习与信息聚合。注意:非官方接口存在风险,使用需遵守平台规则。
|
6月前
|
数据采集 机器学习/深度学习 人工智能
Python:现代编程的首选语言
Python:现代编程的首选语言
793 102

热门文章

最新文章

推荐镜像

更多