Django + MySQL в Mac OS 10.6.2 Snow Leopard
На этот вопрос уже было несколько отличных ответов, однако сейчас они устарели.
Я смог установить модуль, но "python manage.py runserver" не работает с
iMac:myproject drhoden$ python manage.py runserver
Validating models...
Unhandled exception in thread started by <function inner_run at 0x10496f0>
Traceback (most recent call last):
File "/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/site-packages/django/core/management/commands/runserver.py", line 48, in inner_run
self.validate(display_num_errors=True)
File "/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/site-packages/django/core/management/base.py", line 249, in validate
num_errors = get_validation_errors(s, app)
File "/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/site-packages/django/core/management/validation.py", line 22, in get_validation_errors
from django.db import models, connection
File "/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/site-packages/django/db/__init__.py", line 41, in <module>
backend = load_backend(settings.DATABASE_ENGINE)
File "/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/site-packages/django/db/__init__.py", line 17, in load_backend
return import_module('.base', 'django.db.backends.%s' % backend_name)
File "/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/site-packages/django/utils/importlib.py", line 35, in import_module
__import__(name)
File "/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/site-packages/django/db/backends/mysql/base.py", line 13, in <module>
raise ImproperlyConfigured("Error loading MySQLdb module: %s" % e)
django.core.exceptions.ImproperlyConfigured: Error loading MySQLdb module: dynamic module does not define init function (init_mysql)
^CiMac:segisys drhoden$
Аналогично, из оболочки Python:
iMac:myproject drhoden$ python
Python 2.6.4 (r264:75821M, Oct 27 2009, 19:48:32)
[GCC 4.0.1 (Apple Inc. build 5493)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> import MySQLdb
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "build/bdist.macosx-10.3-fat/egg/MySQLdb/__init__.py", line 19, in <module>
File "build/bdist.macosx-10.3-fat/egg/_mysql.py", line 7, in <module>
File "build/bdist.macosx-10.3-fat/egg/_mysql.py", line 6, in __bootstrap__
ImportError: dynamic module does not define init function (init_mysql)
>>>
Использование MySQL-python-1.2.3c1 с setuptools-0.6c11-py2.6.egg
Любая помощь будет оценена.
3 ответа
В конце концов, я решил свою собственную проблему, конечно же, с помощью подсознательной и сознательной помощи от многих постов, блогов и почтовых журналов, которые я прочитал. Я бы дал ссылки, если бы мог вспомнить.
Короче говоря, я переустановил все, используя MacPorts.
После редактирования ~/.bash_profile и комментирования всех предыдущих изменений в ${PATH}, я скачал dmg для Snow Leopard и провел его установку.
Затем открыл терминал и запустил самообновление.
sudo port selfupdate
sudo port install python26
Эта вторая часть, установка Python 2.6, заняла вечность. Но когда это закончилось, это побудило меня со следующим:
To fully complete your installation and make python 2.6 the default, please run
sudo port install python_select
sudo python_select python26
Я сделал оба, и они пошли быстро.
Я забыл упомянуть, насколько удобна команда 'port search '. Я искал "mysql" и тому подобное, чтобы найти то, что нужно напечатать после "install". Но я приступил к переустановке клиента и сервера для MySQL. Возможно, я сделал это в обратном порядке, но конечный результат работал нормально.
sudo port install mysql5
...
---> Installing mysql5 @5.1.41_0
The MySQL client has been installed.
If you also want a MySQL server, install the mysql5-server port.
Так естественно:
sudo port install mysql5-server
Мне нравится, что так много установок macports дают вам обратную связь относительно того, что делать дальше. В конце установки сервера было сказано следующее:
******************************************************
* In order to setup the database, you might want to run
* sudo -u _mysql mysql_install_db5
* if this is a new install
******************************************************
Это была новая установка для меня (не было никаких локальных схем). Для полноты и для собственного ознакомления, вот результат выполнения этой команды:
Installing MySQL system tables...
OK
Filling help tables...
OK
To start mysqld at boot time you have to copy
support-files/mysql.server to the right place for your system
PLEASE REMEMBER TO SET A PASSWORD FOR THE MySQL root USER !
To do so, start the server, then issue the following commands:
/opt/local/lib/mysql5/bin/mysqladmin -u root password 'new-password'
/opt/local/lib/mysql5/bin/mysqladmin -u root -h iMac.local password 'new-password'
Alternatively you can run:
/opt/local/lib/mysql5/bin/mysql_secure_installation
which will also give you the option of removing the test
databases and anonymous user created by default. This is
strongly recommended for production servers.
See the manual for more instructions.
You can start the MySQL daemon with:
cd /opt/local ; /opt/local/lib/mysql5/bin/mysqld_safe &
You can test the MySQL daemon with mysql-test-run.pl
cd /opt/local/mysql-test ; perl mysql-test-run.pl
Please report any problems with the /opt/local/lib/mysql5/bin/mysqlbug script!
The latest information about MySQL is available at http://www.mysql.com/
Support MySQL by buying support/licenses from http://shop.mysql.com/
Почти сделано. Ранее в моем поиске портов я наткнулся на этот интересный порт:
py26-mysql @ 1.2.2 (python, devel, database) Интерфейс Python для mysql
С большой надеждой, что это даст мне пакет MySQLdb, я установил его (и он сделал).
sudo port install py26-mysql
После слов я включил интерпретатор Python, который пытался импортировать MySQLdb, что все время было у меня на пути.
iMac:~ drhoden$ python
Python 2.6.4 (r264:75706, Dec 15 2009, 18:00:14)
[GCC 4.2.1 (Apple Inc. build 5646) (dot 1)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> import MySQLdb
/opt/local/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/site-packages/MySQLdb/__init__.py:34: DeprecationWarning: the sets module is deprecated from sets import ImmutableSet
>>>
Предупреждение, но это сработало!!
Еще одна вещь:
sudo port install py26-django
После всего этого я наконец смог запустить свой проект Django и удаленно подключиться к серверу MySQL моей компании!! Возможно, не было необходимости переустанавливать Django с помощью MacPorts, но я не собирался рисковать осложнениями.
Я написал сообщение в блоге несколько месяцев назад после моей успешной установки MySQL на Snow Leopard:
http://jboxer.com/2009/09/installing-mysql-on-snow-leopard/
Если вы выполните эти шаги, это (теоретически) должно исправить вашу проблему (которая, похоже, вызвана сочетанием 32-битного и 64-битного программного обеспечения).
Кстати, я не пытаюсь саморекламы здесь; текст в блоге - это то, что я бы опубликовал здесь, и я пытаюсь применить СУХОЙ к другим областям моей жизни:)
Это происходит, когда вы смешали 32 и 64-битное программное обеспечение.
В основном, для Snow Leopard вам необходимо установить 64-битный пакет MySQL (который по-прежнему указан как 10.5, но это не проблема), после чего снова выполните простую установку python-mysql. Все будет работать.