Python3 备份 MySQL/MariaDB(本地+FTP)
发表于:2024-11-22 作者:千家信息网编辑
千家信息网最后更新 2024年11月22日,【准备工作】搭建 FTP 服务器:Windows Server 2008 R2 搭建FTP服务如果本机访问报 530 错误:1、检查用户名、密码;2、检查 ftp 目录的用户权限。如果远程主机无法访问
千家信息网最后更新 2024年11月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安全错误
数据库的锁怎样保障安全
护苗网络安全课mp4
合肥国产化服务器订购
上海公安局宣传网络安全
网络安全ips前三厂商
高校网络安全事件
用友Ip地址登录服务器
葫芦岛服务器安全吗
老头网络安全表情
网络安全法是宪法吗
魔兽世界178 数据库
成都网络安全平台作业
高中网络技术第四章
软件开发合作风险
太平保险公司软件开发怎么样
大话西游2服务器怎么选择
软件开发生命周期+文档
茂名软件开发的费用
软件开发研发文档
明日之后莱文市的服务器
国内知名网络安全上市公司
重庆邮电大学网络安全研究生
网络技术能当警察吗
广东移动服务器云主机
天融信edr服务器如
检查数据库连接数
东南大学网络安全录取名单
深圳市南方网通网络技术
武汉钢铁仓储软件开发
部队网络安全演讲稿200字
加强网络安全宣传教育