【问题标题】:docker compose environment varibales are undefined in nodejs containerdocker compose 环境变量在 nodejs 容器中未定义
【发布时间】:2021-09-01 13:23:21
【问题描述】:

当尝试控制台记录在 docker-compose 中定义的环境变量时,节点容器返回未定义的值。

docker-compose.yml

version: "3"

services: 

    api: 
        build: ./api
        ports: 
            - "3004:3004"
        volumes:
            - type: bind
              source: ./api
              target: /usr/src/api
        working_dir: /usr/src/api
        environment: 
            REDIS_HOST: "redis://redis:6379"
            TEST: "123"
        depends_on: 
            - redis
        networks:
            - backend

    redis: 
        image: "redis:latest"
        ports: 
            - "6379:6379"
        networks:
            - backend
networks:
    backend:
        driver: bridge

我尝试过更改 yaml 语法 到 - 测试 =“123” 而不是键值语法只是为了确保。我不确定问题可能是什么。

API dockerfile 如下所示:

FROM node:12


# create destination directory
RUN mkdir -p /usr/src/api
WORKDIR /usr/src/api

# copy the app, note .dockerignore
COPY . /usr/src/api

# Install packages
RUN npm i yarn --save
RUN yarn 

# COPY . /src
EXPOSE 3005

CMD ["yarn", "dev"]

NodeJS 代码段:

console.log("redis host! + test");
console.log(process.env.REDIS_HOST, process.env.TEST)

控制台日志输出:

api_1    | redis host! + test
api_1    | undefined undefined

【问题讨论】:

标签: node.js docker docker-compose environment


【解决方案1】:

您需要使用ARG额外引用Dockerfile中的环境变量

ARG REDIS_HOST
ARG TEST

【讨论】:

  • 谢谢你,成功了。但为什么?您还需要在那里引用它的原因是什么?
猜你喜欢
  • 2020-02-23
  • 1970-01-01
  • 2017-09-18
  • 2019-12-18
  • 2018-12-03
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多