我正在尝试在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地址。还有更多环境变量可以为您提供服务端口号或其他格式的服务地址。