我将通过以下dockerfile创建docker映像:
FROM python:2.7-alpine
RUN set -ex \
&& apk --no-cache add --virtual build-dependencies \
&& pip install --no-cache-dir mysql-python
它通过以下方式下载软件包:
Downloading https://files.pythonhosted.org/packages/a5/e9/51b544da85a36a68debe7a7091f068d802fc515a3a202652828c73453cad/MySQL-python-1.2.5.zip (108kB)
并执行
python setup.py install
但它失败并返回以下错误:
_mysql.c: In function '_mysql_ConnectionObject_ping':
_mysql.c:2005:41: error: 'MYSQL {aka struct st_mysql}' has no member named 'reconnect'
if ( reconnect != -1 ) self->connection.reconnect = reconnect;
^
error: command 'gcc' failed with exit status 1
但当我尝试:
FROM python:2.7
它非常有效。你知道吗?
2条答案
按热度按时间yqhsw0fo1#
我的理解是mysql和mariadb有一个稍微不同的api,这会导致编译失败。
阿尔卑斯山已经提供了
py-mysqldb
软件包工作正常,但这取决于它自己python2
包裹。我的建议是使用以下方法:dw1jzc5e2#
解决方案是使用mysqlclient包而不是mysql-python,它解决了当前mysql-python的多个问题。
https://github.com/pymysql/mysqlclient-python