• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

[MySQL FAQ]系列 — 启用GTID & binlog新安装完的MySQL提示无法

mysql 搞代码 4年前 (2022-01-09) 74次浏览 已收录 0个评论

问:刚刚新安装的MySQL,提示下面信息,无法登入,怎么回事? [root@imysql mysql]# mysql mysqlERROR 1045 (28000): Access denied for user ‘root’@’localhost’ (using password: NO) 答:数据库已经执行过 mysql_install_db 初始化了,按理说应该没问题。

问:刚刚新安装的MySQL,提示下面信息,无法登入,怎么回事?

[root@imysql mysql]# mysql mysqlERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO)

答:数据库已经执行过 mysql_install_db 初始化了,按理说应该没问题。经过排查,发现 $datadir 的 mysql 数据库目录的权限模式为:

drwx------ 2 mysql root        4096 Jan  9 20:22 mysql

看起来没有问题。检查错误日志,发现一行:

130109 21:04:23 [Warning] Bootstrap mode disables GTIDs. Bootstrap mode should only be used by mysql_install_db which initializes the MySQL data directory and creates system tables.ERROR: 1785  Upd<a style="color:transparent">本文来源gao($daima.com搞@代@#码$网</a>ates to non-transactional tables are forbidden when DISABLE_GTID_UNSAFE_STATEMENTS = 1.130109 21:04:23 [ERROR] Aborting

同时,mysql库下的user表空间文件显示:

-rw-rw---- 1 mysql mysql 10684 Jan  9 20:22 user.frm-rw-rw---- 1 mysql mysql     0 Jan  9 20:22 user.MYD-rw-rw---- 1 mysql mysql  1024 Jan  9 20:22 user.MYI

可以看到,user表空间数据文件大小为0。
看起来应该是和启用GTID模式有一定关系了。仔细检查下,发现和GTID相关的选项有:

gtid_mode = ONbinlog_format = mixeddisable-gtid-unsafe-statements = 1log-bin=binlog

这是因为在启用GTID模式下,如果对非事务表更新时,无法保证事务一致性,因此设置 disable-gtid-unsafe-statements = 1 确保主从数据一致性。

解决方案:
这时候可以将选项 disable-gtid-unsafe-statements 的值修改为 0。也可以同时关闭 GTID 、 binlog 选项,初始化完毕后再打开。

#gtid_mode = ON#log-bin=binlog

disable-gtid-unsafe-statements = 0

技术相关:

MySQL基础知识

MySQL FAQ


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:[MySQL FAQ]系列 — 启用GTID & binlog新安装完的MySQL提示无法

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址