Проблема с настройкой модуля MySQLdb

#python #mysql #macos #python-module #mysql-python

#python #mysql #macos #python-module #mysql-python

Вопрос:

Я тут из кожи вон лезу, пытаясь настроить MySQLdb на своем Mac, чтобы подключиться к удаленному серверу MySQL.

  1. Я установил последние клиентские библиотеки C MySQL
  2. Я установил XCode 4
  3. Я наивно пытался установить модуль перед установкой XCode или клиентских библиотек

Я пытаюсь настроить модуль, выполнив следующие команды в терминале:

$ sudo python setup.py сборка

$ sudo python setup.py установить

Обе эти команды завершаются ошибкой с похожими сообщениями об ошибках. Вот первая трассировка стека:

 running build
running build_py
copying MySQLdb/release.py -> build/lib.macosx-10.6-universal-2.6/MySQLdb
running build_ext
building '_mysql' extension
gcc-4.2 -fno-strict-aliasing -fno-common -dynamic -DNDEBUG -g -fwrapv -Os -Wall -Wstrict-prototypes -DENABLE_DTRACE -arch i386 -arch ppc -arch x86_64 -pipe -Dversion_info=(1,2,3,'final',0) -D__version__=1.2.3 -I/usr/include/mysql -I/System/Library/Frameworks/Python.framework/Versions/2.6/include/python2.6 -c _mysql.c -o build/temp.macosx-10.6-universal-2.6/_mysql.o -fno-omit-frame-pointer -pipe
In file included from _mysql.c:36:
/usr/include/mysql/my_config.h:1030:2: warning: #warning defining SIZEOF_CHARP = 4
/usr/include/mysql/my_config.h:1044:2: warning: #warning defining SIZEOF_LONG = 4
/usr/libexec/gcc/powerpc-apple-darwin10/4.2.1/as: assembler (/usr/bin/../libexec/gcc/darwin/ppc/as or /usr/bin/../local/libexec/gcc/darwin/ppc/as) for architecture ppc not installed
Installed assemblers are:
/usr/bin/../libexec/gcc/darwin/x86_64/as for architecture x86_64
/usr/bin/../libexec/gcc/darwin/i386/as for architecture i386
In file included from _mysql.c:36:
/usr/include/mysql/my_config.h:1030:2: warning: #warning defining SIZEOF_CHARP = 4
/usr/include/mysql/my_config.h:1044:2: warning: #warning defining SIZEOF_LONG = 4
/usr/include/mysql/my_config.h:1151:1: warning: "WORDS_BIGENDIAN" redefined
In file included from /System/Library/Frameworks/Python.framework/Versions/2.6/include/python2.6/Python.h:8,
                 from pymemcompat.h:10,
                 from _mysql.c:29:
/System/Library/Frameworks/Python.framework/Versions/2.6/include/python2.6/pyconfig.h:1014:1: warning: this is the location of the previous definition
_mysql.c:2888: fatal error: error writing to -: Broken pipe
compilation terminated.
In file included from _mysql.c:36:
/usr/include/mysql/my_config.h:1027:2: warning: #warning defining SIZEOF_CHARP = 8
/usr/include/mysql/my_config.h:1041:2: warning: #warning defining SIZEOF_LONG = 8
lipo: can't open input file: /var/tmp//ccU6bipK.out (No such file or directory)
error: command 'gcc-4.2' failed with exit status 1
  

И вот трассировка стека для второй команды:

 running install
