FAQ1:在使用pip3安裝庫的時候,提示需要升級pip
pip3 install --upgrade pip
FAQ2:在建立軟連結時,提示:ln: failed to create symbolic link ‘/usr/bin/python3’: File exists
我們可以在引數中加個 f,做強制建立
ln -sf /huyang/python395/bin/python3.9 /usr/bin/python3
FAQ3:在執行 django3 專案時,執行不起來,總是提示:DJANGO.CORE.EXCEPTIONS.IMPROPERLYCONFIGURED: SQLITE 3.9.0 OR LATER IS REQUIRED (FOUND 3.7.17).
centos預設安裝的 SQLite 是 2.x 版本的,但是django要求是大於 3.9.0 版本的,所以會跑不起來。
這個是個比較頭疼的問題,但是有兩種解決方法:
方法一:升級centos的sqlite版本,目前這個方法,我還沒徹底解決,ps:升級centos的sqlite後,從Python3匯入的還是 2.x 版本。這個問題留待以後研究。
這個方法雖然還沒有解決,但是可以先記錄下安裝centos的sqlite
1.建立資料夾,並進入資料夾 mkdir -p /usr/local/sqlite && cd /usr/local/sqlite 2.下載sqlite wget wget https://www.sqlite.org/2021/sqlite-autoconf-3350500.tar.gz 3.解壓,並進入解壓後的資料夾 tar -zxvf sqlite-autoconf-3350500.tar.gz && cd sqlite-autoconf-3350500 4.設定配置檔案,安裝位置 ./configure --prefix=/usr/local/sqlite 5.編譯+安裝 make && make install 6.將之前的sqlite連結做個備份,然後建立軟連結 mv /usr/bin/sqlite3 /usr/bin/sqlite3.bak ln -sf /usr/local/sqlite/bin/sqlite3 /usr/bin/sqlite3 7.配置環境變數,並生效 export LD_LIBRARY_PATH = "/usr/local/lib" source ~/.bashrc 8.檢查sqlite版本 sqlite3 --version
方法二:使用pysqlite替換sqlite,這個方法就比較簡單了,下面就講一下這個方法
這個方法是不依賴系統的 sqlite ,而是使用 pysqlite3 和
pysqlite3-binary 來操作
1.先安裝這兩個庫
pip3 install pysqlite3
pip3 install pysqlite3-binary
2.修改 base.py 檔案
vi /huyang/python395/lib/python3.9.5/site-packages/django/db/backends/sqlite3/base.py
# from sqlite3 import dbapi2 as Database (註釋掉這段)
from pysqlite3 import dbapi2 as Database # 啟用pysqlite3
然後按 ESC ,輸入 :wq!,儲存退出檔案
然後在執行專案,就可以正常執行了。
FAQ4:在安裝Python庫的時候,提示:ModuleNotFoundError: No module named '_ctypes'
需要安裝 libffi-devel ,然後重新編譯安裝Python
yum install libffi-devel -y cd Python-3.9.5 make install