mysqldump: Got error: 1449 及[Warning] IP address could not be resolved

       想换一个版本的mysql,把原有数据库里面的数据备份。

        mysqldump -uxxx -pxxx -A>mysql0106.bak

       mysqldump: Got error: 1449: The user specified as a definer (‘wj’@'%’) does not exist when using LOCK TABLES

       但却报mysqldump: Got error: 1449错误,而且出现的用户名wj,数据库中并不存在。很多人通过给这个莫名的用户赋予权限从而能够成功导出数据。

        于是:grant all on *.* to 'wj'@'%';

        果然数据能够成功导出。将导出文件再次导入数据库,并删除wj用户,数据又不能正常导出。

        查看,导出文件中,有这样一行

       /*!50013 DEFINER=`wj`@`%` SQL SECURITY DEFINER */

       将wj用root或其它有相应权限的用户代替,将导出文件再次导入数据库,并删除wj用户,数据能正常导出。

       为什么会这样,以及为什么会涉及到wj用户产生,可能和导出数据的设置有关。

 

        查看错误日志,发现很多[Warning] IP address could not be resolved

        根本原因是

         主控服务器的网卡属性的DNS不好,或都受控域名的DNS无法解析。

         修改/etc/resolv.conf中对应的ip和DNS配置或是修改my.cnf

         [mysqld]

        skip-name-resolve

        skip-host-cache

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值