在 Docker 环境中运行的 Node.js 应用程序出现了“找不到模块”错误。

3

这个应用程序是用ES6编写的,并使用babel编译为ES5。构建文件按以下顺序存储在构建文件夹内。Dockerfile位于构建文件夹外部。

-build
---public
---server
---shared
---package.json
-Dockerfile

这是我的Docker文件。

FROM node:8.9-alpine
ENV     NODE_ENV production

WORKDIR /usr/src/app
ADD    ./build/  /usr/src/app

RUN npm install --production --silent

RUN ls /usr/src/app/
RUN ls /usr/src/app/server/

EXPOSE 3000

CMD  ["node", "/usr/src/app/server/index.js", "--config", "/usr/src/app/config.json"]

这是运行图像构建命令时的输出结果。

Sending build context to Docker daemon  16.08MB
Step 1/9 : FROM node:8.9-alpine
 ---> 406f227b21f5
Step 2/9 : ENV     NODE_ENV production
 ---> Using cache
 ---> 090d3e742281
Step 3/9 : WORKDIR /usr/src/app
 ---> Using cache
 ---> fa2a344bd8ee
Step 4/9 : ADD    ./build/  /usr/src/app
 ---> 93559e34a45a
Step 5/9 : RUN npm install --production --silent
 ---> Running in ebc2b6b2ba1a
added 212 packages in 15.212s
Removing intermediate container ebc2b6b2ba1a
 ---> b49180988a07
Step 6/9 : RUN ls /usr/src/app/
 ---> Running in b140530cb8ca
build-info.json
node_modules
package-lock.json
package.json
public
server
shared
Removing intermediate container b140530cb8ca
 ---> 0712e1b84e1a
Step 7/9 : RUN ls /usr/src/app/server/
 ---> Running in b6570fbc8d2c
auth
configuration
database
files
index.js
sessions
users
utils
Removing intermediate container b6570fbc8d2c
 ---> c49775551756
Step 8/9 : EXPOSE 3000
 ---> Running in 9318dfc0f183
Removing intermediate container 9318dfc0f183
 ---> ad20aec92973
Step 9/9 : CMD  ["node", "/usr/src/app/server/index.js", "--config", "/usr/src/app/config.json"]
 ---> Running in fa6c2e388906
Removing intermediate container fa6c2e388906
 ---> ba1ced3be150
Successfully built ba1ced3be150
Successfully tagged tiqri:myclaim
SECURITY WARNING: You are building a Docker image from Windows against a non-Windows Docker host. All files and directories added to build context will have '-rwxr-xr-x' permissions. It is recommended to double check and reset permissions for sensitive files and directories.

创建镜像后,我使用以下命令启动镜像。 "docker run -d -v C:\portal\environments\development:/usr/src/app/ -p 3000:80 f057e4bc8191" 配置文件有卷映射。
但是容器没有运行。当我检查日志时,显示以下错误。

C:\portal>docker logs c819d39fea61
module.js:540
    throw err;
    ^

Error: Cannot find module '/usr/src/app/server/index.js'
    at Function.Module._resolveFilename (module.js:538:15)
    at Function.Module._load (module.js:468:25)
    at Function.Module.runMain (module.js:684:10)
    at startup (bootstrap_node.js:187:16)
    at bootstrap_node.js:608:3

尽管在docker容器中运行ls命令时显示文件夹结构,但我仍然无法确定为什么会出现此错误。所有文件夹都已放置在正确位置。

更新

根据@Marcos Casagrande所提供的答案,对dockerfile和容器运行命令进行了更改。现在我遇到了一个新错误。

在Dockerfile中进行修改后。

FROM node:8.9-alpine
ENV     NODE_ENV production

WORKDIR /usr/src/app

ADD    ./build/  /usr/src/app
RUN npm install --production --silent && mv node_modules ../

RUN mkdir /usr/src/app/environments
RUN mkdir /usr/src/app/environments/development

RUN ls /usr/src/app/
RUN ls /usr/src/app/server/

EXPOSE 3000

CMD  ["node", "/usr/src/app/server/index.js", "--config", "/usr/src/app/environments/development/config.json"]

容器运行命令如下所示:

"docker run -d -v C:\portal\environments\development:/usr/src/app/environments/development -p 3000:80 ca290d67ff34"

当我检查日志时,出现以下错误。容器尚未启动。

/usr/src/app/environments/development/config.json
/usr/src/app/environments/development/config.json
fs.js:646
  return binding.open(pathModule._makeLong(path), stringToFlags(flags), mode);
                 ^

Error: ENOENT: no such file or directory, open '/usr/src/app/environments/development/config.json'
    at Object.fs.openSync (fs.js:646:18)
    at Object.fs.readFileSync (fs.js:551:33)
    at loadJSON (/usr/src/node_modules/convict/lib/convict.js:364:25)
    at /usr/src/node_modules/convict/lib/convict.js:501:17
    at Array.forEach (<anonymous>)
    at Object.loadFile (/usr/src/node_modules/convict/lib/convict.js:500:13)
    at Object.<anonymous> (/usr/src/app/server/configuration/configuration.js:156:19)
    at Module._compile (module.js:643:30)
    at Object.Module._extensions..js (module.js:654:10)
    at Module.load (module.js:556:32)


显示以下目录的内容:C:\portal\environments\development,该文件夹中是否有一个名为server的目录? - Marcos Casagrande
@MarcosCasagrande 那个文件夹包含运行应用所需的配置文件。服务器文件夹包含我在开头提到的构建文件夹。 - Manojb86
一分钟后请查看我的回答。 - Marcos Casagrande
2个回答

1

在不知道 C:\portal\environments\development 的内容的情况下,我认为其中没有 server/index.js

尽管在 Docker 容器中所有文件夹都已经就位(运行 ls 可以显示容器中的文件夹结构),但我仍然无法理解为什么会出现此错误。因此,我不能启动容器。

当构建 Docker 镜像时,在复制构建目录之后执行 RUN ls,如果你在启动容器时运行 ls,你会发现没有 server/index.js

在将 build 文件夹复制到 /usr/src/app/ 时,当挂载 development 文件夹到 /usr/src/app 上时,会覆盖那些文件。

最简单的方法是将 C:\portal\environments\development 挂载到 /usr/src/app/development 上。

docker run -d -v C:\portal\environments\development:/usr/src/app/development/ -p 3000:80 f057e4bc8191

此外,您可以将development挂载到/usr/src/app上,然后使用构建在镜像中的build/server
-v C:\portal\environments\development:/usr/src/app/ -v /usr/src/app/server

你需要为每个你从构建镜像中需要的文件夹都这样做。
-v /usr/src/app/server -v /usr/src/app/public -v ...

请检查更新后的问题。我按照您在这里提到的做法进行了操作。我解决了我最初提到的问题,但又遇到了另一个问题。 - Manojb86
进入容器,并在 development 上运行 ls 命令,显示输出。 - Marcos Casagrande

1

我曾经遇到了一个类似的问题,运行docker容器时出现了错误。后来我发现可能是我错误地创建了镜像,所以我通过删除镜像并重新构建来解决这个问题。但首先我需要删除该镜像的现有容器,如下所示:

    docker rm containerId

然后我像下面这样删除了图片。
    docker rmi imageId

然后我重建了镜像并运行以创建一个新的容器。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接