docker安装xxl-job连接数据库时显示无法连接问题

背景:

在项目中需要定时任务调度,需要在docker容器中安装xxl-job

遇到的问题

部署成功后,可以访问xxl-job登录界面,点登录没反应,但过一段时间就弹出数据库拒绝连接,说MyBatis连接用户失败

原因:

在docker容器中,不同容器直接是相互隔离互不影响的,如果使用localhost、或者127.0.0.1是无法生效的。

解决方法:

思路:

1、先检查需要连接的数据库用户名和密码是否正确

2、如果是docker中不同容器之间的连接访问,就需要检查服务器内网地址。

3、检测映射的端口是否对应

方法:

查看服务器内网ip地址:

修改application.properties配置:

数据库连接地址和密码

或者使用:容器名加端口号的方式访问,例如我的mysql数据库的容器名是 n_mysql

yml 复制代码
spring.datasource.url=jdbc:mysql://n_mysql:3306/xxl_job?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&serverTimezone=Asia/Shanghai

注意:这些操作都是在同一服务器上操作的

在操作这些步骤中,可能有其他原因:

1、是否在同一服务器中操作的,不同服务器之间就不能直接使用局域网ip地址,需要使用公网ip进行访问连接数据库

2、在创建容器时,映射地址是否正确(不限于,路径名称)

3、检测防火墙是否放行相应的端口,不过都能访问后台地址了,不会是防火墙的问题

扩展:

docker内的应用访问宿主机上的mysql和Redis

背景:宿主机部署MySQL、Redis,docker内部署tomcat、jdk

需求:tomcat内的应用访问宿主机的MySQL和Redis 方法: 连接地址切记不能用localhost和127.0.0.1

这些地址代表的都是容器内的系统,根本没有访问到宿主机,会一直报连接mysql/redis异常。 用docker的虚拟网卡地址

在宿主机查询网卡情况------ifconfig docker0这块虚拟网卡的 inet 地址就是正确的本地ip(如172.17.0.1)

相关推荐
国服第二切图仔11 分钟前
鸿蒙应用开发之实现键值型数据库跨设备数据同步
数据库·wpf·harmonyos
盒马coding1 小时前
PostgreSQL18新功能COPY命令变得更加用户友好
数据库·postgresql
️️(^~^)1 小时前
触发器,存储过程
数据库
罗光记2 小时前
Quantinuum 发布新型量子计算机“Helios“
数据库·经验分享·其他·百度·twitter
友友马2 小时前
『 数据库 』MySQL索引深度解析:从数据结构到B+树的完整指南
数据库·mysql
SelectDB2 小时前
替换 ClickHouse,查询并发提升 7 倍!高途教育基于阿里云 SelectDB 构建秒级实时报表
数据库·apache
JamSlade2 小时前
优化用户体验的小点:乐观更新链路 双数据库查询
数据库·ux
一 乐3 小时前
个人博客|博客app|基于Springboot+微信小程序的个人博客app系统设计与实现(源码+数据库+文档)
java·前端·数据库·spring boot·后端·小程序·论文
小二·3 小时前
用 eBPF 实现 MySQL 慢查询实时追踪(终极实战版):零侵入、毫秒级、全上下文捕获
数据库·mysql·adb
云飞云共享云桌面3 小时前
三维设计办公资源如何共享集中和安全管控?
运维·服务器·数据库·安全·自动化·制造