mysql gtid 开启失败_[MySQLFAQ]系列--启用GTID&binlog新安装完的MySQL提示无法

新安装的MySQL提示1045错误,访问被拒绝。问题源于GTID模式下的安全设置,user表空间数据文件大小为0。解决方案包括修改disable-gtid-unsafe-statements选项为0或临时关闭GTID和binlog选项,初始化后再开启。
摘要由CSDN通过智能技术生成

问:刚刚新安装的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 mysql

ERROR 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 Updates 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 = ON

binlog_format = mixed

disable-gtid-unsafe-statements = 1

log-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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值