一、数据库备份

1.命令简介:

# mysqldump -h 服务器 -u用户名 -p密码 数据库名 > 备份文件.sql
1)关于数据库名:
  -A, --all-databases         所有库
  school               数据库名
  school stu_info t1 school  数据库的表stu_info、t1
  -B, --databases bbs test mysql 多个数据库
2)关于其它参数说明:
  --single-transaction         #InnoDB 一致性 服务可用性
  -x, --lock-all-tables          #MyISAM 一致性 服务可用性
  -E, --events                    #备份事件调度器代码
  --opt                               #同时启动各种高级选项
  -R, --routines                 #备份存储过程和存储函数
  -F, --flush-logs               #备份之前刷新日志
  --triggers                       #备份触发器
  --master-data=1|2        #该选项将会记录binlog的日志位置与文件名并追加到文件中

2、操作过程:

1)创建库表:

mysql> create database school;
Query OK, 1 row affected (0.01 sec)
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| school |
| sys |
+--------------------+
5 rows in set (0.00 sec) mysql> use school;
Database changed mysql> select * from school.t1;
Empty set (0.00 sec)

mysql> create table t2 (id int);
Query OK, 0 rows affected (0.02 sec)

mysql> insert into t1 values (1),(2);
Query OK, 2 rows affected (0.03 sec)
Records: 2 Duplicates: 0 Warnings: 0 mysql> select * from t1;
+------+
| id |
+------+
| 1 |
| 2 |
+------+
2 rows in set (0.00 sec) mysql>

2)逻辑备份:

[root@localhost ~]# mysqldump -uroot -p'Yanglt123.' --all-databases \
> --single-transaction \
> --routines \
> --triggers \
> --master-data= \
> --flush-logs > /tmp/`date +%F`-mysql-all.sql` mysqldump: [Warning] Using a password on the command line interface can be insecure. #此提示是密码明文显示的愿意
[root@localhost tmp]#

注意事项:

--master-data=    #该选项将会记录binlog的日志位置与文件名并追加到文件中
参数为1和2的时候,都是把position日志截断,如果为2的话第22行为注释状态,为1的时候没有注释,建议选择1: [root@localhost tmp]# vim ---mysql-all.sql 可以
-- Position to start replication or point-in-time recovery from
-- CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000003', MASTER_LOG_POS=; --
:set nu

二、数据库恢复

1. 停止数据库   【systemtl stop mysqld 】
2. 清理环境      【rm -rf /var/lib/mysql/*;】
3. 启动数据库     【初始密码 /var/log/mysqld.log】
4. 重置密码      【新密码 】
5. mysql恢复数据  【新密码 】
6. 刷新授权      【备份时密码 】

注:如果不是一个新的数据库环境,我们需要从第一步开始,如果已经是一个新的数据环境,我们可以直接从第5步执行。

先创建一个表,等一下验证恢复情况:
mysql> create table t2 (id int);
Query OK, rows affected (0.02 sec) mysql> insert into t2 values(),()
-> ;
Query OK, rows affected (0.03 sec)
Records: Duplicates: Warnings: mysql> show tables;
+------------------+
| Tables_in_school |
+------------------+
| t1 |
| t2 |
+------------------+
rows in set (0.00 sec) mysql> Bye
[root@localhost ~]# )停止数据库
[root@localhost ~]# systemctl stop mysqld
[root@localhost ~]#
)清理环境
此处暂时不删除bin-log日志
[root@localhost ~]# systemctl stop mysqld
[root@localhost ~]# rm -rf /var/lib/mysql/*
3)启动数据库
[root@localhost ~]# systemctl start mysqld
4)重置密码
[root@localhost ~]# grep 'temporary password' /var/log/mysqld.log|tail -n 1
2018-09-19T09:48:39.418109Z 1 [Note] A temporary password is generated for root@localhost: aBm<-wrj4NSV
[root@localhost ~]# mysqladmin -uroot -p'aBm<-wrj4NSV' password "Yanglt123."
mysqladmin: [Warning] Using a password on the command line interface can be insecure.
Warning: Since password will be sent to server in plain text, use ssl connection to ensure password safety.
[root@localhost ~]# systemctl restart mysqld
[root@localhost ~]#
5)恢复数据
[root@localhost ~]# mysql -uroot -p'Yanglt123.' < /tmp/2018-09-19-mysql-all.sql
mysql: [Warning] Using a password on the command line interface can be insecure.
[root@localhost ~]#
可以看到它恢复到了备份点,刚才创建的表t2是在备份点之后生成的,可以看到表中没有t2:
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| school |
| sys |
+--------------------+
5 rows in set (0.01 sec) mysql> use school;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A Database changed
mysql> show tables;
+------------------+
| Tables_in_school |
+------------------+
| t1 |
+------------------+
1 row in set (0.00 sec) mysql>
6) 刷新授权
改完密码后与备份点的密码可能不一致,所有我们要执行此步骤,来实现与备份点密码一致。
[root@localhost ~]# mysql -p'Yanglt123.' -e 'flush privileges'
mysql: [Warning] Using a password on the command line interface can be insecure.
[root@localhost ~]# 7)建议在逻辑备份恢复时,暂停BINLOG
mysql> SET SQL_LOG_BIN=0;
Query OK, 0 rows affected (0.02 sec)
mysql> source /tmp/2018-09-19-mysql-all.sql;

三、

最新文章

  1. Linux下的C Socket编程 -- server端的继续研究
  2. xml文件解析(解析以后在RootTableViewController输出)
  3. 10款html5开发工具,实用+好用
  4. mysql 行变列(多行变成一行/多行合并成一行/多行合并成多列/合并行)
  5. Unity手游之路&lt;一&gt;C#版本Protobuf
  6. 构造函数模式自己定义js对象
  7. jsonp的简单例子
  8. hdu 3804 树链剖分
  9. _cpluscplus
  10. Windows2012中安装Nginx并创建为Windows服务
  11. 利用google浏览器开发者工具调试网页(详)
  12. 简单运用 activity 的 button 点击事件
  13. Servlet的学习笔记
  14. Openjudge-计算概论(A)-判断闰年
  15. vc类型转换函数大全
  16. 10.1牛客J题
  17. ubuntu linux下建立stm32开发环境: 程序烧录 openocd+openjtag
  18. HDU - 6394 Tree(树分块+倍增)
  19. 编写支持SSR的通用组件指南
  20. mysql5.7如何修改密码以及密码如何忘记无密码登陆

热门文章

  1. 【星云测试】开发者测试(2)-采用精准测试工具对J2EE Guns开发框架进行测试
  2. js怎样得出数组中某个数据最大连续出现的次数
  3. BZOJ 2654: tree(二分 最小生成树)
  4. vs code 写C心得
  5. PCB布线设计(1)
  6. 阿里云ubantu16.04 搭建LAMP环境
  7. PLL各种问题,关于倍频
  8. 与Linux的第一次遭遇
  9. 20155321 2016-2017-2 《Java程序设计》第二周学习总结
  10. Centos安装man功能