我正在尝试在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有任何建议或替代方法吗?
感谢您的帮助。
答案 0 :(得分:2)
您可以使用kubernetes服务公开每个部署。当您这样做时,每个公开的服务群集IP将作为环境变量供容器使用。
例如:部署hss,并使用名为hss
的服务公开hss端口。然后,任何需要连接到hss
的容器都可以使用环境变量HSS_SERVICE_HOST
来获取该服务的IP地址。还有更多环境变量可以为您提供服务端口号或其他格式的服务地址。