docker部署nacos报数据库连接超时

基于docker部署nacos命令如下

mysql启动命令

docker run --name mysql -p 3306:3306 --net work --restart=always -v /etc/localtime:/etc/localtime -v /data/middleware/mysql/config/my.cnf:/etc/mysql/my.cnf -v /data/middleware/mysql/data/:/var/lib/mysql -v /data/middleware/mysql/logs/:/logs -e MYSQL_ROOT_PASSWORD=root -d mysql:8.0

nacos启动命令

docker run --name nacos -p 8848:8848 -p 9848:9848 --privileged=true --restart=always --net work -v /etc/localtime:/etc/localtime  -e BASE_DIR=/home/nacos -e CLUSTER_CONF=/home/nacos/conf/cluster.conf -e FUNCTION_MODE=all -e CLASSPATH=.:/home/nacos/conf: -e SPRING_DATASOURCE_PLATFORM=mysql -e MYSQL_SERVICE_HOST=mysql -e MYSQL_SERVICE_PORT=3306 -e MYSQL_SERVICE_USER=root -e MYSQL_SERVICE_PASSWORD=root -e MYSQL_SERVICE_DB_NAME=nacos -e MODE=standalone -e TOMCAT_ACCESSLOG_ENABLED=false -d nacos:2.1.0

按照这个部署内容最开始在docker虚拟网络内正常运行,服务器做了网络变更后发现nacos一直报数据库连接失败,随后排查

查询mysql是否正常运行

docker -exec mysql bash

随后连接mysql

mysql -p 3306  -uroot -proot

能够连接,然后查询nacos库是否存在

show databses;

nacos库也在,就代表数据库正常,问题出在nacos上;

查看nacos配置文件发现,原生的application.yml文件内数据库的连接时间跟socket连接时间分别为1秒和3秒

随后新增nacos启动参数

MYSQL_SERVICE_DB_PARAM=characterEncoding=utf8&connectTimeout=10000&socketTimeout=30000&autoReconnect=true&useSSL=false

更新完后的启动命令如下

docker run --name nacos -p 8848:8848 -p 9848:9848 --privileged=true --restart=always --net work -v /etc/localtime:/etc/localtime  -e BASE_DIR=/home/nacos -e CLUSTER_CONF=/home/nacos/conf/cluster.conf -e FUNCTION_MODE=all -e CLASSPATH=.:/home/nacos/conf: -e SPRING_DATASOURCE_PLATFORM=mysql -e MYSQL_SERVICE_HOST=mysql -e MYSQL_SERVICE_PORT=3306 -e MYSQL_SERVICE_USER=root -e MYSQL_SERVICE_PASSWORD=root -e MYSQL_SERVICE_DB_NAME=nacos -e MYSQL_SERVICE_DB_PARAM=characterEncoding=utf8&connectTimeout=10000&socketTimeout=30000&autoReconnect=true&useSSL=false -e MODE=standalone -e TOMCAT_ACCESSLOG_ENABLED=false -d nacos:2.1.0

随后删除旧容器,重新启动

访问映射的端口8848

恢复正常

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值