python 自动备份mysql数据库并上传到FTP服务器上

 
  
#!/usr/bin/env python
import sys,os,time
from ftplib import FTP
mysql_usr='root'
mysql_pwd='dingjia'
mysql_db='test'
mysql_charset='gb2312'
bk_path='/home/hzhida/FTPFile/backup'
logs_path=bk_path+'Logs'

def writeLogs(filename,contents):
    f=file(filename,'aw')
    f.write(contents)
    f.close()

today=bk_path+time.strftime('%Y-%m-%d')
fname=today+os.sep+time.strftime('%H%M%S')+'.gz'

if not os.path.exists(today):
    Msg='-'*30+time.strftime('%Y-%m-%d,%H:%M:%S')+'-'*30+'n'
    if(os.mkdir(today))==None:
        Msg+='**succeed to create dir:'+today+'nn'
        writeLogs(logs_path,Msg)
    else:
        Msg+='!!create backup dir:'+today+'failed,check whether dir can write! nn'
        writeLogs(logs_path,Msg)
    sys.exit()

cmd_dump='mysqldump -u%s -p%s %s |gzip > %s' %(mysql_usr,mysql_pwd,mysql_db,fname)

if os.system(cmd_dump)==0:
    writeLogs(logs_path,'database backup: '+fname+'n')
else:
    writeLogs(logs_path,'database backup failed! n')

#上传到FTP服务器上,并确保有权限写 ftp
=FTP() ftp.set_debuglevel(2) ftp.connect('localhost','21') ftp.login('hzhida','36039975') print ftp.getwelcome() ftp.cwd('Downloads') bufsize=1024 file_handler=open(fname,'rb') ftp.storbinary('STOR sql.gz',file_handler,bufsize) ftp.set_debuglevel(0) file_handler.close()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值