jjzjj

node.js - libclntsh.so.12.1 : cannot open shared object file error when running sample of node-oracledb

coder 2023-05-29 原文

我的目标是从 Ubuntu 连接到 VMWare 客户机 (OpenSuse) 上的 Oracle 数据库。

目前我只安装了 oracledb 驱动程序,并试图运行给定的 example connect program

我所遵循的步骤来自 github INSTALL 页面。到目前为止我所做的是这些:

1) 因为我已经安装了 node.js,所以我跳过了 step 3.1

2) 我已经成功下载并解压了 step 3.2 中提到的 basicsdk。 p>

3) 由于我找不到任何名为 libaio 的包,但我确实找到了 libaio1。所以我安装了libaio1

4) 我创建了环境变量LD_LIBRARY_PATH,它在我的PC上的内容是/opt/oracle/instantclient

5) 如 step 3.3 中所述;即使在我的情况下这不是强制性的;我创建了两个环境变量: OCI_LIB_DIR 内容为 /opt/oracle/instantclientOCI_INC_DIR 内容为 /opt/oracle/instantclient/sdk/include.

6) 安装 node-oracledb.

我正在尝试运行示例连接程序。我正在使用的代码在这里 https://github.com/ishanatmuz/oracle-test 。当我运行 node connect.js 时出现此错误。

/home/ishan/node.js/oracle-test/node_modules/oracledb/lib/oracledb.js:28
throw err;
          ^
Error: libclntsh.so.12.1: cannot open shared object file: No such file or directory
    at Module.load (module.js:356:32)
    at Function.Module._load (module.js:312:12)
    at Module.require (module.js:364:17)
    at require (module.js:380:17)
    at Object.<anonymous> (/home/ishan/node.js/oracle-test/node_modules/oracledb/lib/oracledb.js:23:15)
    at Module._compile (module.js:456:26)
    at Object.Module._extensions..js (modullibclntsh.so.12.1e.js:474:10)
    at Module.load (module.js:356:32)
    at Function.Module._load (module.js:312:12)
    at Module.require (module.js:364:17)

由于我还没有启动 VMware 客户机器;我希望得到一个关于没有找到这样的数据库实例的错误。然后才运行 VMWare 机器并连接到其中的数据库。但相反,我收到 cannot open shared object file for libclntsh.so.12.1 的错误。

最佳答案

我的第一个怀疑是 LD_LIBRARY_PATH 实际上没有正确设置或导出。三重检查它是否已设置,并且尝试启动 Node 的实际 shell 可以读取该目录。

export LD_LIBRARY_PATH=/opt/oracle/instantclient_12_2

您需要在任何启动 Node.js 的 shell 中执行此操作。

我还会检查机器上安装了哪些其他 Oracle 库,并确保没有冲突。

使用 ldconfig 全局设置路径几乎肯定比设置 LD_LIBRARY_PATH 更容易。您可以执行以下操作:

sudo sh -c "echo /opt/oracle/instantclient_12_2 > /etc/ld.so.conf.d/oracle-instantclient.conf"
sudo ldconfig

Instant Client install详细说明。

如果您有可选的网络配置文件,如 sqlnet.oratnsnames.ora,它们可以放在目录 /opt/oracle/instantclient_12_2/network/admin 这是配置文件的默认位置。见 Optional Oracle Net Configuration .

更新:如果您安装 Instant Client 19.3 RPM 软件包,ldconfig 步骤会自动完成。 (对于 19.3 ZIP 文件安装,您仍然需要/可以/应该这样做)

Instant Client 19 将连接到 Oracle Database 11.2 或更高版本,因此除非您对旧版本有特殊要求,否则请使用 Instant Client 19。

关于node.js - libclntsh.so.12.1 : cannot open shared object file error when running sample of node-oracledb,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29330841/

有关node.js - libclntsh.so.12.1 : cannot open shared object file error when running sample of node-oracledb的更多相关文章

随机推荐