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

相关文章
|
11天前
|
Python
自动化微信朋友圈:Python脚本实现自动发布动态
本文介绍如何使用Python脚本自动化发布微信朋友圈动态,节省手动输入的时间。主要依赖`pyautogui`、`time`、`pyperclip`等库,通过模拟鼠标和键盘操作实现自动发布。代码涵盖打开微信、定位朋友圈、准备输入框、模拟打字等功能。虽然该方法能提高效率,但需注意可能违反微信使用条款,存在风险。定期更新脚本以适应微信界面变化也很重要。
118 61
|
2月前
|
数据采集 监控 数据挖掘
Python自动化脚本:高效办公新助手###
本文将带你走进Python自动化脚本的奇妙世界,探索其在提升办公效率中的强大潜力。随着信息技术的飞速发展,重复性工作逐渐被自动化工具取代。Python作为一门简洁而强大的编程语言,凭借其丰富的库支持和易学易用的特点,成为编写自动化脚本的首选。无论是数据处理、文件管理还是网页爬虫,Python都能游刃有余地完成任务,极大地减轻了人工操作的负担。接下来,让我们一起领略Python自动化脚本的魅力,开启高效办公的新篇章。 ###
|
1月前
|
数据采集 存储 监控
21个Python脚本自动执行日常任务(2)
21个Python脚本自动执行日常任务(2)
94 7
21个Python脚本自动执行日常任务(2)
|
21天前
|
数据挖掘 vr&ar C++
让UE自动运行Python脚本:实现与实例解析
本文介绍如何配置Unreal Engine(UE)以自动运行Python脚本,提高开发效率。通过安装Python、配置UE环境及使用第三方插件,实现Python与UE的集成。结合蓝图和C++示例,展示自动化任务处理、关卡生成及数据分析等应用场景。
88 5
|
1月前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
206 15
|
1月前
|
Android开发 开发者 Python
通过标签清理微信好友:Python自动化脚本解析
微信已成为日常生活中的重要社交工具,但随着使用时间增长,好友列表可能变得臃肿。本文介绍了一个基于 Python 的自动化脚本,利用 `uiautomator2` 库,通过模拟用户操作实现根据标签批量清理微信好友的功能。脚本包括环境准备、类定义、方法实现等部分,详细解析了如何通过标签筛选并删除好友,适合需要批量管理微信好友的用户。
57 7
|
1月前
|
安全 API 文件存储
Yagmail邮件发送库:如何用Python实现自动化邮件营销?
本文详细介绍了如何使用Yagmail库实现自动化邮件营销。Yagmail是一个简洁强大的Python库,能简化邮件发送流程,支持文本、HTML邮件及附件发送,适用于数字营销场景。文章涵盖了Yagmail的基本使用、高级功能、案例分析及最佳实践,帮助读者轻松上手。
37 4
|
2月前
|
开发者 Python
使用Python实现自动化邮件通知:当长时程序运行结束时
本文介绍了如何使用Python实现自动化邮件通知功能,当长时间运行的程序完成后自动发送邮件通知。主要内容包括:项目背景、设置SMTP服务、编写邮件发送函数、连接SMTP服务器、发送邮件及异常处理等步骤。通过这些步骤,可以有效提高工作效率,避免长时间等待程序结果。
76 9
|
2月前
|
监控 数据挖掘 数据安全/隐私保护
Python脚本:自动化下载视频的日志记录
Python脚本:自动化下载视频的日志记录
|
2月前
|
运维 监控 网络安全
自动化运维的崛起:如何利用Python脚本简化日常任务
【10月更文挑战第43天】在数字化时代的浪潮中,运维工作已从繁琐的手工操作转变为高效的自动化流程。本文将引导您了解如何运用Python编写脚本,以实现日常运维任务的自动化,从而提升工作效率和准确性。我们将通过一个实际案例,展示如何使用Python来自动部署应用、监控服务器状态并生成报告。文章不仅适合运维新手入门,也能为有经验的运维工程师提供新的视角和灵感。
下一篇
开通oss服务