running bdist_egg
running egg_info
writing MySQL_python.egg-info/PKG-INFO
writing top-level names to MySQL_python.egg-info/top_level.txt
writing dependency_links to MySQL_python.egg-info/dependency_links.txt
reading manifest file 'MySQL_python.egg-info/SOURCES.txt'
reading manifest template 'MANIFEST.in'
warning: no files found matching 'MANIFEST'
warning: no files found matching 'ChangeLog'
warning: no files found matching 'GPL'
writing manifest file 'MySQL_python.egg-info/SOURCES.txt'
installing library code to build/bdist.macosx-10.6-universal/egg
running install_lib
running build_py
copying MySQLdb/release.py -> build/lib.macosx-10.6-universal-2.6/MySQLdb
running build_ext
building '_mysql' extension
gcc-4.2 -fno-strict-aliasing -fno-common -dynamic -DNDEBUG -g -fwrapv -Os -Wall -Wstrict-prototypes -DENABLE_DTRACE -arch i386 -arch ppc -arch x86_64 -pipe -Dversion_info=(1,2,3,'final',0) -D__version__=1.2.3 -I/usr/include/mysql -I/System/Library/Frameworks/Python.framework/Versions/2.6/include/python2.6 -c _mysql.c -o build/temp.macosx-10.6-universal-2.6/_mysql.o -fno-omit-frame-pointer -pipe
In file included from _mysql.c:36:
/usr/include/mysql/my_config.h:1030:2: warning: #warning defining SIZEOF_CHARP = 4
/usr/include/mysql/my_config.h:1044:2: warning: #warning defining SIZEOF_LONG = 4
/usr/libexec/gcc/powerpc-apple-darwin10/4.2.1/as: assembler (/usr/bin/../libexec/gcc/darwin/ppc/as or /usr/bin/../local/libexec/gcc/darwin/ppc/as) for architecture ppc not installed
Installed assemblers are:
/usr/bin/../libexec/gcc/darwin/x86_64/as for architecture x86_64
/usr/bin/../libexec/gcc/darwin/i386/as for architecture i386
In file included from _mysql.c:36:
/usr/include/mysql/my_config.h:1030:2: warning: #warning defining SIZEOF_CHARP = 4
/usr/include/mysql/my_config.h:1044:2: warning: #warning defining SIZEOF_LONG = 4
/usr/include/mysql/my_config.h:1151:1: warning: "WORDS_BIGENDIAN" redefined
In file included from /System/Library/Frameworks/Python.framework/Versions/2.6/include/python2.6/Python.h:8,
                 from pymemcompat.h:10,
                 from _mysql.c:29:
/System/Library/Frameworks/Python.framework/Versions/2.6/include/python2.6/pyconfig.h:1014:1: warning: this is the location of the previous definition
_mysql.c:2888: fatal error: error writing to -: Broken pipe
compilation terminated.
In file included from _mysql.c:36:
/usr/include/mysql/my_config.h:1027:2: warning: #warning defining SIZEOF_CHARP = 8
/usr/include/mysql/my_config.h:1041:2: warning: #warning defining SIZEOF_LONG = 8
lipo: can't open input file: /var/tmp//cchhckGP.out (No such file or directory)
error: command 'gcc-4.2' failed with exit status 1
  

Я занимаюсь этим уже несколько дней, и это начинает сводить меня с ума. Любая помощь была бы высоко оценена!

Комментарии:

1. WTF не работает с вашими CFLAGS? -arch i386 -arch ppc -arch x86_64 ? Это безумие!

2. Эти арки являются стандартными для системного Python 2.6 в OS X 10.6.

Ответ №1:

Вы обрекаете себя на головную боль, установив новую и перспективную, Xcode 4 а не последнюю версию Xcode 3 , с которой была выпущена Mac OS X 10.6. Непосредственная проблема, с которой вы сталкиваетесь, заключается в том, что Python пытается создать модули расширения C с той же конфигурацией, что и сам Python. Для версии 10.6 это включает в себя три архитектуры: i386 , x86_64 и ppc (для совместимости с программами, созданными на более ранних системах). По-видимому, Xcode 4 удалена поддержка построения ppc archs. Вы можете легко обойти эту проблему, используя ARCHFLAGS переменную среды, которая используется для переопределения параметров arch, используемых Distutils в Python при создании модулей расширения. Попробуйте сделать что-то подобное (непроверенное, поскольку у меня нет Xcode 4 под рукой):

 sudo bash
export ARCHFLAGS='-arch i386 -arch x86_64'
rm -r build
python setup.py build
python setup.py install
  

Лучшим решением, как рекомендовано в другом месте, является не пытаться установить MySQLdb на 10.6 с помощью системного Python и установщиков двоичных файлов MySQL. Скорее используйте комплексное решение, установив все через менеджер пакетов, такой как MacPorts.

Комментарии:

1. Сработало как по волшебству, спасибо миллион. Похоже, пришло время ознакомиться с компиляторами…

2. Удачи с этим! К сожалению, большая часть этого материала очень загадочна.

3. Спасибо, Нед. Это было занозой в моем боку с тех пор, как я перешел на OSX для разработки! Теперь виртуальная машина Ubuntu больше не нужна!

Ответ №2:

Есть другой способ, который я только что нашел для решения этой проблемы. Я столкнулся с той же проблемой, что и вы, и версия моего python 2.7.4 и Xcode 4. Возможно, вы только что получили 32-разрядный python, как и я. Итак, я изменил его на 2.7.5x64bit, тогда проблем быть не должно.