为什么使用 Docker 容器的 NextJS 在更改开发环境的代码后没有重新加载?

IT技术 node.js reactjs docker docker-compose next.js
2021-05-07 00:52:23

我正在尝试使用 Dockerfile 在 Docker 容器上运行 NextJS,并通过 docker-compose 运行,在我更改了 JS 文件(例如 index.js)中的代码后,Next 服务器没有重新加载。

但是,当我尝试在不使用 Docker 的情况下在室外运行时(通过直接执行“npm run dev”命令),Next 服务器确实顺利重新加载。

我还尝试通过“nodemon”命令(在容器内)运行服务器,它也没有成功。

Dockerfile:

FROM node:10.14.2-alpine
COPY . /home/next_app
WORKDIR /home/next_app
RUN npm install

docker-compose.yml:

version: "3.6"
services:
  self_nextjs:
    container_name: self_nextjs
    build:
        context: ./app
        dockerfile: Dockerfile
    ports:
        - 3000:3000
    volumes:
        - ./app:/home/next_app
        - /home/next_app/node_modules
    networks:
        - zen_frontend
    restart: always
    command: npm run dev

networks:
  zen_frontend:
      name: zen_frontend
      driver: bridge

任何建议,将不胜感激。

2个回答

您是否通过暴露 webpack 默认热重载端口进行了测试?

添加到您的 Dockerfile

...
EXPOSE 49153
...

并更新您的 docker-compose.yml

version: "3.6"
services:
  self_nextjs:
    container_name: self_nextjs
    build:
        context: ./app
        dockerfile: Dockerfile
    ports:
        - 3000:3000
        - 49153:49153
    volumes:
        - ./app:/home/next_app
        - /home/next_app/node_modules
    networks:
        - zen_frontend
    restart: always
    command: npm run dev

networks:
  zen_frontend:
      name: zen_frontend
      driver: bridge

希望这有帮助,

问候

我在 Windows 10 上遇到了同样的问题。我遵循了这个线程https://github.com/zeit/next.js/issues/6417 中的一些说明基本上,您必须添加一个next.config.js以轮询更改。我不确定 MacOS 是否有同样的问题。

module.exports = {
  webpackDevMiddleware: config => {
    config.watchOptions = {
      poll: 800,
      aggregateTimeout: 300,
    }
    return config
  },
}