|
由于备份时语法错误 或 指定的目录不存在,但在备份的时候又没报错,所以工程师以为备份成功了,最终酿成大祸;(成为黑锅侠)
一、错误备份演示
语法出错,备份失效看似备份成功,但查看备份内容时,出现语法错误的警告
1234567891011
[root@db02 ~]# mysqldump -uroot -poldboy123 -A -B oldboy >/opt/oldboy_bak1.sql
[root@db02 ~]# cat /opt/oldboy_bak1.sqlUsage: mysqldump [OPTIONS] database [tables]OR mysqldump [OPTIONS] --databases [OPTIONS] DB1 [DB2 DB3...]OR mysqldump [OPTIONS] --all-databases [OPTIONS]For more options, use mysqldump --help 提示:
1,错误点就是 -A 与-B 不能同时使用,会产生语法错误,看下面解释就明白了,指定的范围有冲突 -A:--all databases 所有数据库备份
-B:指定多个数据库备份
mysql 不能使用kill -9 否则后果自负;
补充强调:我们平时发帖子,都是通过web服务器连接mysql,之后通过insert语句把数据存入数据库
-A全备会出现events—warning,下面是 处理方法:
1234
这是因为mysqldump默认是不备份事件表的,只有加了--events 才会,解决办法:
加上--events 或 --ignore-table=mysql.events 参数即可;
#导出事件 #忽略某个表的意思,可以man mysqldump查看
mysqldump -uroot -poldboy123 -S /data/3307/mysql.sock --events -A >all.sql
如何拒绝成为黑锅侠:胆大心细,善于总结,吸取经验,脱离黑锅;
二,正确备份演示
定期做备份恢复演练 或恢复测试
1,在test数据库中创建student表
12345678mysql> use test; ##进入test库create table student(id int(4) not null,name char(20) not null,age tinyint(2) NOT NULL default '0',dept varchar(16) default NULL);##创建student表 里面是各个字段的设置 2,备份数据库test
12mysqldump -uroot -poldboy123 -S /data/3307/mysql.sock -B test >/opt/test.sqlcat /opt/test.sql #检测备份是否有效 3,删除test库(模拟真实环境)
1234567891011mysql> drop database test;Query OK, 0 rows affected (0.00 sec)mysql> show databases; #没有test数据了+--------------------+| Database |+--------------------+| information_schema || mysql || oldboy || performance_schema | +--------------------
4,恢复test库
1234567891011121314151617181920212223[root@db02 ~]# mysql -uroot -poldboy123 -S /data/3307/mysql.sock show databases; #恢复test库,因为之前使用-B备份的,所以现在不用指定库,直接恢复mysql> show databases;+--------------------+| Database |+--------------------+| information_schema || mysql || oldboy || performance_schema || test |+--------------------+5 rows in set (0.00 sec)mysql> desc student;+-------+-------------+------+-----+---------+-------+| Field | Type | Null | Key | Default | Extra |+-------+-------------+------+-----+---------+-------+| id | int(4) | NO | | NULL | || name | char(20) | NO | | NULL | || age | tinyint(2) | NO | | 0 | || dept | varchar(16) | YES | | NULL | |+-------+-------------+------+-----+---------+-------+4 rows in set (0.00 sec) 到此,模拟数据恢复成功。
mysql 常见报错代码链接:
http://oldboy.blog.51cto.com/2561410/1728380
|
|
|