[OpenStack]Mysql中空用户名的问题

在部署OpenStack组件(nova, keystone, glance, cinder)时,发现数据库虽已创建但无表。问题源于MySQL 5.0.95版本的两个空用户名,导致任何用户名和空密码都能在localhost和主机名下登录。MySQL验证机制先匹配host,若存在空用户,将尝试匹配。解决方案是删除mysql.user表的空用户。此问题在mysql 5.5.44及更高版本中已不存在。" 117633876,10615794,MySQL数据库存储引擎与索引深入解析,"['数据库理论', 'SQL', '索引']
摘要由CSDN通过智能技术生成

今天在部署openstack(nova,keystone,glance,cinder)的时候遇到了一个奇怪的问题。问题表现为一下特征:

          成功建立了nova,keystone,glance,cinder数据库,但是数据库中没有表


后来查到问题的关键在于用nova,keystone,glance,cinder用户登录mysql的时候报错

         Access denied for user 'xxx'@'$hostname'


最后定位在mysql 5.0.95 版本在执行默认安装后,会创建两个空用户

用root用户登录后

mysql -uroot -p

执行

select user,host from mysql.user

这两个用户名为空的用户为导致在登陆时,以任意用户名和空密码都可以在localhost和$hostname 登陆mysql


                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值