描述:
- 最開始在測試環境裝了
mysql8
,用來作為airflow
后端的metadata
存儲; - 在裝了
mysql8
之后,通過pip3
安裝了mysqlclient=1.3.14
;但是安裝過程是在單獨的venv
環境中安裝的。系統的python3
環境中並沒有安裝該庫。 - 為了進行其他功能測試,將
mysql8
卸載,安裝了mysql5.7.28
。之后airflow運行不起來了,報錯:
libmysqlclient.so.21: cannot open shared object file: no such file or direct
- 刪除venv環境,重建venv環境,重新在venv環境中安裝
mysqlclient=1.3.14
,但是依然報錯。 - 在venv的lib庫根目錄下查看
mysqlclient
的so文件,確實找不到libmysqlclient.so.21
:
ldd /home/airflow/venv/lib64/python3.6/site-packages/_mysql.cpython-36m-x86_64-linux-gnu.so
linux-vdso.so.1 => (0x00007ffdb6db5000)
libmysqlclient.so.21 => not found
libpthread.so.0 => /lib64/libpthread.so.0 (0x00007f245a087000)
libm.so.6 => /lib64/libm.so.6 (0x00007f2459e03000)
librt.so.1 => /lib64/librt.so.1 (0x00007f2459bfb000)
libssl.so.10 => /usr/lib64/libssl.so.10 (0x00007f245998e000)
libcrypto.so.10 => /usr/lib64/libcrypto.so.10 (0x00007f24595a9000)
libdl.so.2 => /lib64/libdl.so.2 (0x00007f24593a5000)
libc.so.6 => /lib64/libc.so.6 (0x00007f2459010000)
/lib64/ld-linux-x86-64.so.2 (0x0000557c6a8b7000)
libgssapi_krb5.so.2 => /lib64/libgssapi_krb5.so.2 (0x00007f2458dcc000)
libkrb5.so.3 => /lib64/libkrb5.so.3 (0x00007f2458ae5000)
libcom_err.so.2 => /lib64/libcom_err.so.2 (0x00007f24588e0000)
libk5crypto.so.3 => /lib64/libk5crypto.so.3 (0x00007f24586b4000)
libz.so.1 => /lib64/libz.so.1 (0x00007f245849e000)
libkrb5support.so.0 => /lib64/libkrb5support.so.0 (0x00007f2458292000)
libkeyutils.so.1 => /lib64/libkeyutils.so.1 (0x00007f245808f000)
libresolv.so.2 => /lib64/libresolv.so.2 (0x00007f2457e75000)
libselinux.so.1 => /lib64/libselinux.so.1 (0x00007f2457c55000)
-
在網上搜
so.21
,發現該so文件是屬於mysql-community-libs-8.xxx
這個rpm包中包含的so文件。因此懷疑是我的mysql8沒有卸載干凈,比如一些頭文件沒有刪掉,在安裝mysqlclient
的時候,還是編譯了mysql8的so文件。 -
於是卸載所有mysql的rpm包,找到所有mysql目錄遺留文件刪除,再通過yum自動安裝
mysql-community-server
- 先安裝mysql的yum源
rpm -ivh https://dev.mysql.com/get/mysql80-community-release-el6-3.noarch.rpm
- 檢查yum源的repo,確保mysql5版本的源啟用,其他版本的處於禁用狀態,如果不對的話,使用
yum-config-manager --disable xxx
或者yum-config-manager --enable xxx
處理
yum repolist enabled | grep "mysql.*-community.*" yum repolist all | grep mysql
- 詳細操作內容看mysql官方文檔: Installing MySQL on Linux Using the MySQL Yum Repository
- 先安裝mysql的yum源
nohup yum install mysql-community-server &> ~/mysql-yum-install.log &
# tail ~/mysql-yum-install.log
已安裝:
mysql-community-server.x86_64 0:5.7.28-1.el6
作為依賴被安裝:
mysql-community-client.x86_64 0:5.7.28-1.el6
mysql-community-common.x86_64 0:5.7.28-1.el6
mysql-community-libs.x86_64 0:5.7.28-1.el6
沒有安裝mysql-community-devel-5.7.28-1.el6.x86_64
,要手動安裝下。
- 再重新刪除venv環境,重建venv環境,重新在venv環境中安裝
mysqlclient=1.3.14
,但是依然報錯。 - 但是在pip安裝mysqlclient的時候看到這樣的日志:
# pip install mysqlclient==1.3.14
Looking in indexes: http://pypi.douban.com/simple/
Processing /root/.cache/pip/wheels/e6/8e/61/fa14585dc24636befc6090deea404474d3c18acfa0e8685278/mysqlclient-1.3.14-cp36-cp36m-linux_x86_64.whl
Installing collected packages: mysqlclient
Successfully installed mysqlclient-1.3.14
這個whl居然是從cache中讀取的。。。
- 找到cache中的文件,copy出來解壓,發現一個so
# find /root/.cache/ -name 'mysqlclient*'
/root/.cache/pip/wheels/e6/8e/61/fa14585dc24636befc6090deea404474d3c18acfa0e8685278/mysqlclient-1.3.14-cp36-cp36m-linux_x86_64.whl
cp /root/.cache/pip/wheels/e6/8e/61/fa14585dc24636befc6090deea404474d3c18acfa0e8685278/mysqlclient-1.3.14-cp36-cp36m-linux_x86_64.whl ~
cd ~; tar zxvf mysqlclient-1.3.14-cp36-cp36m-linux_x86_64.whl
Archive: mysqlclient-1.3.14-cp36-cp36m-linux_x86_64.whl
inflating: _mysql.cpython-36m-x86_64-linux-gnu.so
inflating: _mysql_exceptions.py
inflating: MySQLdb/__init__.py
inflating: MySQLdb/compat.py
inflating: MySQLdb/connections.py
inflating: MySQLdb/converters.py
inflating: MySQLdb/cursors.py
inflating: MySQLdb/release.py
inflating: MySQLdb/times.py
inflating: MySQLdb/constants/CLIENT.py
inflating: MySQLdb/constants/CR.py
inflating: MySQLdb/constants/ER.py
inflating: MySQLdb/constants/FIELD_TYPE.py
inflating: MySQLdb/constants/FLAG.py
inflating: MySQLdb/constants/REFRESH.py
inflating: MySQLdb/constants/__init__.py
inflating: mysqlclient-1.3.14.dist-info/LICENSE
inflating: mysqlclient-1.3.14.dist-info/METADATA
inflating: mysqlclient-1.3.14.dist-info/WHEEL
inflating: mysqlclient-1.3.14.dist-info/top_level.txt
inflating: mysqlclient-1.3.14.dist-info/RECORD
# ldd _mysql.cpython-36m-x86_64-linux-gnu.so
linux-vdso.so.1 => (0x00007ffdb572d000)
libmysqlclient.so.21 => not found
libpthread.so.0 => /lib64/libpthread.so.0 (0x00007f5e71a4e000)
libm.so.6 => /lib64/libm.so.6 (0x00007f5e717ca000)
librt.so.1 => /lib64/librt.so.1 (0x00007f5e715c2000)
libssl.so.10 => /usr/lib64/libssl.so.10 (0x00007f5e71355000)
libcrypto.so.10 => /usr/lib64/libcrypto.so.10 (0x00007f5e70f70000)
libdl.so.2 => /lib64/libdl.so.2 (0x00007f5e70d6c000)
libc.so.6 => /lib64/libc.so.6 (0x00007f5e709d7000)
/lib64/ld-linux-x86-64.so.2 (0x000055d1e0f27000)
libgssapi_krb5.so.2 => /lib64/libgssapi_krb5.so.2 (0x00007f5e70793000)
libkrb5.so.3 => /lib64/libkrb5.so.3 (0x00007f5e704ac000)
libcom_err.so.2 => /lib64/libcom_err.so.2 (0x00007f5e702a7000)
libk5crypto.so.3 => /lib64/libk5crypto.so.3 (0x00007f5e7007b000)
libz.so.1 => /lib64/libz.so.1 (0x00007f5e6fe65000)
libkrb5support.so.0 => /lib64/libkrb5support.so.0 (0x00007f5e6fc59000)
libkeyutils.so.1 => /lib64/libkeyutils.so.1 (0x00007f5e6fa56000)
libresolv.so.2 => /lib64/libresolv.so.2 (0x00007f5e6f83c000)
libselinux.so.1 => /lib64/libselinux.so.1 (0x00007f5e6f61c000)
- 確鑿無疑,是因為pip緩存了mysql8時候的庫文件導致的,刪除pip的cache,再重新安裝。
# find /root/.cache/ -name 'mysqlclient*' -print -delete
/root/.cache/pip/wheels/e6/8e/61/fa14585dc24636befc6090deea404474d3c18acfa0e8685278/mysqlclient-1.3.14-cp36-cp36m-linux_x86_64.whl
# pip uninstall mysqlclient==1.3.14
Uninstalling mysqlclient-1.3.14:
Would remove:
/home/airflow/venv/lib/python3.6/site-packages/MySQLdb/*
/home/airflow/venv/lib/python3.6/site-packages/_mysql.cpython-36m-x86_64-linux-gnu.so
/home/airflow/venv/lib/python3.6/site-packages/_mysql_exceptions.py
/home/airflow/venv/lib/python3.6/site-packages/mysqlclient-1.3.14.dist-info/*
Proceed (y/n)? y
Successfully uninstalled mysqlclient-1.3.14
# pip install mysqlclient==1.3.14
Looking in indexes: http://pypi.douban.com/simple/
Collecting mysqlclient==1.3.14
Downloading http://pypi.doubanio.com/packages/f7/a2/1230ebbb4b91f42ad6b646e59eb8855559817ad5505d81c1ca2b5a216040/mysqlclient-1.3.14.tar.gz (91kB)
|████████████████████████████████| 92kB 4.6MB/s
Installing collected packages: mysqlclient
Running setup.py install for mysqlclient ... done
Successfully installed mysqlclient-1.3.14
- 再重新檢查venv下的庫文件,果然依賴問題已經解決。
# ldd /home/airflow/venv/lib64/python3.6/site-packages/_mysql.cpython-36m-x86_64-linux-gnu.so
linux-vdso.so.1 => (0x00007ffc6efff000)
libmysqlclient.so.20 => /usr/lib64/mysql/libmysqlclient.so.20 (0x00007f7dc8f0d000)
libpthread.so.0 => /lib64/libpthread.so.0 (0x00007f7dc8cf0000)
libm.so.6 => /lib64/libm.so.6 (0x00007f7dc8a6b000)
librt.so.1 => /lib64/librt.so.1 (0x00007f7dc8863000)
libdl.so.2 => /lib64/libdl.so.2 (0x00007f7dc865f000)
libc.so.6 => /lib64/libc.so.6 (0x00007f7dc82ca000)
libstdc++.so.6 => /usr/lib64/libstdc++.so.6 (0x00007f7dc7fc4000)
libgcc_s.so.1 => /lib64/libgcc_s.so.1 (0x00007f7dc7dae000)
/lib64/ld-linux-x86-64.so.2 (0x00005557f93df000)
- 注意 操作過程請先source到venv下