zoukankan      html  css  js  c++  java
  • 实现定时备份mysql数据库并把备份数据库邮件发送

    一、先来看备份mysql数据库的命令

    1
    mysqldump -u root --password=root --database abcDataBase > c:/abc_backup.sql

    二、写Python程序

           BackupsDB.py

    1
    2
    3
    4
    #!/usr/bin/python
    # -*- coding: UTF-8 -*-
     '''''
    zhouzhongqing

    备份数据库  

    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
    '''
    import os
    import time
    import sched
    import smtplib
    from email.mime.text import MIMEText
    from email.header import Header
    from email.mime.multipart import MIMEMultipart
    from email.mime.application import MIMEApplication
    # 第一个参数确定任务的时间,返回从某个特定的时间到现在经历的秒数
    # 第二个参数以某种人为的方式衡量时间
    schedule = sched.scheduler(time.time, time.sleep);
    def backupsDB():
            # 如果是linux改下路径就可以了
      cmdString = 'D:/php/phpStudy/MySQL/bin/mysqldump -u root --password=root --database abcDataBase > c:/abc_backup.sql';
      os.system(cmdString);
    def sendMail():
      _user = "mall@xxxx.com"#发送者的邮箱
      _pwd = "xxxx"#发送者的密码
      _to = "1030907690@qq.com"#接收者的邮箱
      # 如名字所示Multipart就是分多个部分
      msg = MIMEMultipart()
      msg["Subject"] = "商城数据库备份"
      msg["From"] = _user
      msg["To"] = _to
      # ---这是文字部分---
      part = MIMEText("商城数据库备份")
      msg.attach(part)
      # ---这是附件部分---
      # 类型附件
      part = MIMEApplication(open('c:/abc_backup.sql', 'rb').read())
      part.add_header('Content-Disposition', 'attachment', filename="abc_backup.sql")
      msg.attach(part)
      s = smtplib.SMTP("smtp.exmail.qq.com", timeout=30) # 连接smtp邮件服务器,端口默认是25
      s.login(_user, _pwd) # 登陆服务器
      s.sendmail(_user, _to, msg.as_string()) # 发送邮件
      s.close();
    def perform_command(cmd, inc):
      # 安排inc秒后再次运行自己,即周期运行
      schedule.enter(inc, 0, perform_command, (cmd, inc));
      os.system(cmd);
      backupsDB();
      sendMail();
    def timming_exe(cmd, inc=60):
      # enter用来安排某事件的发生时间,从现在起第n秒开始启动
      schedule.enter(inc, 0, perform_command, (cmd, inc))
      # 持续运行,直到计划时间队列变成空为止
      schedule.run()
    if __name__ == '__main__':
      print("show time after 10 seconds:");
      timming_exe("echo %time%", 56400);#每间隔56400秒备份发送邮件
      #46400 基本上是半天

    然后命令

    1
    py BackupsDB.py

    运行程序就可以了。

     

  • 相关阅读:
    android 权限及原理
    通讯协议的相关知识(备忘)
    MongoDB安装以及java开发入门<二>
    Struts2架构图
    Lucene查询对象笔记_TermQuery(笔记)
    mongodb指南(翻译)(二十) developer zone 索引(四)地理信息索引(转载)
    项目结尾公共模块WebService封装
    Redhat 5.5下安装MongoDB
    wsimport生成客户端出现的异常
    Hibernate关于空间表查询时的的一个异常
  • 原文地址:https://www.cnblogs.com/quegai18/p/10551212.html
Copyright © 2011-2022 走看看