首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在哪个港口,我的码头容器与一个反应应用程序运行?响应默认端口还是从Dockerfile公开?

在哪个港口,我的码头容器与一个反应应用程序运行?响应默认端口还是从Dockerfile公开?
EN

Stack Overflow用户
提问于 2020-08-25 12:56:58
回答 3查看 5.3K关注 0票数 2

我是码头工人的新手,所以如果我说错了,请纠正我。

我创建了一个React应用程序,并在根存储库中编写了以下Dockerfile:

代码语言:javascript
复制
# pull official base image
FROM node:latest

# A directory within the virtualized Docker environment
# Becomes more relevant when using Docker Compose later
WORKDIR /usr/src/app
 
# Copies package.json and package-lock.json to Docker environment
COPY package*.json ./
 
# Installs all node packages
RUN npm install
 
# Copies everything over to Docker environment
COPY . .
 
# Uses port which is used by the actual application
EXPOSE 8080
 
# Finally runs the application
CMD [ "npm", "start" ]

我的目标是以一种方式运行docker映像,这样我就可以在浏览器中打开React应用程序(使用localhost)。因为在Dockerfile中,我将应用程序公开给端口: 8080。我以为我能跑:

代码语言:javascript
复制
docker run -p 8080:8080 -t <name of the docker image>

但是很明显,应用程序可以在容器中通过3000进行访问,因为当我运行时:

代码语言:javascript
复制
docker run -p 8080:3000 -t <name of the docker image>

我可以用本地主机8080访问它。

如果运行在其容器中的服务可以通过不同的端口访问,那么在Dockerfile中公开端口的意义是什么?当包含NodeJS应用程序时,我是否总是必须确保应用程序中的process.env.PORT与Dockerfile中的公开相同?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2020-08-25 13:34:30

EXPOSE是为了告诉停靠者,可以从应用程序内部公开哪些端口可以公开。如果您不使用内部的端口(容器->主机),这并不意味着什么。

EXPOSE在使用docker run -P -t <name of the docker image> (-P大写P)让Docker自动将所有公开端口发布到主机上的随机端口时非常方便(尝试一下)。然后运行docker psdocker inspect <containerId>并检查输出)。

因此,如果您的web (React )运行在端口3000 (容器内)上,您应该使用EXPOSE 3000 (而不是8080)来正确地集成Docker。

票数 4
EN

Stack Overflow用户

发布于 2020-08-25 13:55:21

有点奇怪。这只是某种意义上的文件。

https://docs.docker.com/engine/reference/builder/#:~:text=The%20EXPOSE%20instruction%20informs%20Docker,not%20actually%20publish%20the%20port

公开指令实际上并不发布端口。它作为构建映像的人和运行容器的人之间的一种文档类型,而这些港口将被发布。要在运行容器时实际发布端口,请在运行的码头上使用-p标志发布和映射一个或多个端口,或者使用-P标志发布所有公开的端口,并将它们映射到高级端口。我是否总是必须确保我的应用程序中的process.env.PORT与Dockerfile中的公开相同?是。你应该这样做。

然后,您还需要确保当您使用docker run命令或在docker -come.yml文件中,或者无论您计划如何运行docker时,端口实际上都会被发布。

票数 1
EN

Stack Overflow用户

发布于 2021-09-15 06:42:34

实际上,react运行默认端口3000。因此,您必须提到端口并在docker-compose.yml中公开。现在我要把3000端口改为8081

代码语言:javascript
复制
  frontend: 
      container_name: frontend 
      build: 
        context: ./frontend/app
        dockerfile: ../Dockerfile  
      volumes:
        - ./frontend/app:/home/devops/frontend/app 
        - /home/devops/frontend/app/node_modules
      ports:
        - "8081:3000"
      expose:
        - 8081
      command: ["npm", "start"]
      restart: always 
      stdin_open: true 

管理码头

代码语言:javascript
复制
$ sudo docker-compose up -d

然后检查正在运行的容器,以找到正在运行的端口。

代码语言:javascript
复制
$ sudo docker ps

CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                              NAMES
83b970baf16d        devops_frontend     "docker-entrypoint..."   31 seconds ago      Up 30 seconds       8081/tcp, 0.0.0.0:8081->3000/tcp   frontend

已经解决了。检查你的公共港口

代码语言:javascript
复制
$ curl 'http://0.0.0.0:8081'
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63579358

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档