0

我在公司防火墙后面,我有一个 node.js 应用程序可以通过 docker 映像部署在 Openshift 容器上。该应用程序需要 oracledb 附加二进制文件 - 要在服务器上配置的 Oracle InstantClient 软件包。

我有以下 Dockerfile:

FROM devops-automation-docker<....>/rhel7-nodejs-10:latest
RUN mkdir -p /opt/oracle
# set working directory
RUN mkdir /usr/src/app
WORKDIR /usr/src/app

ENV PATH /usr/src/app/node_modules/.bin:$PATH

COPY . .

RUN mv instantclient_11_2 /opt/oracle
ENV LD_LIBRARY_PATH /opt/oracle/instantclient_11_2

RUN sh -c "echo /opt/oracle/instantclient_11_2 > /etc/ld.so.conf.d/oracle-instantclient.conf" && \
    ldconfig && \ 
    echo ${LD_LIBRARY_PATH} && \
    npm ci 


EXPOSE 3002

CMD ["node", "server.js"]

构建正在成功,但是当我部署和运行时,它会抛出以下错误:

/usr/src/app/design-pattern-exemplars/node_modules/oracledb/lib/oracledb.js:68 throw new Error(nodbUtil.getErrorMessage('NJS-045', nodeInfo)); ^

错误:NJS-045:无法加载 Node.js 10.16.0(linux、x64)的 oracledb 附加二进制文件 无法加载 /usr/src/app/design-pattern-exemplars/node_modules/oracledb/build/Release/oracledb .node /usr/src/app/design-pattern-exemplars/node_modules/oracledb/build/Release/oracledb.node:无效的ELF头Node-oracledb安装说明: https ://oracle.github.io/node-oracledb/ INSTALL.html 您必须在 LD_LIBRARY_PATH 中有 64 位 Oracle 客户端库,或者使用 ldconfig 进行配置。如果此计算机上没有 Oracle 数据库,请从 http://www.oracle.com/technetwork/topics/linuxx86-64soft-092277.html安装 Instant Client Basic 或 Basic Light 软件包

at Object.<anonymous> (/usr/src/app/design-pattern-exemplars/node_modules/oracledb/lib/oracledb.js:68:13)
at Module._compile (internal/modules/cjs/loader.js:776:30)
at Object.Module._extensions..js (internal/modules/cjs/loader.js:787:10)
at Module.load (internal/modules/cjs/loader.js:653:32)
at tryModuleLoad (internal/modules/cjs/loader.js:593:12)
at Function.Module._load (internal/modules/cjs/loader.js:585:3)
at Module.require (internal/modules/cjs/loader.js:690:17)
at require (internal/modules/cjs/helpers.js:25:18)
at Object.<anonymous> (/usr/src/app/design-pattern-exemplars/node_modules/oracledb/index.js:1:18)
at Module._compile (internal/modules/cjs/loader.js:776:30)

我究竟做错了什么?

PS 在我看到其他一些关于 SO 的帖子后添加了前 2 个命令,这些帖子有一些类似类型的问题,但它与 docker 无关,而是通过 sudo 运行的。

请帮忙!自从过去 10 天以来,我浏览了其他帖子,现在我感到无助。让我知道是否需要其他任何东西。

4

1 回答 1

1

乍一看,您是从不同的主机架构复制 node-oracledb 安装。由于 node-oracledb 有一个二进制组件,这可能会导致问题。但话虽如此,较新的 node-oracledb 版本可以在预提供的二进制文件可用的操作系统之间复制。您的 node-oracledb 版本是多少?最新的是4.0。你有 node-oracledb 作为依赖package.json吗?

我的建议:首先在 Dockerfile 中安装https://blogs.oracle.com/opal/dockerfiles-for-node-oracledb-are-easy-and-simple

FROM oraclelinux:7-slim

RUN  yum -y install oracle-release-el7 oracle-nodejs-release-el7 && \
     yum-config-manager --disable ol7_developer_EPEL && \
     yum -y install oracle-instantclient19.3-basiclite nodejs && \
     rm -rf /var/cache/yum

WORKDIR /myapp
ADD package.json /myapp/
ADD index.js /myapp/
RUN npm install

CMD exec node index.js

package.jsonoracledb依赖项。注意我什至不运行 ldconfig 因为 19.3 RPM Instant Client 已经这样做了。

如果事实证明您的 docker 容器架构没有二进制文件,您将不得不从源代码编译,再次在 Dockerfile 中。

更新:您可能对新博客文章Docker for Oracle Database Applications in Node.js and Python感兴趣。

一些评论:

  • (i) 为什么要使用这么旧的 Instant Client - 较新的 Instant Client 将连接到 11.2 DB 或更高版本。你的数据库版本是什么?
  • (ii) 如果您已经运行 ldconfig,则无需设置 LD_LIBRARY_PATH。
  • (iii) 当我在防火墙后面时,我会在我的 Dockerfile 中添加类似的内容:ENV https_proxy=http://example.com:80和/或RUN npm config set proxy http://example.com:80
于 2019-08-05T12:11:06.450 回答