我正在尝试编写一个容器化的 Node 应用程序,它接收 Microsoft Access 数据库并访问其中的数据。我想将应用程序放在 docker 容器中,并希望使用 npm odbc与 Access 进行交互。我没有太多创建容器的经验,所以这是一个学习过程。
我正在努力为 Access 安装和配置 odbc。根据我链接的文档,odbc 有三个要求。
- 安装 unixODBC 和 unixODBC-devel
- 为目标数据库安装 ODBC 驱动程序
- 定义 odbc.ini 和 odbcinst.ini
我正在努力让任何数量的 odbc 功能正常工作,所以我认为问题是我没有正确配置环境。这是我定义容器环境的基础 Dockerfile。运行 AccessDatabaseEngine.exe 文件会返回 Not Found 错误,即使我很确定该文件应该存在于那里。现在,我已经注释掉了这条线。应用程序代码从一组不同的 Dockerfile 运行,这些 Dockerfile 建立在这个基础之上。
# Use Ubuntu OS as base image
FROM ubuntu:latest
# Set env vars
ENV NPM_CONFIG_LOGLEVEL info
# odbc requirement #1
# Install unixODBC, unixODBC-devel, and curl
RUN apt-get update
RUN apt-get -y install unixodbc
RUN apt-get -y install unixodbc-dev
RUN apt-get -y install curl
# Download & install Node.js
RUN curl -fsSL https://deb.nodesource.com/setup_12.x | bash
RUN apt-get -y install nodejs
# odbc requirement #2
# Install ODBC drivers for Access database
RUN curl -LJO https://download.microsoft.com/download/2/4/3/24375141-E08D-4803-AB0E-10F2E3A07AAA/AccessDatabaseEngine.exe
RUN cp AccessDatabaseEngine.exe /bin/
RUN chmod +x /bin/AccessDatabaseEngine.exe
# RUN ['/bin/AccessDatabaseEngine.exe'] # Error: #14 0.249 /bin/sh: 1 [/bin/AccessDatabaseEngine.exe]: not found
# Run node
CMD [ "node" ]
在我的应用程序中,我尝试像这样使用 odbc。odbc 要求 #3 的连接字符串可在此处找到:
// Test function to test out npm odbc
exports.export = async (file) => {
// odbc requirement #3
// Make Access connection
const conn = await odbc.connect(`Driver={Microsoft Access Driver (*.mdb, *.accdb)};DBQ=${file.path}`);
// Execute test query
const res = await conn.query('SELECT 1');
console.log(JSON.stringify(res));
}
我对 odbc 要求 #1 和 #3 的实现感觉非常好,但我正在努力解决 #2(为目标数据库安装 ODBC 驱动程序)。我不仅在努力运行 AccessDatabaseEngine.exe,而且我也不能 100% 确定它是否是要尝试安装的正确文件。我遇到了这个,这似乎是我需要的 odbc 驱动程序。但是,我尝试对他们提供的代码进行 docker 化,但遇到了更多问题。
同样,我想创建一个容器化的 Node 应用程序,它使用 ODBC npm 库来访问 Microsoft Access 数据库中的数据。有没有人有这样做的经验?任何帮助,将不胜感激。提前谢谢。