Python3 备份 MySQL/MariaDB(本地+FTP)
发表于:2024-09-22 作者:千家信息网编辑
千家信息网最后更新 2024年09月22日,【准备工作】搭建 FTP 服务器:Windows Server 2008 R2 搭建FTP服务如果本机访问报 530 错误:1、检查用户名、密码;2、检查 ftp 目录的用户权限。如果远程主机无法访问
千家信息网最后更新 2024年09月22日Python3 备份 MySQL/MariaDB(本地+FTP)
【准备工作】
搭建 FTP 服务器:Windows Server 2008 R2 搭建FTP服务
如果本机访问报 530 错误:1、检查用户名、密码;2、检查 ftp 目录的用户权限。
如果远程主机无法访问,检查防火墙。
关于 ftp 的端口:控制端口为21;数据端口在主动模式(PORT)下为20,被动模式(PASV)下不定。
开启被动模式:在"FTP 防火墙支持"里面配置端口,然后重启"Microsoft FTP Service"服务。注意具体 ftp 站点的数据框是灰色的,需要在 IIS 总站点配置。
【code】
以下代码对 Windows 下 MariaDB 10.1.18,Ubuntu 下 MySQL 5.7.23 测试可行。
# encoding: utf-8# author: walker# date: 2018-08-02 # summary: Python3 备份 MySQL/MariaDB(本地+FTP),一个库一个文件import osimport timeimport pymysqlimport pprintimport psutilfrom ftplib import FTPDBHost = r'127.0.0.1'DBPort = 3306DBUser = r'root' DBPwd = r'password'# LocalBakRoot = r'/home/walker/sql_bak' # 本地备份目录LocalBakRoot = r'D:\sql_bak' # 本地备份目录LocalIP = ''FtpHost = r'192.168.xx.xx' # FTP 主机FtpBakRoot = r'sql_bak' # FTP 目录FtpUser = r'ftpadmin' FtpPwd = r'password' # 忽略掉系统库IgnoreDB = {'information_schema', 'mysql', 'performance_schema', 'sys'} # 根据前缀获取IPdef GetLocalIPByPrefix(prefix): localIP = '' dic = psutil.net_if_addrs() for adapter in dic: snicList = dic[adapter] for snic in snicList: if not snic.family.name.startswith('AF_INET'): continue ip = snic.address if ip.startswith(prefix): localIP = ip return localIP # 处理一个数据库def ProcOneDB(dbName): print('ProcOneDB %s ...' % dbName) filename = '%s_%s_%s.sql' % (time.strftime('%Y%m%d', time.localtime()), LocalIP, dbName) localFile = os.path.join(LocalBakRoot, filename) #备份数据库,如果没有 -B 参数不会导出数据库创建语句 cmd = 'mysqldump -u%s -p%s -B %s > %s' % (DBUser, DBPwd, dbName, localFile) # print('cmd: %s' % cmd) print('mysqldump ...') rtn = os.system(cmd) if 0 != rtn: print('Error: 0 != rtn') return False ftp = FTP() ftp.encoding = 'gb18030' ftp.set_pasv(False) ftp.connect(FtpHost, port=21, timeout=10) ftp.login(user=FtpUser, passwd=FtpPwd) print(ftp.getwelcome()) ftp.cwd(FtpBakRoot) # 以 sql 服务器 ip 作为子目录名 if LocalIP not in ftp.nlst(): ftp.mkd(LocalIP) # 创建子目录 ftp.cwd(LocalIP) with open(localFile, mode='rb') as f: ftp.storbinary('STOR ' + filename, f) return True # 处理所有数据库def ProcAllDB(): connDB = pymysql.connect(host=DBHost, port=DBPort, user=DBUser, passwd=DBPwd, charset='utf8mb4') cur = connDB.cursor() sql = "show databases;" print('input sql:' + sql) cur.execute(sql) rowList = cur.fetchall() cur.close() connDB.close() dbList = list() for row in rowList: dbList.append(row[0]) print('dbList(%d):\n%s\n' % (len(dbList), pprint.pformat(dbList, indent=4))) for dbName in dbList: if dbName in IgnoreDB: continue print('current time: %s' % time.strftime('%Y-%m-%d %H:%M:%S',time.localtime())) ProcOneDB(dbName) print('current time: %s\n' % time.strftime('%Y-%m-%d %H:%M:%S',time.localtime())) if __name__ == '__main__': LocalIP = GetLocalIPByPrefix('192.168.xx.') ProcAllDB()
【相关阅读】
Python3 统计 ftp 文件个数和大小
ftplib - FTP protocol client
psutil
MySQL/MariaDB Tips
Ubuntu Server 18.04 与 MySQL 5.7
FTP 目录同步:pyftpsync
*** walker ***
数据
目录
备份
数据库
端口
服务
模式
检查
主机
子目
子目录
文件
服务器
用户
站点
防火墙
处理
配置
防火
可行
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
江阴软件开发方法
oracle连不上数据库
电信企业网络安全责任书
光线传输网络技术
民政厅网络安全
服务器的cpu是通过代码计算的
档案信息和网络安全检查
广东常见软件开发价钱
服务器机房标示牌
比特币算力服务器
mc服务器作弊mod
炒币软件开发企业
长春盘古网络技术
民间法律法规数据库最新规定
视频网站如何连接云服务器
添加数据库有相同数据
数据库26个
济南 软件开发十年 工资
西安来实慧网络技术有限公司
黑魂3的 捏脸数据库
web服务器协议
数据库核心基础的对象
传统软件开发最小单元
聊天软件需要买什么服务器
软件开发w亿玛酷1流量订制
企业网络安全文章绪论
杭州苹果软件开发什么价格
广州软件开发和丰软件不错
云顶之弈显示连接不上服务器
hp服务器 固态硬盘