设为首页 收藏本站
查看: 947|回复: 0

[经验分享] 利用Python脚本一键备份Mysql数据库

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-12-22 09:13:06 | 显示全部楼层 |阅读模式
工作中以前都是使用shell为主,最近一段时间静下心来学习python语言,通过一段时间的学习,打算做一些简单的工作任务,算是一个小实践。
#########################################
    测试环境:centos6.2/windows 7       #

    数据库版本:mysql 5.x                #

    Python版本:python 2.7.3            #

#########################################
    脚本如果用在windows环境,稍作改动即可。linux下可以直接使用。不推荐使用python 2.6版本,一般绝大多数linux系统在安装时已经自带python。

    脚本内容如下,也是为了联系面向对象技术,所以采用了静态方法、特性、私有字段、邮件函数等内容,脚本按日备份:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
#!/usr/bin/env python
#_*_ coding:utf-8 _*_
#!/usr/bin/env python
#_*_ coding:utf-8 _*_
#Backup with mysqldump everyday
#Backup Mysql can use on windows or linux
#But TAR Fuction can only use on linux because command different between windows and linux
import time
import datetime
import os
import conf
import smtplib
from email.mime.text import MIMEText

#返回任意一天
class Day(object):
    @staticmethod
    def any_day(add_days):
        today = datetime.date.today()
        utl_add_day = str(today - datetime.timedelta(days=int(add_days)))
        return utl_add_day
     
class MysqlBackup(object):
    def __init__(self,**kargs):
        self.__host = kargs['host']
        self.__dbname = kargs['db']
        self.__username = kargs['user']
        self.__password = kargs['passwd']   
        self.__port = kargs['port']
         
#mysqldump备份数据库        
    def BakData(self,backup_file):
        cmd_bak='mysqldump -u '+self.__username+' -p'+self.__password+' -h'+self.__host +' '+self.__dbname+' --single-transaction '+' > '+backup_file
        outp = os.system(cmd_bak)
        return cmd_bak,outp
     
#Linux下用tar打包压缩备份文件   
    def TarData(self,date):
        cmd_tar='tar zcf '+conf.backup_path+self.__dbname+'_'+date+'.tar.gz '+'-C '+conf.backup_path+self.__dbname+'_'+date+'.dump >> /dev/null 2>&1'
        outp = os.system(cmd_tar)
        return cmd_tar,outp     
        
    @property
    def dbname(self):
        return self.__dbname
     
class sendmail():
    def __init__(self, *args,**kargs):
        self.SMTPserver = kargs['address']
        self.sender = kargs['sender']
        self.password = kargs['password']
        self.destination = args[0]

#登录邮箱发送邮件        
    def send(self,message):
        msg = MIMEText(message,_charset='utf-8')
        msg['Subject'] = 'Mysql Backup Failed'
        msg['From'] = self.sender
        msg['To'] = self.destination
        mailserver = smtplib.SMTP(self.SMTPserver, 25)
        mailserver.login(self.sender, self.password)
        mailserver.sendmail(self.sender, [self.destination], msg.as_string())
        mailserver.quit()
        print 'send email success'

#主函数起始        
def main():      
    DATA_DATE = Day.any_day(1)
    #发件人和收件人地址
    MAIL_USER_ADDRESS = sendmail(*conf.note_user,**conf.contact_user)
    #初始化需要备份的数据库类
    DB_BAK_INFO = MysqlBackup(**conf.conn_dict)
    backup_file = conf.backup_path+DB_BAK_INFO.dbname+'_'+DATA_DATE+'.dump'
    print backup_file
    log_file = conf.backup_path+DB_BAK_INFO.dbname+'.log'
    #MAIL_USER_ADDRESS.send('I send a message by Python. 你好')
     
    #保存日志
    with open(log_file,'a') as f:
        f.write('\n\n ***********************\n')
        f.write(' * '+time.strftime("%Y-%m-%d %H:%M:%S",time.localtime())+' *\n')
        f.write(' ***********************\n')
        #不存在dump备份文件才备份
        if os.path.isfile(backup_file) is False:
            #备份
            cmd_result = DB_BAK_INFO.BakData(backup_file)
            print cmd_result
            f.write('** COMMAND     :'+cmd_result[0]+'\n')
            f.write('** DATABASE    : '+DB_BAK_INFO.dbname+'\n')
            f.write('** DATA_DATE   : '+DATA_DATE+'\n')
            f.write('** RESULT(BAK) : '+('succeed\n' if cmd_result[1] == 0 else 'failed\n'))
            #备份成功打包
            if cmd_result[1] == 0:
                #打包
                tar_result = DB_BAK_INFO.TarData(DATA_DATE)
                f.write('** COMMAND     :'+tar_result[0]+'\n')
                f.write('** RESULT(TAR) : '+('succeed' if tar_result[1] == 0 else 'failed'))
                #打包成功删除备份文件
                if tar_result[1] == 0:
                    os.remove(backup_file)
                else:
                    MAIL_USER_ADDRESS.send('Mysql备份打包失败,请核查!')
            else:
                MAIL_USER_ADDRESS.send('Mysql数据库备份失败,请核查!')
        else:
            f.write('** RESULT(BAK) : ' +'%s is already exists\n' %backup_file)

#程序入口        
if __name__ == '__main__':
    main()
#bakimeeting.bakData('backup_file')



配置文件conf.py,请自行更换
1
2
3
4
5
6
#!/usr/bin/env python
#_*_ coding:utf-8 _*_
conn_dict = dict(host='127.0.0.1',user='root',passwd='12345',db='08day05',port = 33061)
contact_user = dict(address='smtp.163.com',sender='xxx@163.com',password='xxxxxx')
note_user = ('xxxxx@126.com',)
backup_path = "D:/KuGou/"



后期优化思路:
多线程提供性能,支持多个库批量备份


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-154607-1-1.html 上篇帖子: 三元运算式、lambda表达式、内置函数map、reduce、filter以及yield生成器 下篇帖子: Python的pass语句 数据库
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表