Python3 备份 MySQL/MariaDB(本地+FTP)
发表于:2025-02-23 作者:千家信息网编辑
千家信息网最后更新 2025年02月23日,【准备工作】搭建 FTP 服务器:Windows Server 2008 R2 搭建FTP服务如果本机访问报 530 错误:1、检查用户名、密码;2、检查 ftp 目录的用户权限。如果远程主机无法访问
千家信息网最后更新 2025年02月23日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安全错误
数据库的锁怎样保障安全
数据库帐号加密
软件开发阶段采用什么策略
三道杠服务器视频教学
三峡移民网络安全
海康威视服务器显示系统恢复选项
对网络安全的重要性
hmcl离线服务器地址
计算机网络技术编程的应用
数据库与信息系统ppt
西藏加油卡 网络安全
hr逻辑数据库
总是dns服务器为响应
苹果只删除一个游戏的数据库
韩国ibm服务器租用
春考网络技术技能考试真题
网络安全广告图片
数据库 二维表
access保护数据库
c语言数据库接口
杭州亿岛互联网科技有限公司
vue初始化数据库
u8数据库安装前我们先要干什么
数据库备份难吗
提高网络安全防范宣传活动
软件开发需要监理吗
如何获取dns服务器
杰奇小说数据库优化
数据库怎么创建
聊天女仆为什么服务器超时
元神5开头是什么服务器