# MySql数据库的备份与恢复
>[success]项目上线后,难免会遇到一些灾难年性的数据丢失,所以如何做好数据库备份,把损失降到最低是重中之重。
## 数据库的备份方式
>[success]数据库的备份方式有很多种,包括全量备份和增量备份等。在这里要介绍的是全量备份和二进制日志。
### 1. 全量备份
即按照指定时间对数据库完全备份,但是这种备份方式占用磁盘空间,并且时效性差,对于突发时件,较难处理。
在linux服务器下,全量完全备份可以采用脚本加定时任务的方式:
~~~
//备份脚本
/usr/local/mysql/bin/mysqldump [数据库] >sql.sql
~~~
>[danger]完全备份可以加入定时任务,每天备份,并且服务器上保留近30天的备份数据
### 2. 二进制日志
>[success]这种方式是咱们这里要介绍的注点,因为他可以帮助咱们进行数据库数据的实时回滚。如果再配合完全备份,可以这处理一些灾难性的数据丢失。
运用场景:如一项目数据更新频繁,如果数据库目前采用全量备份方式(每天凌晨3点备份),但是如果在某天下午,突然误删或者误修改了某些记录。那么这里,就很难处理了。如果操作记录少的话,可能还可以手工恢复,如果量大的话就麻烦了。
>[danger]像这种情况,就可以借助于`二进制日志`进行恢复,但是要配合全量备份。
#### MySQL中的日志
>[warning] MySQL中有六种日志文件,分别是:
> 重做日志(redo log)
> 回滚日志(undo log)
> 二进制日志(binlog)
> 错误日志(errorlog)
> 慢查询日志(slow query log)
> 一般查询日志(general log)
> 中继日志(relay log)`。
>其中重做日志和回滚日志与事务操作息息相关,二进制日志也与事务操作有一定的关系,这三种日志,对理解MySQL中的事务操作有着重要的意义。
#### 二进制日志(binlog)的特点
>[danger]它记录了某时间段内所有的`增删改`的操作。如果需要恢复某段时间的数据,只需要重新执行一遍对应的SQL即可。
- 前言
- PHP获取服务器信息
- PHP中的常用函数-新手必备知识
- 日期时间相关的函数
- 时区设置
- time函数
- strtotime 时间戳
- date函数
- mktime函数
- 联合使用 date() 和 mktime()
- PHP数据类型相关的函数
- PHP数组相关的函数
- array函数
- 数组的排序
- sort()和rsort()函数
- asort()和arsort()函数
- ksort()和krsort()函数
- array_multisort()函数
- array_reverse函数
- 数组的遍历
- 数组中新增和删除元素
- 数组头部插入和删除元素
- 数组尾部插入和删除元素
- 删除数组中重复的元素
- 删除数组中指定的元素
- 数组的合并
- 随机/打乱已知数组
- range函数
- 数组去除重复
- PHP常用功能函数
- URL地址处理函数
- post/get请求
- PHP字符串相关的函数
- PHP文件系统
- PHP正则表达式
- 正则表达式语法规则
- POSIX扩展的正则表达式函数
- 查找字串函数
- 替换字符串函数
- Perl兼容的正则表达式函数
- PHP中类的应用
- 中文编码
- 关于stdClass
- 变量相关函数
- unset
- PHP数值相关的函数
- 数值取整
- 开发工具与开发环境使用技巧
- sublime
- 常用插件
- Atom
- 常用插件
- 常见问题
- Visual Studio Code
- vscode常用插件
- 编程推荐字体
- MAC下开发常识
- MAC下的常用设置
- MAC下的常用开发工具
- MAC下XAMMP的常见问题
- Apache配置基础
- PhpStrom
- php中的常见问题
- 文件上传相关问题
- API接口中常见问题
- 关于缓冲区问题
- PHP中注意事项
- 条件判断
- PHP文件管理模块
- 文件管理源码
- 文件管理的常用函数
- 文件管理中文乱码处理
- 自定义功能函数
- 文件下载
- PHP常用头信息定义汇总
- 常见PHP网页木马
- 加密算法
- 1. Base58可逆加密
- 2. AES加密/解密
- mysql数据库操作
- 命令行操作Mysql常用令行-查询
- 命令行操作Mysql常用令行-操作
- Mysql使用中的技巧
- 在线数据库管理中常用命令
- sql show命令
- mysql数据库的备份与恢复
- 二进制日志介绍
- 二进制日志常用命令
- ThinkPHP
- 数据迁移
- 常见问题
- 验证码问题
- API接口中的异常处理
- API接口安全
- 解决跨域问题
- 自定义实用功能函数