请选择 进入手机版 | 继续访问电脑版
  • 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

docker - 使用 docker stack 部署主机环境变量

[复制链接]
菜鸟教程小白 发表于 2022-8-3 10:14:04 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我想知道是否有一种方法可以使用从部署容器的主机中获取的环境变量,而不是从 docker stack deploy 中获取的环境变量。命令被执行。例如想象以下 docker-compose.yml在三节点 Docker Swarm 集群上启动:

version: '3.2'
services:
  kafka:
    image: wurstmeister/kafka
    ports:
      - target: 9094
        published: 9094
        protocol: tcp
        mode: host
    deploy:
      mode: global
    environment:
      KAFKA_JMX_OPTS: "-Djava.rmi.server.hostname=${JMX_HOSTNAME} -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.rmi.port=1099"
JMX_HOSTNAME应该取自实际部署容器的主机,并且不应为每个容器使用相同的值。
有没有正确的方法来做到这一点?



Best Answer-推荐答案


是的,当您结合两个概念时,这会起作用:

  • node labels ,其中 Hostname 是内置的其中之一。
  • service go templates ,这也适用于堆栈文件。

  • 这会将主机名拉入 DUDE 的 ENV 值,使每个容器成为它运行的主机:
    version: '3.4'
    
    services:
      nginx:
        image: nginx
        environment:
          DUDE: "{{.Node.Hostname}}"
        deploy:
          replicas: 3
    

    关于docker - 使用 docker stack 部署主机环境变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49025686/

    回复

    使用道具 举报

    懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    关注0

    粉丝2

    帖子830918

    发布主题
    阅读排行 更多
    广告位

    扫描微信二维码

    查看手机版网站

    随时了解更新最新资讯

    139-2527-9053

    在线客服(服务时间 9:00~18:00)

    在线QQ客服
    地址:深圳市南山区西丽大学城创智工业园
    电邮:jeky_zhao#qq.com
    移动电话:139-2527-9053

    Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap