您现在的位置是:首页 > cms教程 > shopxo教程shopxo教程
shopxo怎么实现mysql备份
卫耿羿2025-07-28shopxo教程已有人查阅
导读完全备份full backup:备份全部字符集增量备份incremental backup:上次完全备份或增量备份以来改变的数据,不能单独使用,要借助于完全备份,备份的频率取决于数据的更新频率
1.为什么要进行mysql的备份?
(1)灾难恢复
(2)测试
(3)数据还原
2.备份的注意事项
(1)恢复数据所需要的时间
(2)恢复过程中是否需要停止数据库
(3)恢复的对象(库,表,多库,多表)
(4)可以容忍丢失多久的数据
3.备份的类型
(1)根据是否需要停止数据库分为:
冷备cold backup:需要关闭mysql服务,读写请求均不允许进行
温备warm backup:服务在线,但仅支持读请求,不允许写请求
热备hot backup:备份的同时,业务不受影响
注:
这种类型的备份,取决于业务的需求,而不是备份工具
MyISAM不支持热备;InnoDB支持热备,但需要专门的工具
(2)根据备份的数据 的范围分为:
完全备份full backup:备份全部字符集
增量备份incremental backup:上次完全备份或增量备份以来改变的数据,不能单独使用,要借助于完全备份,备份的频率取决于数据的更新频率
差异备份differential backup:上次完全备份以来改变了的数据
两种策略:
完全+增量+二进制日志
完全+差异+二进制日志
(3)根据备份数据或文件
物理备份:直接备份数据文件
优点:
备份和恢复操作都比较简单,可跨mysql版本;恢复速度快
建议:
不要假设备份一定可用,要进行测试
mysql> check table table_name;#测试表是否可用
逻辑备份:备份表中的数据和代码
优点:恢复很简单、备份的结果为ASCII文件,可用直接编辑
与存储引擎无关、可用通过网络备份和恢复
缺点:
备份或恢复都需要mysql服务器进程参与
备份结果占据更多的空间
浮点数可用会丢失精度
还原之后,索引需要重建
4.备份的对象
数据;配置文件;代码(存储过程,存储函数,触发器);
os相关的配置文件;复制相关的配置;二进制日志
5.备份和恢复的实现
(1)利用select into outfile实现数据的备份和还原
mysqldump常用来做<温备>,所以我们首先需要对想备份的数据施加读锁
施加读锁的方式:
(1)直接在备份的时候添加选项
--lock-all-tables #对备份的数据库的所有表施加读锁
--lock-table#仅对单张表施加读锁,即使是备份整个数据库(备份某张表时才使用)
(2)服务器端
增量备份
(1)灾难恢复
(2)测试
(3)数据还原
2.备份的注意事项
(1)恢复数据所需要的时间
(2)恢复过程中是否需要停止数据库
(3)恢复的对象(库,表,多库,多表)
(4)可以容忍丢失多久的数据
3.备份的类型
(1)根据是否需要停止数据库分为:
冷备cold backup:需要关闭mysql服务,读写请求均不允许进行
温备warm backup:服务在线,但仅支持读请求,不允许写请求
热备hot backup:备份的同时,业务不受影响
注:
这种类型的备份,取决于业务的需求,而不是备份工具
MyISAM不支持热备;InnoDB支持热备,但需要专门的工具
(2)根据备份的数据 的范围分为:
完全备份full backup:备份全部字符集
增量备份incremental backup:上次完全备份或增量备份以来改变的数据,不能单独使用,要借助于完全备份,备份的频率取决于数据的更新频率
差异备份differential backup:上次完全备份以来改变了的数据
两种策略:
完全+增量+二进制日志
完全+差异+二进制日志
(3)根据备份数据或文件
物理备份:直接备份数据文件
优点:
备份和恢复操作都比较简单,可跨mysql版本;恢复速度快
建议:
不要假设备份一定可用,要进行测试
mysql> check table table_name;#测试表是否可用
逻辑备份:备份表中的数据和代码
优点:恢复很简单、备份的结果为ASCII文件,可用直接编辑
与存储引擎无关、可用通过网络备份和恢复
缺点:
备份或恢复都需要mysql服务器进程参与
备份结果占据更多的空间
浮点数可用会丢失精度
还原之后,索引需要重建
4.备份的对象
数据;配置文件;代码(存储过程,存储函数,触发器);
os相关的配置文件;复制相关的配置;二进制日志
5.备份和恢复的实现
(1)利用select into outfile实现数据的备份和还原
#把需要备份的数据备份出来
mysql> use shopxo;#打开shopxo库
mysql> select * from s_app_home_nav into outfile '/data/mysql/app.txt';
#删除s_app_home_nav表
#使用load data infile恢复
mysql> drop table s_app_home_nav;
Query OK, 0 rows affected (0.37 sec)
#新建s_app_home_nav表
CREATE TABLE `s_app_home_nav` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增id',
`platform` char(30) NOT NULL DEFAULT 'pc' COMMENT '所属平台(pc PC网站, h5 H5手机网站, app 手机APP, alipay 支付宝小程序, weixin 微信小程序, baidu 百度小程序)',
`event_type` tinyint(2) NOT NULL DEFAULT '-1' COMMENT '事件类型(0 WEB页面, 1 内部页面(小程序或APP内部地址), 2 外部小程序(同一个主体下的小程序appid), 3 打开地图, 4 拨打电话)',
`event_value` char(255) NOT NULL DEFAULT '' COMMENT '事件值',
`images_url` char(255) NOT NULL DEFAULT '' COMMENT '图片地址',
`name` char(60) NOT NULL DEFAULT '' COMMENT '别名',
`is_enable` tinyint(1) unsigned NOT NULL DEFAULT '1' COMMENT '是否启用(0否,1是)',
`is_need_login` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否需要登录(0否,1是)',
`bg_color` char(30) NOT NULL DEFAULT '' COMMENT 'css背景色值',
`sort` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '排序',
`add_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '添加时间',
`upd_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',
PRIMARY KEY (`id`),
KEY `platform` (`platform`),
KEY `is_enable` (`is_enable`),
KEY `sort` (`sort`)
) ENGINE=InnoDB AUTO_INCREMENT=25 DEFAULT CHARSET=utf8mb4 ROW_FORMAT=DYNAMIC COMMENT='手机 - 首页导航';
mysql> load data infile '/data/mysql/app' into table s_app_home_nav;
Query OK, 24 rows affected (0.16 sec)
Records: 24Deleted: 0Skipped: 0Warnings: 0
(2)利用mysqldump工具对数据进行备份和还原mysqldump常用来做<温备>,所以我们首先需要对想备份的数据施加读锁
施加读锁的方式:
(1)直接在备份的时候添加选项
--lock-all-tables #对备份的数据库的所有表施加读锁
--lock-table#仅对单张表施加读锁,即使是备份整个数据库(备份某张表时才使用)
(2)服务器端
mysql> flush tables with read lock; #施加读锁,表示把位于内存上的表统统都同步到磁盘上去,然后施加读锁
mysql> flush tables with read lock;
#释放读锁
#但这对于InnoDB存储引擎来讲,虽然你也能够请求到读锁,但是不代表它的所有数据都已经同步到磁盘上,
#因此当面对InnoDB的时候,我们要使用
mysql> show engine innodb status;
#看看InnoDB所有的数据都已经同步到磁盘上去了,才进行备份操作
#备份策略:完全+增量+二进制日志
例子:
#先给数据库做完全备份
[root@lfs ~]# mysqldump -uroot -p --single-transaction --master-data=2 --databases shopxo > /data/mysql/shopxo_`date +%F`.sql
#--single-transaction 此选项能实现热备innodb表,因此不需要同时使用--lock-all-tables
#--master-data=2 记录备份那一时刻的二进制日志的位置,并且注释掉,1为不注释
#--database 指定备份的数据库
#回到mysql服务器端更新数据
mysql> use shopxo;
mysql> create table tb1(id int);
#创建表
mysql> insert into tb1 values(1),(2);
#插入数据
#查看完全备份里的二进制日志位置
[root@lfs ~]# cat /data/mysql/shopxo_2020-08-25.sql |grep mysql-bin
-- CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000026', MASTER_LOG_POS=214;
#查看此时的二进制日志位置,从备份文件里边记录的位置到此位置,即为增量的部分
mysql> show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000026 |494 |||
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)增量备份
[root@lfs ~]# mysqlbinlog --start-position=214 --stop-position=494 /usr/local/mysql/data/mysql-bin.000026 > /data/mysql/shopxo_bin.sql
回到mysql
#插入一些记录
mysql> insert into tb1 values (4),(5);
#删除shopxo库
mysql> drop database shopxo;
导出这次的二进制日志
#查看删除操作时二进制日志的位置
[root@lfs ~]# mysqlbinlog --start-position=494 /usr/local/mysql/data/mysql-bin.000026
# at 564
#2008253:32:17 server id 1end_log_pos 659 Querythread_id=4exec_time=0error_code=0
use `shopxo`/*!*/;
SET TIMESTAMP=1598297537/*!*/;
insert into tb1 values (4),(5)
/*!*/;
# at 659
#2008253:32:17 server id 1end_log_pos 686 Xid = 625
COMMIT/*!*/;
#导出二进制日志
[root@lfs ~]# mysqlbinlog --start-position=494 --stop-position=686 /usr/local/mysql/data/mysql-bin.000026 >/data/mysql/shopxo_02.sql
先让mysql离线
#关闭二进制日志
mysql> set sql_log_bin=0;
#滚动下日志
mysql> flush logs;
恢复数据
#导入完全备份文件
[root@lfs ~]# mysql -uroot -p < /data/mysql/shopxo_2020-08-25.sql
#导入增量备份文件
[root@lfs ~]# mysql -uroot -p < /data/mysql/shopxo_bin.sql
#导入二进制日志文件
[root@lfs ~]# mysql -uroot -p < /data/mysql/shopxo_02.sql
#验证:
mysql> use shopxo;
Database changed
mysql> select * from tb1;
+------+
| id |
+------+
|1 |
|2 |
|4 |
|5 |
+------+
4 rows in set (0.00 sec)
本文标签:
很赞哦! ()
相关教程
图文教程
URLOS部署安装shopxo的方法
本方法可以一键安装ShopXO,并且自动申请域名SSL证书。ShopXO一键安装可自动创建网站运行环境,自动申请和续签SSL证书。
shopxo支付宝支付申请步骤流程
进入支付应用创建网页应用点击 创建网页应用,或者点击已经创建好的应用进去设置公钥(再获取支付宝公钥)用于接口签名使用,第一次操作可能需要短信验证码
shopxo是免费开源的吗?可以商用吗?
ShopXO企业级免费开源电商系统!求实进取、创新专注、自主研发、企业级电商系统解决方案。遵循MIT开源协议发布,无需授权、可商用、可二次开发、满足99%的电商运营需求。
shopxo头条小程序注册方法
访问开发者平台,在右上角点击「注册」登录开发者平台登录成功后,在首页或前往「账号中心」认证企业身份,填写主体资质信息并通过平台审核。
相关源码
-
(自适应)响应式文章博客互联网新闻pbootcms模板下载本模板基于PbootCMS开发,专为科技新闻、互联网资讯和文章博客类网站设计。采用响应式布局技术,确保在电脑、平板和手机上都能获得最佳浏览体验。适用于科技媒体、行业博客查看源码 -
(PC+WAP)餐饮奶茶美食小吃招商加盟pbootcms模板源码下载为茶饮烘焙、小吃快餐等餐饮品牌打造的招商加盟系统,助力品牌快速拓展市场;双端pc+wap设计呈现加盟政策对比表。支持后台实时更新菜品图片、加盟费用等关键信息。查看源码 -
(自适应响应式)陶瓷研磨盘抛光机械设备pbootcms网站模板本模板基于PbootCMS系统开发,为研磨抛光设备制造企业设计,特别适合陶瓷研磨盘、抛光设备等表面处理设备展示。采用响应式布局技术,确保各类设备的参数和工艺在不同终端上都能清晰呈现。查看源码 -
(自适应)帝国CMS7.5模板淘宝客导购博客文章源码本模板基于帝国CMS7.5内核深度开发,为电商导购类网站设计。采用响应式布局技术,确保在手机、平板及电脑端均能获得优质浏览体验。模板内置商品推荐模块与优惠信息展示区,可快速搭建专业导购平台。查看源码 -
(自适应)帝国cms7.5模板自媒体文章新闻博客为帝国CMS7.5设计的响应式模板,采用H5技术构建现代化内容展示框架。通过智能断点检测技术实现手机、平板、PC三端适配查看源码 -
(响应式)企业管理人力资源服务类pbootcms模板源码下载为人力资源服务及企业管理设计的响应式网站模板,基于PbootCMS内核开发。通过宽屏布局优化岗位展示效果,简洁界面聚焦人才服务核心业务,自适应技术确保在PC端与手机端查看源码
| 分享笔记 (共有 篇笔记) |
