Python 数据库备份脚本(邮件通知)

简介:

今天用Python写了一个数据库备份脚本,备份失败会用邮件的形式通知系统管理员,感觉还行,先凑和着用:

 
  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.  
  11. mail_to_list = ['lihuipeng007@51cto.com',] 
  12.  
  13. def backup(user='root', password='123456', host='localhost', dbname='mysql'): 
  14.     start_time = time.clock() 
  15.     ip = getip.get_ip_address('eth0'
  16.     today = time.strftime("%Y%m%d", time.localtime()) 
  17.     backup_dir = '/data/dbbackup/%s' % today 
  18.     if not os.path.isdir(backup_dir): 
  19.         os.makedirs(backup_dir) 
  20.     os.chdir(backup_dir) 
  21.     cmd = "/usr/local/mysql/bin/mysqldump --opt -u%s -p%s -h%s %s | gzip > %s-%s-%s.sql.gz" \ 
  22.                 % (user,password,host,dbname,today,ip,dbname) 
  23.     result = subprocess.Popen(cmd, shell=True,stdout=subprocess.PIPE,stderr=subprocess.STDOUT) 
  24.     content = result.stdout.read() 
  25.     if content: 
  26.         print "Dump error at %s" % content 
  27.         subject = "%s - %s backup error" % (ip,dbname) 
  28.         sendEmail.send_mail(mail_to_list,subject,content) 
  29.     end_time = time.clock() 
  30.     use_time = end_time - start_time 
  31.     print "backup use: %s" % use_time 
  32.      
  33. def help(): 
  34.     print '''''Usage: %s dbname'''  % sys.argv[0
  35.     sys.exit(1
  36.          
  37. if __name__ == "__main__"
  38.     if len(sys.argv) != 2
  39.         help() 
  40.     backup(dbname=sys.argv[1]) 

发送邮件的PY接口:

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 = ['lihuipeng007@51cto.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!"  

获取本机IP地址的PY接口:

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'

参考博文:

http://www.cnblogs.com/gudai/archive/2008/12/17/1356723.html

http://www.juyimeng.com/simple-python-send-mail-sample-code-with-smtp-auth.html

本文转自运维笔记博客51CTO博客,原文链接http://blog.51cto.com/lihuipeng/1059805如需转载请自行联系原作者


lihuipeng

相关文章
|
28天前
|
安全 网络安全 文件存储
思科设备巡检命令Python脚本大集合
【10月更文挑战第18天】
64 1
思科设备巡检命令Python脚本大集合
|
24天前
|
关系型数据库 MySQL 数据库连接
python脚本:连接数据库,检查直播流是否可用
【10月更文挑战第13天】本脚本使用 `mysql-connector-python` 连接MySQL数据库,检查 `live_streams` 表中每个直播流URL的可用性。通过 `requests` 库发送HTTP请求,输出每个URL的检查结果。需安装 `mysql-connector-python` 和 `requests` 库,并配置数据库连接参数。
122 68
|
8天前
|
存储 Python
Python自动化脚本编写指南
【10月更文挑战第38天】本文旨在为初学者提供一条清晰的路径,通过Python实现日常任务的自动化。我们将从基础语法讲起,逐步引导读者理解如何将代码块组合成有效脚本,并探讨常见错误及调试技巧。文章不仅涉及理论知识,还包括实际案例分析,帮助读者快速入门并提升编程能力。
34 2
|
10天前
|
运维 监控 Python
自动化运维:使用Python脚本简化日常任务
【10月更文挑战第36天】在数字化时代,运维工作的效率和准确性成为企业竞争力的关键。本文将介绍如何通过编写Python脚本来自动化日常的运维任务,不仅提高工作效率,还能降低人为错误的风险。从基础的文件操作到进阶的网络管理,我们将一步步展示Python在自动化运维中的应用,并分享实用的代码示例,帮助读者快速掌握自动化运维的核心技能。
25 3
|
15天前
|
缓存 运维 NoSQL
python常见运维脚本_Python运维常用脚本
python常见运维脚本_Python运维常用脚本
20 3
|
15天前
|
数据采集 JSON 数据安全/隐私保护
Python常用脚本集锦
Python常用脚本集锦
16 2
|
16天前
|
运维 监控 应用服务中间件
自动化运维:如何利用Python脚本提升工作效率
【10月更文挑战第30天】在快节奏的IT行业中,自动化运维已成为提升工作效率和减少人为错误的关键技术。本文将介绍如何使用Python编写简单的自动化脚本,以实现日常运维任务的自动化。通过实际案例,我们将展示如何用Python脚本简化服务器管理、批量配置更新以及监控系统性能等任务。文章不仅提供代码示例,还将深入探讨自动化运维背后的理念,帮助读者理解并应用这一技术来优化他们的工作流程。
|
17天前
|
运维 监控 Linux
自动化运维:如何利用Python脚本优化日常任务##
【10月更文挑战第29天】在现代IT运维中,自动化已成为提升效率、减少人为错误的关键技术。本文将介绍如何通过Python脚本来简化和自动化日常的运维任务,从而让运维人员能够专注于更高层次的工作。从备份管理到系统监控,再到日志分析,我们将一步步展示如何编写实用的Python脚本来处理这些任务。 ##
|
23天前
|
JSON 测试技术 持续交付
自动化测试与脚本编写:Python实践指南
自动化测试与脚本编写:Python实践指南
25 1
|
25天前
|
关系型数据库 MySQL 数据处理
探索Python中的异步编程:从asyncio到异步数据库操作
在这个快节奏的技术世界里,效率和性能是关键。本文将带你深入Python的异步编程世界,从基础的asyncio库开始,逐步探索到异步数据库操作的高级应用。我们将一起揭开异步编程的神秘面纱,探索它如何帮助我们提升应用程序的性能和响应速度。