在Docker中安装PostgreSQL的ODBC驱动并添加Python测试代码

# 使用官方的Ubuntu镜像作为基础镜像
FROM ubuntu:20.04

# 设置环境变量以避免交互式安装提示
ENV DEBIAN_FRONTEND=noninteractive

# 更新包列表并安装必要的软件包
RUN apt-get update && \
    apt-get install -y \
    build-essential \
    unixodbc \
    unixodbc-dev \
    odbcinst \
    wget \
    python3 \
    python3-pip \
    curl \
    gnupg && \
    apt-get clean && \
    rm -rf /var/lib/apt/lists/*

# 安装 PostgreSQL ODBC 驱动
RUN apt-get update && \
    apt-get install -y odbc-postgresql && \
    apt-get clean && \
    rm -rf /var/lib/apt/lists/*

# 配置 ODBC 驱动
RUN echo "[PostgreSQL]" > /etc/odbcinst.ini && \
    echo "Description = ODBC for PostgreSQL" >> /etc/odbcinst.ini && \
    echo "Driver = /usr/lib/x86_64-linux-gnu/odbc/psqlodbcw.so" >> /etc/odbcinst.ini && \
    echo "Setup = /usr/lib/x86_64-linux-gnu/odbc/libodbcpsqlS.so" >> /etc/odbcinst.ini && \
    echo "Driver64 = /usr/lib/x86_64-linux-gnu/odbc/psqlodbcw.so" >> /etc/odbcinst.ini && \
    echo "Setup64 = /usr/lib/x86_64-linux-gnu/odbc/libodbcpsqlS.so" >> /etc/odbcinst.ini && \
    echo "FileUsage = 1" >> /etc/odbcinst.ini

# 配置 ODBC 数据源
RUN echo "[PostgreSQLDataSource]" > /etc/odbc.ini && \
    echo "Driver = PostgreSQL" >> /etc/odbc.ini && \
    echo "Servername = localhost" >> /etc/odbc.ini && \
    echo "Port = 5432" >> /etc/odbc.ini && \
    echo "Database = testdb" >> /etc/odbc.ini && \
    echo "Username = postgres" >> /etc/odbc.ini && \
    echo "Password = YOUR_PASSWORD" >> /etc/odbc.ini && \
    echo "ReadOnly = No" >> /etc/odbc.ini && \
    echo "RowVersioning = No" >> /etc/odbc.ini && \
    echo "ShowSystemTables = No" >> /etc/odbc.ini && \
    echo "ConnSettings = " >> /etc/odbc.ini

# 设置默认命令
#CMD ["bash"]

# 安装 pyodbc 用于测试连接
RUN pip3 install pyodbc

# 添加测试脚本
COPY pgtest_odbc.py /pgtest_odbc.py

# 设置默认命令
CMD ["python3", "/pgtest_odbc.py"]
 

Python测试代码:
import pyodbc

# 配置数据库连接
dsn = 'PostgreSQLDataSource'
user = 'postgres'
password = 'YOUR_PASSWORD'
database = 'testdb'

# 创建连接字符串
conn_str = f'DSN={dsn};UID={user};PWD={password};DATABASE={database}'

# 尝试连接到数据库
try:
    conn = pyodbc.connect(conn_str)
    print("Connected to the database successfully!")
    conn.close()
except Exception as e:
    print(f"Failed to connect to the database: {e}")

__EOF__

本文作者pccai
本文链接https://www.cnblogs.com/pccai/p/18203799.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   pccai  阅读(56)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
点击右上角即可分享
微信分享提示