首页 > 数据库 >数据库的备份和恢复

数据库的备份和恢复

时间:2024-07-19 17:30:00浏览次数:11  
标签:opt -- 恢复 备份 sql mysql root 数据库

四、数据库的备份和恢复

4.1备份的目的:

备灾。(防止数据丢失)
在生产环境中,数据的安全性非常重要。
造成数据丢失的原因:
1、程序出错
2、人为的问题
3、磁盘的故障

备份的分类:
物理备份:

对磁盘或者对文件直接进行备份。

**冷备份:**脱机备份,先把指定的程序关闭然后对资料进行备份。(先关闭服务)
**热备份:**联机备份,不用关闭程序就可以对资料进行备份。

逻辑备份:

根据数据库文件当中保存的sql语句,表结构,等等以特定的格式和命令对文件的内容进行还原。(热备份的一种
只能对表,库没了没有办法恢复。

物理备份

1、全量备份:

把数据库的内容整个一次性的做备份。

mysqldmp (自带)

mysgl自带的备份命令。可以备份库,也可以备份库里面的表

热备份(备份一个库)
mysqldump -u root -p --databases xy102 > /opt/xy102.sql
mysql -u root -p  < /opt/xy102.sql   (恢复备份)

热备份(备份多个库)
mysqldump -u root -p --databases xy102 xy103 > /opt/xy_all.sql
mysql -u root -p  < /opt/xy_all.sql   (恢复备份)

数据库全部备份
mysqldump -u root -p --all-databases > /opt/all.sql
scp [email protected]:/opt/all.sql /opt/  (11.144的远程复制到另外一台数据库11.145上)
mysql -u root -p < /opt/all.sql 

备份一个表
[root@myslq2 opt]# mysqldump -u root -p xy102 t1 > /opt/xy102_ti.sql
[root@myslq2 opt]# mysql -u root -p  xy102 < /opt/xy102_ti.sql

备份多个表
[root@myslq2 opt]# mysqldump -u root -p xy102  t1    student  > /opt/xy102_ti.sql
                                         库名  表名    表名  
[root@myslq2 opt]# mysql -u root -p  xy102 < /opt/xy102_ti.sql
                      恢复备份
2、增量备份
[root@myslq2 opt]# vim /etc/my.cnf
general_log=ON  #查询日志默认
general_log_file=/usr/local/mysql/data/mysql_general.log
#查询日志的保存位置
log-error=/usr/local/mysql/data/mysql_error.log
#错误日志的保存位置,错误日志默认开启
slow_query_log=ON
#开启慢查询日志
slow_query_log_file=/usr/local/mysql/data/mysql_slow_query.log
#设置慢查询日志的位置
long_query_time=5
#默认的慢查询时间是10秒,超过5秒就记录
log-bin=mysql-bin  # 开启二进制日志功能
binlog_format=MIXED  #记录二进制日志的文件格式
STATEMENT  基于sql语句:只记录用户操作的sql语句,高并发的情况下,记录操作的sql语句的顺序可能会出错,导致恢复数据时,就会出现丢失或者误差,效率高
ROW 基于行:记录每一行的数据,准确,高并发也不会出错,但是恢复的效率低。
MIXED 混合模式:正常情况下使用,STATEMENT,高并发使用ROW。智能判断。

五、Mysql的日志管理

5.1开启二进制日志的功能:

binlog 逻辑语句,会生成一个文件,这个里面包含了sql语句,要使用特定的方式和语句

mysqlbinlog --no-defaults --base64-output=decode-rows -v mysql-bin.000001

mysqlbinlog --no-defaults /usr/local/mysql/data/mysql-bin.000001 | mysql -u root -p   恢复

[root@myslq2 data]# mysqladmin -u root -p flush-logs       #断点	
5.2根据指定区间恢复数据
mysqlbinlog --no-defaults --start-position ='8224' --stop-position='9011' mysql-bin.00001 | mysql -u root -p
2.3根据指定时间恢复数据
[root@myslq2 data]# mysqlbinlog --no-defaults --start-datetime='时间点' --stop-datetime='结束时间'  mysql-bin.000001 | mysql - u root -p    
mysqlbinlog --no-defaults --start-datetime='2024-7-19 13:48:16' --stop-datetime='2024-7-19 13:52:25' mysql-bin00001 | mysql -u root -p

标签:opt,--,恢复,备份,sql,mysql,root,数据库
From: https://blog.csdn.net/qq_52448810/article/details/140555597

相关文章

  • 使用Java和JPA构建健壮的数据库应用
    使用Java和JPA构建健壮的数据库应用大家好,我是微赚淘客系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿!今天,我们将探讨如何使用Java和JPA(JavaPersistenceAPI)来构建健壮的数据库应用。JPA是JavaEE规范的一部分,用于对象关系映射(ORM),简化了数据库操作和数据管理。1.JPA基础......
  • java比较mysql两个数据库中差异
    java对比两个库之间差异packagecom.ruoyi.shht;importjava.io.File;importjava.io.FileOutputStream;importjava.io.OutputStream;importjava.sql.Connection;importjava.sql.DriverManager;importjava.sql.ResultSet;importjava.sql.Statement;importjava.tex......
  • PG夜话(第20期):数据库老陈、德哥、快立方华总,聊一聊数据库内存管理
     PostgreSQLPG夜话(第20期):数据库老陈、德哥、快立方华总,聊一聊数据库内存管理(PG夜话,CUUG陈卫星,与数据库大伽一起聊PG数据库相关的话题) 老陈:“数据库内存管理是永远不变的话题,本期分享pg&oracle内存管理...”德哥:“DuckDB&PG的内存管理” 时间:07月20日19:30直播地址:......
  • idea内置数据库DataGrip + 多表操作sql语句
    多表操作:一对多(多对一),一对一,一对多可以通过物理外键实现,但实际上更推荐使用逻辑外键以下均为物理外键使用方法--=====================================多表设计================================---------------------一对多职位与员工--员工子表createta......
  • 打破僵局:深度解析数据库死锁的策略与实践(专家篇)
    在多任务操作系统和数据库管理系统中,死锁是一个常见问题,它发生在两个或多个进程/线程因争夺资源而相互等待,导致系统资源无法继续执行。有效地检测和预防死锁对于确保系统稳定性和提高系统性能至关重要。本次探讨不同的死锁检测与预防策略,以及如何在实际应用中实现这些策略......
  • Jmter(十六)jmter连接数据库
    Jmter连接数据库下载对应的驱动包mysql-connector-java-5.1.13-bin.jar点击测试计划,点击浏览,添加即可(不需要解压,目录最好是lib的ext)在线程组中,右键添加-->配置元件--->“JDBCConnectionConfiguration”,具体配置如下图1)VaribleName:这个是变量的名字,也就是说不能重复,2)J......
  • [MAUI 项目实战] 笔记App(二):数据库设计
    @目录Sqlite配置创建实体笔记实体类笔记分组实体笔记片段实体笔记片段负载实体笔记片段仓库实体笔记模板(场景)实体笔记片段模板实体笔记片段模板负载实体配置EF创建映射迁移和种子数据项目地址Sqlite配置应用程序里使用Sqlite作为数据库,使用EntityFramworkCore作为ORM,使用CodeFir......
  • 向量数据库的检索服务
    最近应该是开始了向量数据库热门,阿里云和腾讯云都推出了相应的服务,阿里云现阶段可以免费的试用。 说说为啥热门起来了,主要是由于向量以及大模型的特殊性。向量是有指向的,最直观的就是二维向量,简单的表示就是一个箭头。通过不同的大模型的embedding服务,我们可以对音视频,......
  • 20240718 数据库外键报错
    报错1. 1452-Cannotaddorupdateachildrow:aforeignkeyconstraintfails(bvn'.'user_user_role^,CONSTRAINT^user_user_role_user_id_e615b4e0_fk_user_user_idFOREIGNKEY(user_id’)REFERENCES^user_user(id'))翻译:不能添加或更新子行:外键约束失败(bvn&#......
  • mysql数据库常用命令(补充)
    1、查看表的所有内容select*from表名;2、查看指定内容selectname,agefromtest;select表示查询,name表示名字,age表示年龄,from是从的意思,test是表名。翻译过来就是:从test表中查询名字和年龄字段的内容。在select后面指定要查询的项,可以是一项也可以多项。在select后面添......