当前位置:  编程技术>python

Python备份Mysql脚本

    来源: 互联网  发布时间:2014-09-04

    本文导语:  代码如下:#!/usr/bin/python  import os  import time  import ftplib  import traceback  #config vars  systempathchr="/" #路径分割符,*nix用"/" win32用"\"  dbuser="root" #数据库用户名  dbpwd="dbpwd" #数据库密码  dbnamelist=["dbone","dbtwo","dbthree"] #需要...

代码如下:

#!/usr/bin/python 

import os 
import time 
import ftplib 
import traceback 

#config vars 
systempathchr="/" #路径分割符,*nix用"/" win32用"\" 

dbuser="root" #数据库用户名 
dbpwd="dbpwd" #数据库密码 
dbnamelist=["dbone","dbtwo","dbthree"] #需要备份那些数据库 

workdir="/path/to/backup/" #本地备份文件夹 
errlogfile="databack.log" #错误日志名 
ftp_addr="192.168.0.2" #ftp地址 
ftp_port="2102" #ftp端口 
ftp_user="databack" #ftp用户名 
ftp_pwd="backpwd" #ftp密码 
ftp_path="/" #存放到ftp路径 

ftpqueue=[] 


def ftpstor(): 
    #login 
    bufsize=1024 
    ftp=ftplib.FTP() 
    try: 
        ftp.connect(ftp_addr,ftp_port) 
        ftp.login(ftp_user,ftp_pwd) 
        ftp.cwd(ftp_path) 
        for filepath in ftpqueue: 

            #open file for input as binary 
            f=open(filepath,"rb") 
            #store file as binary 
            print getfilename(filepath) 
            ftp.storbinary("STOR "+getfilename(filepath),f,bufsize) 
            f.close() 
        ftp.quit() 
    except: 
        path=os.path.join(workdir,errlogfile) 
        traceback.print_exc(file=open(path,"a")) 

     

def dumpdb(dbname): 
    global ftpqueue 
    timeformat="%Y%m%d" 
    sqlvalformat="mysqldump -u%s -p"%s" "%s" >"%s"" 
    tarvalformat="tar --directory="%s" -zcf "%s" "%s"" 
    nowdate=time.strftime(timeformat) 
    dumpfile=os.path.join(workdir,dbname+".dump") 
    zipfile=os.path.join(workdir,dbname+nowdate+".tar.gz") 
    sqlval=sqlvalformat % (dbuser,dbpwd,dbname,dumpfile) 

    result=os.system(sqlval) 
    tarval=tarvalformat % (workdir,zipfile,dbname+".dump") 

    result=os.system(tarval) 
    os.remove(dumpfile) 
    ftpqueue.append(zipfile) 

def getfilename(path): 

    pt=path.rfind(systempathchr) 
    return path[pt+1:] 

def main(): 
    for dbname in dbnamelist: 
        dumpdb(dbname) 

    ftpstor() 

main()

没有仔细看,不过下面这两句,推荐看看os.path模块里面的函数,可能就不用针对linux和win分别设定不同的分隔符了 引用  
#config vars
systempathchr="/" #路径分割符,*nix用"/" win32用"\"  
看到代码里面是用在得到文件名的,可以试试os.path.basename活着os.path.split了 
 
代码如下:

 >>> import os.path 
  >>> os.path.basename("c:\test\aa.txt") 
  'aa.txt' 
  >>> os.path.split("c:\test\aa.txt") 
  ('c:\test', 'aa.txt') 
  >>> os.path.split("c:\test\aa.txt")[-1] 
  'aa.txt' 
  >>> os.path.basename("/home/test/aa.txt") 
  'aa.txt' 
  >>> os.path.split("/home/test/aa.txt") 
  ('/home/test', 'aa.txt') 
  >>> os.path.basename("/home/test/aa.txt") 
  'aa.txt'

    
 
 

您可能感兴趣的文章:

  • shell脚本中执行python脚本并接收其返回值的例子
  • Shell,Python,Jython,Perl都是脚本语言,如何选择?
  • 用Python脚本生成Android SALT扰码的方法
  • linux系统使用python监控apache服务器进程脚本分享
  • 写了个监控nginx进程的Python脚本
  • 使用python编写批量卸载手机中安装的android应用脚本
  • java直接调用python脚本的例子
  • linux系统使用python监测系统负载脚本分享
  • linux系统使用python获取内存使用信息脚本分享
  • 使用python检测手机QQ在线状态的脚本代码
  • 使用python编写android截屏脚本双击运行即可
  • Python Mysql自动备份脚本
  • Python抓取Discuz!用户名脚本代码
  • linux系统使用python获取cpu信息脚本分享
  • linux下如何运行带参数的python脚本
  • python备份文件以及mysql数据库的脚本代码
  • 重命名批处理python脚本
  • Python linecache.getline()读取文件中特定一行的脚本
  • 使用python编写脚本获取手机当前应用apk的信息
  • Python获取脚本所在目录的正确方法
  • python在windows下实现备份程序实例
  • python使用7z解压软件备份文件脚本分享
  • python实现数通设备tftp备份配置文件示例
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • python文件读写并使用mysql批量插入示例分享(python操作mysql)
  • 在Python安装MySQL支持模块的方法
  • Python下的Mysql模块MySQLdb安装详解
  • python插入mysql数据无效
  • python sqlobject(mysql)中文乱码解决方法
  • python3图片转换二进制存入mysql
  • python连接mysql调用存储过程示例
  • 可用于监控 mysql Master Slave 状态的python代码
  • Python中让MySQL查询结果返回字典类型的方法
  • Python查询Mysql时返回字典结构的代码
  • Python Mysql数据库操作 Perl操作Mysql数据库
  • python连接mysql并提交mysql事务示例
  • python批量导出导入MySQL用户的方法
  • python操作MySQL数据库的方法分享
  • python操作MySQL数据库具体方法
  • python Django连接MySQL数据库做增删改查
  • Python 分析Nginx访问日志并保存到MySQL数据库实例
  • python连接mysql数据库示例(做增删改操作)
  • python基于mysql实现的简单队列以及跨进程锁实例详解
  • python连接MySQL、MongoDB、Redis、memcache等数据库的方法
  • Python GUI编程:tkinter实现一个窗口并居中代码
  • 让python同时兼容python2和python3的8个技巧分享
  • Python不使用print而直接输出二进制字符串
  • 使用setup.py安装python包和卸载python包的方法
  • Python中实现json字符串和dict类型的互转
  • 不小心把linux自带的python卸载了,导致安装一个依赖原python的软件不能安装,请问该怎么办?
  • python异常信息堆栈输出到日志文件
  • python读取csv文件示例(python操作csv)
  • python下用os.execl执行centos下的系统时间同步命令ntpdate
  • python基础教程之python消息摘要算法使用示例
  • Python namedtuple对象json序列化/反序列化及对象恢复


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3