问题产生背景:
这两天在学习docker部署分布式项目,nacos,mysql等都是跑在docker中的,在将服务部署在容器里面时,老是报错显示无法注册到nacos
解决办法:
给所有用到的容器配置一个专用网络,代码中用到相关联的服务全部使用容器名进行访问即可
示例:
provider-user-service的application.yml配置文件:
spring:
application:
name: user-provider
main:
allow-bean-definition-overriding: true
datasource:
type: com.zaxxer.hikari.HikariDataSource
driver-class-name: com.mysql.cj.jdbc.Driver
#之前直接使用的mysql跑在容器中对外暴露的端口,即便如此,当程序跑在容器内时也还无法连接的,所以统一配置在同一个网络中,通过容器名访问即可
url: jdbc:mysql://c_mysql_02:3306/ppf_db?useUnicode=true&characterEncoding=utf-8&serverTimezone=UTC
username: root
password: 123456
hikari:
minimum-idle: 5
idle-timeout: 600000
maximum-pool-size: 10
auto-commit: true
pool-name: MyHikariCP
max-lifetime: 1800000
connection-timeout: 30000
connection-test-query: SELECT 1
jpa:
database-platform: org.hibernate.dialect.MySQLDialect
show-sql: true
dubbo:
scan:
base-packages: com.ppf.demo.provider.service
protocol:
name: dubbo
port: -1
serialization: kryo
registry:
#此处也是通过nacos容器名进行服务注册的
address: nacos://nacos-standalone:8848
ppf-user-service 容器启动时配置指定网络(–network=my-net)
docker run -di --name=p_u_s --network=my-net ppf-user-service
docker-compose.yml中配置指定网络
networks:
default:
external:
name: my-net