迁移docker-compose到Kubernetes

时间:2019-12-17 17:45:42

标签: docker kubernetes docker-compose

我正在尝试在K8上部署free5GC(cluster version)。 该软件的问题在于,某些服务在启动之前必须知道其他服务IP。我通过在docker-compose中执行此问题来解决此问题,并在每个docker容器内执行脚本,并以其他服务IP作为参数。 这是我的docker-compose.yaml:

version: '3'

networks:
    testing_net:
        ipam:
            driver: default
            config:
                - subnet: 172.28.0.0/16

services:
  mongo:
    container_name: mongo
    image: mongo
    networks: 
      testing_net:
        ipv4_address: ${mongo_ip}

  webui:
    container_name: webui
    image: j0lama/free5gc-webui
    depends_on:
      - mongo
    ports:
      - '80:3000'
    extra_hosts:
      - "mongo:${mongo_ip}"
    networks: 
      testing_net:
        ipv4_address: ${webui_ip}

  hss:
    container_name: hss
    command: bash -c "./hss_setup.sh ${mongo_ip} ${hss_ip} ${amf_ip}"
    image: j0lama/free5gc-hss
    depends_on:
      - mongo
    networks: 
      testing_net:
        ipv4_address: ${hss_ip}

  amf:
    container_name: amf
    command: bash -c "./amf_setup.sh ${mongo_ip} ${hss_ip} ${amf_ip} ${smf_ip}"
    image: j0lama/free5gc-amf
    depends_on:
      - mongo
      - hss
    ports:
      - '36412:36412'
    networks: 
      testing_net:
        ipv4_address: ${amf_ip}

  smf:
    container_name: smf
    command: bash -c "./smf_setup.sh ${smf_ip} ${upf_ip} ${pcrf_ip}"
    image: j0lama/free5gc-smf
    depends_on:
      - mongo
      - hss
      - amf
    networks: 
      testing_net:
        ipv4_address: ${smf_ip}

  pcrf:
    container_name: pcrf
    command: bash -c "./pcrf_setup.sh ${mongo_ip} ${smf_ip} ${pcrf_ip}"
    image: j0lama/free5gc-pcrf
    depends_on:
      - mongo
      - hss
      - amf
      - smf
    networks: 
      testing_net:
        ipv4_address: ${pcrf_ip}

  upf:
    container_name: upf
    command: bash -c "./upf_setup.sh ${upf_ip}"
    image: j0lama/free5gc-upf
    depends_on:
      - mongo
      - hss
      - amf
      - smf
      - pcrf
    networks: 
      testing_net:
        ipv4_address: ${upf_ip}

通过此操作,我可以正确设置群集的所有组件。 我已经尝试过kompose实用程序,但是不起作用。

对Kubernetes有任何建议或替代方法吗?

感谢您的帮助。

1 个答案:

答案 0 :(得分:2)

您可以使用kubernetes服务公开每个部署。当您这样做时,每个公开的服务群集IP将作为环境变量供容器使用。

例如:部署hss,并使用名为hss的服务公开hss端口。然后,任何需要连接到hss的容器都可以使用环境变量HSS_SERVICE_HOST来获取该服务的IP地址。还有更多环境变量可以为您提供服务端口号或其他格式的服务地址。