携程Apollo是一个基于Java开发的强大配置中心,提供了基于Docker的快速部署方案:https://github.com/ctripcorp/apollo/wiki/Apollo-Quick-Start-Docker%E9%83%A8%E7%BD%B2
但是通过官方部署方案部署完成之后,我们会发现,通过浏览器可以访问授权中心8070、8080端口,但是只有在同一网桥内部的程序可以成功获取Apollo中的配置信息,其他服务器或者网桥以外的程序无法成功获取配置需信息。
通过观察,我发现问题原因如下:Apollo配置中心通过8080端口提供配置获取接口,其接口依赖Spring Eureka,默认情况下,Eureka使用的是网桥中该节点的IP地址端口号,以其他IP地址访问是不被允许的。
依据该情况,我首先对Apollo提供的docker-compose文件做如下改动:
- 为apollo-quick-start容器增加环境变量,配置实例地址为容器所在宿主机IP地址。
- 对8090端口做映射,后面会用到。
- 为保证容器销毁后数据不丢失,为apollo-db节点增加目录映射,将数据库路径映射到宿主机中
修改后docker-compose文件如下,高亮部分为个人增加部分:
version: '2' services: apollo-quick-start: image: nobodyiam/apollo-quick-start container_name: apollo-quick-start environment: EUREKA_INSTANCE_IP_ADDRESS: '192.168.10.151' depends_on: - apollo-db ports: - "8090:8090" - "8080:8080" - "8070:8070" links: - apollo-db apollo-db: image: mysql:5.7 container_name: apollo-db environment: TZ: Asia/Shanghai MYSQL_ALLOW_EMPTY_PASSWORD: 'yes' depends_on: - apollo-dbdata ports: - "13306:3306" volumes: - ./sql:/docker-entrypoint-initdb.d - ./data:/var/lib/mysql volumes_from: - apollo-dbdata apollo-dbdata: image: alpine:latest container_name: apollo-dbdata volumes: - /var/lib/mysql
修改完成后通过docker-compose启动容器,我们打开,8080端口,会发现此处显示宿主机IP地址,则修改成功:
但是我们通过8070端口,访问Apollo配置中心界面,进入项目配置会发现报错。此时查看管理员工具->系统信息:发现Meta serve,Config Services,Admin Service信息配置不正确。
这里我们需要通过连接Apollo数据库,修改其中的配置项。修改内容如下:讲数据库ApolloConfigDB中ServerConfig表的Key=eureka.service.url的数据项的Value值改为http://【宿主机IP】:8080/eureka/,将数据库ApolloPortalDB的ServerConfig表中Key=apollo.portal.meta.servers项中value改为{"DEV":"http://【宿主机IP】:8080"}
修改后,我们通过docker-compose重建Apollo容器,再次打开8070端口,我们会发现一下配置项均为以宿主机IP为根的正确地址:(这里我们可以看到8090端口也必须是宿主机IP,所以前面我把8090端口映射出来)
查看Apollo中所有项目及配置,可正常呈现。则所有配置成功。