如何在Docker中部署一个可以被外部访问的Apollo配置中心

  携程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文件做如下改动:

  1. 为apollo-quick-start容器增加环境变量,配置实例地址为容器所在宿主机IP地址。
  2. 对8090端口做映射,后面会用到。
  3. 为保证容器销毁后数据不丢失,为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"}

扫描二维码关注公众号,回复: 11280095 查看本文章

  修改后,我们通过docker-compose重建Apollo容器,再次打开8070端口,我们会发现一下配置项均为以宿主机IP为根的正确地址:(这里我们可以看到8090端口也必须是宿主机IP,所以前面我把8090端口映射出来)

   查看Apollo中所有项目及配置,可正常呈现。则所有配置成功。

猜你喜欢

转载自www.cnblogs.com/zklight/p/12974872.html
今日推荐