【操作環境】
操作系統:MacOS X 10.13.1
mysql運行環境:Docker
Docker版本:17.09-ce
在開發Django時,剛開始使用的sqlite進行開發,想部署到生產環境需要連接到mysql上再跑一邊測試。
為了不破壞整機的文件環境,我使用了Docker運行了Mysql。並沒有通過源碼的方式或brew
命令來安裝mysql。
在剛運行Django 的 migrate
命令的時,便提示我不存在連接mysql的庫,叫我安裝mysqlclient。
順帶一提,mysqlclient 是Python3中的MySQLdb, 它實現了與MySQLdb相兼容的接口,可以完美的替代MySQLdb,並且不用對代碼做任何修改。
此時,我的電腦上沒有任何關於mysql的文件(除了Docker鏡像外)
運行 pip install mysqlclient
出現了下面的問題
Collecting mysqlclient
Using cached mysqlclient-1.3.12.tar.gz
Complete output from command python setup.py egg_info:
/bin/sh: mysql_config: command not found
Traceback (most recent call last):
File "<string>", line 1, in <module>
File "/private/var/folders/w2/xwm2lzmn55sfs0_s8gpxv5g00000gn/T/pip-build-y1_wya1q/mysqlclient/setup.py", line 17, in <module>
metadata, options = get_config()
File "/private/var/folders/w2/xwm2lzmn55sfs0_s8gpxv5g00000gn/T/pip-build-y1_wya1q/mysqlclient/setup_posix.py", line 44, in get_config
libs = mysql_config("libs_r")
File "/private/var/folders/w2/xwm2lzmn55sfs0_s8gpxv5g00000gn/T/pip-build-y1_wya1q/mysqlclient/setup_posix.py", line 26, in mysql_config
raise EnvironmentError("%s not found" % (mysql_config.path,))
OSError: mysql_config not found
大意便是說,我的系統中缺少了mysql_config文件。
於是我是用brew
安裝了mysql-connector-c ,安裝再次運行安裝mysqlclient的命令,相應的錯誤沒有了,但是卻出現了下面的錯誤
Collecting mysqlclient
Using cached mysqlclient-1.3.12.tar.gz
Complete output from command python setup.py egg_info:
Traceback (most recent call last):
File "<string>", line 1, in <module>
File "/private/var/folders/w2/xwm2lzmn55sfs0_s8gpxv5g00000gn/T/pip-build-59wqoy85/mysqlclient/setup.py", line 17, in <module>
metadata, options = get_config()
File "/private/var/folders/w2/xwm2lzmn55sfs0_s8gpxv5g00000gn/T/pip-build-59wqoy85/mysqlclient/setup_posix.py", line 54, in get_config
libraries = [dequote(i[2:]) for i in libs if i.startswith('-l')]
File "/private/var/folders/w2/xwm2lzmn55sfs0_s8gpxv5g00000gn/T/pip-build-59wqoy85/mysqlclient/setup_posix.py", line 54, in <listcomp>
libraries = [dequote(i[2:]) for i in libs if i.startswith('-l')]
File "/private/var/folders/w2/xwm2lzmn55sfs0_s8gpxv5g00000gn/T/pip-build-59wqoy85/mysqlclient/setup_posix.py", line 12, in dequote
if s[0] in "\"'" and s[0] == s[-1]:
IndexError: string index out of range
這個問題果然不是我一個人遇到的。在mysqlclient的issue上我找到了相應的解決辦法
Issue #169
即修改mysql_config中的下列內容
# Create options
libs="-L$pkglibdir"
libs="$libs -l "
修改為
# Create options
libs="-L$pkglibdir"
libs="$libs -lmysqlclient -lssl -lcrypto"
修改完后就能夠安裝mysqlclient了呢。
修改mysql_config文件可能會遇到的問題:
mysql_config文件不可寫。
在我的機器上,文件/usr/local/bin/mysql_config 為符號文件,通過ls命令,找到原來的文件,修改為可寫文件,進行修改后,為防止被不小修改,再設為只讀文件就好了。