Python tk dos命令备份mysql数据库

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: Python tk dos命令备份mysql数据库

一、操作环境

1、python 3.7(个人感觉不是第2代就行)

2、tk pythom已经内置

3、pycharm 2020

4、SQLAlchemy     1.4.44

二、来个图提个神

三、上代码

import os
import tkinter
from tkinter import ttk, messagebox, filedialog
from framework.base.BaseConfig import BaseConfig
from framework.control.AdenButton import AdenButton
from framework.control.AdenCheckButton import AdenCheckButton
from framework.control.AdenEntry import AdenEntry
from framework.control.AdenLabel import AdenLabel
from framework.control.AdenMessageBox import AdenMessageBox
from framework.control.AdenTkPlugin import TkPlugin
from framework.pulgin.Tools import Tools
from operation.access.DBBackupAccess import DBBackupAccess
from operation.entity.DBBackupEntity import DBBackupEntity
class MySqlDBBackView():
    dbAccess = DBBackupAccess()
    action_type = "add"
    def getFrame(self, root, tab):
        self.note_book = tab
        self.frame = tkinter.Frame(root)
        frame_data_config = self.frame
        frame_data_config.configure(background=TkPlugin.background())
        frame_data_config.columnconfigure(1, weight=1)  # 设置第2列自动适应Frame 需要sitcky布局配合
        frame_data_config.columnconfigure(3, weight=1)  # 设置第4列自动适应Frame
        frame_data_config.rowconfigure(8, weight=1)
        # 第1行
        lable_sys_name = AdenLabel(frame_data_config, text="数据库类型:")
        lable_sys_name.grid(row=0, column=0, sticky=tkinter.E)
        self.com_database_type = ttk.Combobox(frame_data_config, state='readonly')  # 邮件名称 通过自定义控件实现 读取值和获取值都可以通过控件获取
        database_type = ('MySql', 'SQLSERVER')
        self.com_database_type['value'] = database_type
        self.com_database_type.grid(row=0, column=1, sticky=TkPlugin.sticky_all(), padx="6", pady="6", columnspan=3)
        self.com_database_type.current(0)
        # 第2行1列
        connection_string = AdenLabel(frame_data_config, text="数据库IP地址:", bg=TkPlugin.background())
        connection_string.grid(row=1, column=0, sticky=tkinter.E)
        self.txt_connection_ipaddress = AdenEntry(frame_data_config)
        self.txt_connection_ipaddress.grid(row=1, column=1, sticky=TkPlugin.sticky_all(), padx="6", pady="6")
        # 第2行2列
        connection_name = AdenLabel(frame_data_config, text="数据库名称:", bg=TkPlugin.background())
        connection_name.grid(row=1, column=2, sticky=tkinter.E)
        self.txt_connection_name = AdenEntry(frame_data_config)
        self.txt_connection_name.grid(row=1, column=3, sticky=TkPlugin.sticky_all(), padx="6", pady="6")
        #  第3行1列
        lable_smtp_user = AdenLabel(frame_data_config, text="用户名:", bg=TkPlugin.background())
        lable_smtp_user.grid(row=2, column=0, sticky=tkinter.E)
        self.txt_user_name = AdenEntry(frame_data_config)
        self.txt_user_name.grid(row=2, column=1, sticky=TkPlugin.sticky_all(), padx="6", pady="6")
        # 第3行2列
        lable_smtp_pass = AdenLabel(frame_data_config, text="密码:", bg=TkPlugin.background())
        lable_smtp_pass.grid(row=2, column=2, sticky=tkinter.E)
        self.txt_pass_word = AdenEntry(frame_data_config)
        self.txt_pass_word.grid(row=2, column=3, sticky=TkPlugin.sticky_all(), padx="6", pady="6")
        # 第4行1
        lable_dbback_path = AdenLabel(frame_data_config, text="端口号:", bg=TkPlugin.background())
        lable_dbback_path.grid(row=3, column=0, sticky=tkinter.E)
        self.txt_db_port = AdenEntry(frame_data_config)
        self.txt_db_port.grid(row=3, column=1, sticky=TkPlugin.sticky_all(), padx="6", pady="6")
        # 第4行2
        lable_dbback_path = AdenLabel(frame_data_config, text="自动备份:", bg=TkPlugin.background())
        lable_dbback_path.grid(row=3, column=2, sticky=tkinter.E)
        self.ck_check_view = tkinter.IntVar()
        self.check_view = AdenCheckButton(frame_data_config, variable=self.ck_check_view, text="选中是自动", fg="#0081FF")
        self.check_view.grid(row=3, column=3, sticky=tkinter.W, padx="6", columnspan=2)
        # 第5行第1列
        lable_dbback_path = AdenLabel(frame_data_config, text="备份数量:", bg=TkPlugin.background())
        lable_dbback_path.grid(row=4, column=0, sticky=tkinter.E)
        self.txt_dbback_number = AdenEntry(frame_data_config)
        self.txt_dbback_number.grid(row=4, column=1, sticky=TkPlugin.sticky_all(), padx="6", pady="6")
        # 第5行第2列
        lable_dbback_path = AdenLabel(frame_data_config, text="备份时间:", bg=TkPlugin.background())
        lable_dbback_path.grid(row=4, column=2, sticky=tkinter.E)
        self.txt_dbback_timer = AdenEntry(frame_data_config)
        self.txt_dbback_timer.grid(row=4, column=3, sticky=TkPlugin.sticky_all(), padx="6", pady="6")
        # 第6行第1列
        lable_dbback_path = AdenLabel(frame_data_config, text="备份路径:", bg=TkPlugin.background())
        lable_dbback_path.grid(row=5, column=0, sticky=tkinter.E)
        self.txt_dbback_path = AdenEntry(frame_data_config)
        self.txt_dbback_path.grid(row=5, column=1, sticky=TkPlugin.sticky_all(), padx="6", pady="6")
        # 第6行第2列
        lable_dbback_path = AdenLabel(frame_data_config, text="目标邮件:", bg=TkPlugin.background())
        lable_dbback_path.grid(row=5, column=2, sticky=tkinter.E)
        self.txt_send_mail = AdenEntry(frame_data_config)
        self.txt_send_mail.grid(row=5, column=3, sticky=TkPlugin.sticky_all(), padx="6", pady="6")
        btnbackup = AdenButton(frame_data_config, text="备份", width=8, bg="#FF1493", command=lambda: self.run_backup())
        btnbackup.grid(row=9, column=2, sticky=tkinter.E, columnspan="2", padx="210")
        btnSave = AdenButton(frame_data_config, text="保存", width=8, command=lambda: self.db_config_save())
        btnSave.grid(row=9, column=2, sticky=tkinter.E, columnspan="2", padx="140")
        btnTest = AdenButton(frame_data_config, text="测试链接", bg="#FFA500", width=8,
                             command=lambda: self.db_config_test())
        btnTest.grid(row=9, column=2, sticky=tkinter.E, columnspan="2", padx="70")
        btnDelete = AdenButton(frame_data_config, text="关闭窗体", bg="#D9534F", width=8, command=lambda: self.forget())
        btnDelete.grid(row=9, column=3, sticky=tkinter.E)
        self.initialize_database_config()
        return self.frame
    def initialize_database_config(self):
        dict_result = self.dbAccess.query()
        if dict_result["result"]:
            entity = dict_result["datas"]
            if entity is None:
                self.action_type = "add"
                self.txt_dbback_path.SetValue(BaseConfig().ROOT_PATH + os.sep + "DBBackup")
            else:
                self.action_type = entity.backup_id
                self.com_database_type.set(entity.db_type)
                self.txt_connection_ipaddress.SetValue(entity.db_url)
                self.txt_connection_name.SetValue(entity.db_name)
                self.txt_user_name.SetValue(entity.db_user)
                self.txt_pass_word.SetValue(entity.db_pass)
                self.txt_db_port.SetValue( entity.db_port)
                self.txt_dbback_path.SetValue(entity.backup_path)
                self.txt_dbback_timer.SetValue(entity.backup_cycle)
                self.txt_dbback_number.SetValue(entity.backup_number)
                if entity.backup_auto.lower() == "true":
                    self.ck_check_view.set(1)
                else:
                    self.ck_check_view.set(0)
                self.txt_send_mail.SetValue(entity.target_mail)
        else:
            messagebox.showinfo('提示信息', '数据加载失败' + dict_result["datas"])
    def run_backup(self):
        db_type = self.com_database_type.get()
        server = self.txt_connection_ipaddress.GetValue()
        folder = self.txt_dbback_path.GetValue()
        user = self.txt_user_name.GetValue()
        pwd = self.txt_pass_word.GetValue()
        port= self.txt_db_port.GetValue()
        dbname= self.txt_connection_name.GetValue()
        folder=folder+os.sep+dbname+Tools.get_guid()+".sql"
        str_sql = "mysqldump -h {0} -P {1} -u {2} -p{3} --databases {4} > {5}".format(server, port, user, pwd, dbname,
                                                                                      folder)
        print(str_sql)
        os.system(str_sql)
        messagebox.showinfo('提示信息', '备份成功!!!')
    def db_config_save(self):
        entity = DBBackupEntity()
        entity.db_name = self.txt_connection_name.GetValue()
        entity.db_type = self.com_database_type.get()
        entity.db_user = self.txt_user_name.GetValue()
        entity.db_pass = self.txt_pass_word.GetValue()
        entity.db_url = self.txt_connection_ipaddress.GetValue()
        entity.db_port = self.txt_db_port.GetValue()
        entity.backup_path = self.txt_dbback_path.GetValue()
        entity.create_datetime = Tools.get_current_datetime()
        entity.backup_cycle = self.txt_dbback_timer.GetValue()
        entity.backup_number = self.txt_dbback_number.GetValue()
        if self.ck_check_view.get() == 1:
            entity.backup_auto = "true"
        else:
            entity.backup_auto = "false"
        entity.target_mail = self.txt_send_mail.GetValue()
        if self.action_type=="add":
            entity.backup_id = Tools.get_guid()
            dict_result = self.dbAccess.save(entity)
            if dict_result["result"]:
                messagebox.showinfo('提示信息', '保存成功!!!')
            else:
                messagebox.showinfo('提示信息', '保存失败,错误原因如下:' + dict_result["datas"])
        else:
            entity.backup_id = self.action_type
            dict_result = self.dbAccess.update(entity)
            if dict_result["result"]:
                messagebox.showinfo('提示信息', '保存成功!!!')
            else:
                messagebox.showinfo('提示信息', '保存失败,错误原因如下:' + dict_result["datas"])
        pass
    def db_config_test(self):
        """
        测试数据库链接
        :return:
        """
        db_type = self.com_database_type.get()
        db_conn_ipaddress = self.txt_connection_ipaddress.GetValue()
        db_conn_name = self.txt_connection_name.GetValue()
        db_user_name = self.txt_user_name.GetValue()
        db_pass_word = self.txt_pass_word.GetValue()
        dict_result = self.dbAccess.test_connection(db_type, db_conn_ipaddress, db_conn_name, db_user_name, db_pass_word)
        if dict_result["result"]:
            AdenMessageBox.show('连接成功!!!')
        else:
            AdenMessageBox.show('数据库链接不上,错误原因如下:'+ dict_result["datas"])
        pass
    def forget(self):
        self.note_book.forget(self.frame)

