我的目标是从 Ubuntu 连接到 VMWare 客户机 (OpenSuse) 上的 Oracle 数据库。
目前我只安装了 oracledb 驱动程序,并试图运行给定的 example connect program。
我所遵循的步骤来自 github INSTALL 页面。到目前为止我所做的是这些:
1) 因为我已经安装了 node.js,所以我跳过了 step 3.1 。
2) 我已经成功下载并解压了 step 3.2 中提到的 basic 和 sdk。 p>
3) 由于我找不到任何名为 libaio 的包,但我确实找到了 libaio1。所以我安装了libaio1。
4) 我创建了环境变量LD_LIBRARY_PATH,它在我的PC上的内容是/opt/oracle/instantclient。
5) 如 step 3.3 中所述;即使在我的情况下这不是强制性的;我创建了两个环境变量: OCI_LIB_DIR 内容为 /opt/oracle/instantclient 和 OCI_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.ora 或 tnsnames.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/