zoukankan      html  css  js  c++  java
  • Python mysql backup

    http://www.linuxidc.com/Linux/2015-02/113057.htm

    -------------

    #!/usr/bin/python
    ###########################################################
    #
    # This python script is used for mysql database backup
    # using mysqldump utility.
    #
    # Written by : Rahul Kumar
    # Website: http://tecadmin.net
    # Created date: Dec 03, 2013
    # Last modified: Dec 03, 2013
    # Tested with : Python 2.6.6
    # Script Revision: 1.1
    #
    ##########################################################

    # Import required python libraries
    import os
    import time
    import datetime

    # MySQL database details to which backup to be done. Make sure below user having enough privileges to take databases backup.
    # To take multiple databases backup, create any file like /backup/dbnames.txt and put databses names one on each line and assignd to DB_NAME variable.

    DB_HOST = 'localhost'
    DB_USER = 'root'
    DB_USER_PASSWORD = '_root_user_password_'
    #DB_NAME = '/backup/dbnames.txt'
    DB_NAME = 'db_name'
    BACKUP_PATH = '/backup/dbbackup/'

    # Getting current datetime to create seprate backup folder like "12012013-071334".
    DATETIME = time.strftime('%m%d%Y-%H%M%S')

    TODAYBACKUPPATH = BACKUP_PATH + DATETIME

    # Checking if backup folder already exists or not. If not exists will create it.
    print "creating backup folder"
    if not os.path.exists(TODAYBACKUPPATH):
        os.makedirs(TODAYBACKUPPATH)

    # Code for checking if you want to take single database backup or assinged multiple backups in DB_NAME.
    print "checking for databases names file."
    if os.path.exists(DB_NAME):
        file1 = open(DB_NAME)
        multi = 1
        print "Databases file found..."
        print "Starting backup of all dbs listed in file " + DB_NAME
    else:
        print "Databases file not found..."
        print "Starting backup of database " + DB_NAME
        multi = 0

    # Starting actual database backup process.
    if multi:
       in_file = open(DB_NAME,"r")
       flength = len(in_file.readlines())
       in_file.close()
       p = 1
       dbfile = open(DB_NAME,"r")

       while p <= flength:
           db = dbfile.readline()   # reading database name from file
           db = db[:-1]         # deletes extra line
           dumpcmd = "mysqldump -u " + DB_USER + " -p" + DB_USER_PASSWORD + " " + db + " > " + TODAYBACKUPPATH + "/" + db + ".sql"
           os.system(dumpcmd)
           p = p + 1
       dbfile.close()
    else:
       db = DB_NAME
       dumpcmd = "mysqldump -u " + DB_USER + " -p" + DB_USER_PASSWORD + " " + db + " > " + TODAYBACKUPPATH + "/" + db + ".sql"
       os.system(dumpcmd)

    print "Backup script completed"
    print "Your backups has been created in '" + TODAYBACKUPPATH + "' directory"

  • 相关阅读:
    ajaxFileUpload 实现多文件上传(源码)
    Springboot 热部署的两种方式
    基于树莓派3B+Python3.5的OpenCV3.4的配置教程
    Shiro 架构原理
    Cron表达式
    SpringBoot中Scheduled代码实现
    Linus安装mysql8
    查看虚拟机CENTOS7 的 IP 地址和命令
    linux vi保存退出命令 (如何退出vi)
    Linux常用命令大全
  • 原文地址:https://www.cnblogs.com/moss_tan_jun/p/6831485.html
Copyright © 2011-2022 走看看