五、其实就是使用Mysql的备份语句备份的数据库

mysqldump -h 127.0.0.1 -P 3306 -u root -p123123 --databases yadinghao > D:\Freedom\DBBack\yadinghaoE72E3A1C-9EB4-11ED-B855-709CD1DEFC28.sql

mysqldump 个命令需要将mysql的bin路径配置到环境变量里,我这里就不说了。网上一大堆......

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1天前
|
存储 缓存 NoSQL
NoSQL缓存数据库的使用场景实例和命令速查表
【5月更文挑战第8天】Redis 是一个内存数据结构服务,用 C 编写,支持五种数据结构,不仅限于键值对。它用于缓存、消息队列、订阅/发布系统等,提供持久化、主从复制和集群支持。了解其核心数据结构和应用场景是有效利用 Redis 的关键。
9 3
NoSQL缓存数据库的使用场景实例和命令速查表
|
2天前
|
机器学习/深度学习 关系型数据库 MySQL
MySQL 到 Greenplum 实时数据同步实操分享,2024年最新【Python面试题
MySQL 到 Greenplum 实时数据同步实操分享,2024年最新【Python面试题
|
2天前
|
Prometheus Cloud Native 关系型数据库
实时计算 Flink版产品使用合集之binlog被清理掉的问题,并且binlog有备份,有什么方法来恢复到RDS
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
20 2
|
4天前
|
Linux Shell Python
python实现Tree命令输出
python实现Tree命令输出
7 0
|
4天前
|
关系型数据库 MySQL Linux
服务器Linux系统配置mysql数据库主从自动备份
这是一个基本的配置主从复制和设置自动备份的指南。具体的配置细节和命令可能因您的环境和需求而有所不同,因此建议在操作前详细阅读MySQL文档和相关资源,并谨慎操作以避免数据丢失或不一致。
16 3
|
4天前
|
Python
【Python进阶(四)】——魔术命令
【Python进阶(四)】——魔术命令
|
4天前
|
关系型数据库 MySQL 数据库连接
用Navicat备份Mysql演示系统数据库的时候出:Too Many Connections
用Navicat备份Mysql演示系统数据库的时候出:Too Many Connections
19 0
|
4天前
|
Linux 数据安全/隐私保护 iOS开发
如何将python命令链接到Python3
如何将python命令链接到Python3
11 0
|
4天前
|
Shell 测试技术 Python
在Mac上用Python调用终端执行命令
在Mac上用Python调用终端执行命令
15 1
|
4天前
|
关系型数据库 MySQL 数据管理
MySQL通过 bin-log 恢复从备份点到灾难点之间数据
MySQL通过 bin-log 恢复从备份点到灾难点之间数据

推荐镜像

更多