我正在尝试在K8s上部署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有任何建议或替代方案吗?

谢谢你的帮助。

最佳答案

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

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

08-28 08:12