针对mariadbconn构建pythonmysqlclient

2024-10-04 03:23:34 发布

您现在位置:Python中文网/ 问答频道 /正文

我试图在Conda环境中针对mariadb-connector-c编译python-mysqlclient。这意味着安装前缀不是/usr/local,而是$HOME/conda/envs/test。我还想使用auth_gssapi_client.so插件。在

两个包都会生成,但是import MySQLdb引发以下异常:

Traceback (most recent call last):
  File "/opt/emsconda/conda-bld/env/test_tmp/run_test.py", line 2, in <module>
    import MySQLdb
  File "/opt/emsconda/conda-bld/env/lib/python3.6/site-packages/MySQLdb/__init__.py", line 19, in <module>
    import _mysql
ImportError: libmariadb.so.3: cannot open shared object file: No such file or directory

原因是mysqlclient只搜索lib/,而不是 lib/mariadb即使它配置了正确的路径并且成功地 建造。我可以通过将*.so文件复制到lib/(或 通过创建一个符号链接),但是,它找不到GSSAPI插件

我用这种方式构建mariadb-connector-c3.0.2

^{pr2}$

我可以安装它并运行mariadb_config,这将产生以下输出:

Copyright 2011-2015 MariaDB Corporation AB
Get compiler flags for using the MariaDB Connector/C.
Usage: /opt/emsconda/conda-bld/mysqlclient_1510048680472/_h_env/bin/mariadb_config [OPTIONS]
  --cflags        [-I/opt/emsconda/conda-bld/env/include/mariadb -I/opt/emsconda/conda-bld/env/include/mariadb/mysql]
  --include       [-I/opt/emsconda/conda-bld/env/include/mariadb -I/opt/emsconda/conda-bld/env/include/mariadb/mysql]
  --libs          [-L/opt/emsconda/conda-bld/env/lib/mariadb/ -lmariadb -lpthread -ldl -lm -lssl -lcrypto]
  --libs_r        [-L/opt/emsconda/conda-bld/env/lib/mariadb/ -lmariadb -lpthread -ldl -lm -lssl -lcrypto]
  --libs_sys      [-lpthread -ldl -lm -lssl -lcrypto]
  --version       [10.2.6]
  --socket        [/tmp/mysql.sock]
  --port          [3306]
  --plugindir     [/opt/emsconda/conda-bld/env/lib/mariadb/plugin]
  --tlsinfo       [OpenSSL 1.0.2k]

然后,我通过以下方式构建python mysqlclient 1.3.12:

MYSQL_CONFIG="$PREFIX/bin/mariadb_config"
echo "mysql_config = $PREFIX/bin/mariadb_config" >> site.cfg
$PYTHON -m pip install -I --no-deps .

这个问题有两种可能的解决方案:

  1. mariadb-connector-c配置为直接将其内容放入lib/中—我还没有找到关于如何这样做的文档。

  2. 使pythonmysqlclient尊重mariadb_config返回的路径——如何?


Tags: testimportenvconfigconnectorincludelibmysql
1条回答
网友
1楼 · 发布于 2024-10-04 03:23:34

您必须将gssapi静态链接到mariadb-connector-c,Pythonmysqlclient就可以工作了。在

这是如何构建mariadb-connector-c:

mkdir build
cd build

cmake \
    -DCMAKE_INSTALL_PREFIX=$PREFIX \
    -DINSTALL_LIBDIR=lib \
    -DINSTALL_PLUGINDIR=lib/plugin \
    -DWITH_MYSQLCOMPAT=ON \
    -DAUTH_GSSAPI=STATIC \
    -DCMAKE_BUILD_TYPE=Release \
    ..

make
make install

# WITH_MYSQLCOMPAT only creates links for the libs, not for the binary:
cd $PREFIX/bin
ln -s mariadb_config mysql_config

相关问题 更多 >