设为首页 收藏本站
查看: 1219|回复: 0

[经验分享] mysql 数据恢复之语法报错

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2018-10-9 09:27:03 | 显示全部楼层 |阅读模式
  由于备份时语法错误指定的目录不存在,但在备份的时候又没报错,所以工程师以为备份成功了,最终酿成大祸;(成为黑锅侠)
  一、错误备份演示
  语法出错,备份失效看似备份成功,但查看备份内容时,出现语法错误的警告
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


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-619412-1-1.html 上篇帖子: Linux命令:MySQL系列之十--MySQL用户和权限管理,mysql管理员密码重置 下篇帖子: centos7配置mysql的主从复制
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表