MacOS 下安裝mysqlclient 的問題及解決辦法


【操作環境】
操作系統: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命令,找到原來的文件,修改為可寫文件,進行修改后,為防止被不小修改,再設為只讀文件就好了。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM