[linux] kolla-ansible 部署的openstack 修改mariadb默认端口号

kolla-ansible 部署前修改global.yml

复制代码
#freezer_database_backend: "mariadb"
database_port: 9306
mariadb_port: 9306

如果已经部署成功,直接修改配置文件里的端口号重启是没有用的,怀疑内部做了缓存,查看openstack 使用的memcached,也没有什么结果,nova的所有服务与数据库交互的都报失败,打印日志发现,修改了配置,连接mysql端口仍然使用的3306,刚开始怀疑端口是不是没有从配置传下去,后来感觉,openstack不会犯这么sb的错误。本以为这个问题,几周了,也没收获了,算了,直到想想,还是再使劲定位下,打开了debug,所有与数据库交互的openstack都是直接调用的封装好的 oslo_db,在nova源码里搜索oslo

发现连接数据库用的缓存池,数据库的连接url原来是保存在一张表里。。。

还以为是个本地的sqlit数据库,没想到在nova_api数据库中果然存在这张cell_mappings映射信息表,直接修改了数据后,重启服务,db连接恢复正常。

openstack过于庞大,花了很多猜想,搜资料,本来用自己的经验去寻找答案,从来没想到过链接db时的url信息,保存在数据库里读取,做了缓存,就不从配置里读了。

复制代码
# 备份
cd /etc/kolla
sed -i "s/3306/9306/g" `grep 3306 -rl .`

navicat登录数据库,进入nova_api,修改表cell_mappings 字段database_connection内的端口号

systemctl restart docker
重启所有的服务
相关推荐
LUCIFER12 分钟前
[驱动之路(九)——UART(串口)子系统]学习总结,万字长篇,一文彻底搞懂UART(串口)子系统(含串口数据收发流程解析)
linux·驱动开发
忙里偷闲学python16 分钟前
ceph介绍和安装
linux·ceph·kubernetes
zhong_kh1 小时前
字符串判断
linux·运维·服务器
来鸟 鸣间1 小时前
i2c_add_driver关键流程
linux·i2c
fengyue01101 小时前
C++使用epoll实现高并发tcp服务
linux·服务器·网络·c++
谷雨不太卷1 小时前
Linux_文件指令
linux·运维·服务器
0vvv01 小时前
Vimer
linux·靶机
MediaTea1 小时前
Python:实例 __dict__ 详解
java·linux·前端·数据库·python
jerryinwuhan2 小时前
linux_shell_2
linux
Hncj20222 小时前
项目02--JsonRpc
linux·c++·ubuntu·rpc