在 CentOS 下安裝軟體,可以使用 rpm軟體包、yum工具、自行下載源代碼進行編譯安裝,其中編譯安裝的定製性較高 對於一些在軟體,自行下載源代碼進行編譯安裝較為方便 程式:源代碼 --> 編譯 --> 鏈接 --> 運行 執行編譯安裝步驟: 獲取源代碼並解壓 在解壓完的源代碼目錄下執行 con ...
在 CentOS 下安裝軟體,可以使用 rpm軟體包、yum工具、自行下載源代碼進行編譯安裝,其中編譯安裝的定製性較高
對於一些在軟體,自行下載源代碼進行編譯安裝較為方便
程式:源代碼 --> 編譯 --> 鏈接 --> 運行
執行編譯安裝步驟:
- 獲取源代碼並解壓
#tar xf xxx.tar.gz //或者: #tar xf xxx.tar.bz2
- 在解壓完的源代碼目錄下執行 configure 腳本
#./configure [options] 選項: --help 查看該腳本幫助信息,各個軟體的選項存在差異,下麵是通常情況下 --prefix=PATH 定義應用程式的安裝路徑,--prefix=/usr/local/APP_NAME --sbin-path=PATH 定義應用程式的二進位命令的路徑 --conf-path=PATH 定義應用程式配置文件路徑,--conf-path=/etc/APP_NAME --enable-XXXX 開啟某項功能(XXXX),應用程式支持該功能,但預設不安裝 --disable--XXXX 關閉某項功能(XXXX),應用程式支持該功能,預設安裝,但用戶不需要 --with--XXXX 開啟某項功能(XXXX),應用程式支持該功能,但預設不安裝 --without--XXXX 關閉某項功能(XXXX),應用程式支持該功能,預設安裝,但用戶不需要
如果 ./configure 時遇到依賴性的錯誤信息,可以用下列方法解決
- 用 without 關閉該項功能(不推薦)
- 安裝所需的環境,安裝所需的環境的 devel 包
- make:定義 Makefile 按照哪種順序去編譯源程式
make -j N 多個線程一起編譯,N為線程數量,make會自動按照當前目錄下makefile文件中的編譯順序對文件進行編譯
- make install:安裝應用程式
make install
編譯安裝完成後的工作:
- 添加所安裝的應用程式命令文件到系統路徑:(把應用程式的命令文件添加的 PATH 變數中)
第一種方法:在 /etc/bin 目錄下做命令文件( bin 文件)的鏈接
#ln -s /usr/local/APP_NAME/bin/* /usr/bin //為所有文件做鏈接,會產生大量的inode節點,不推薦 //或者: #ln -s /usr/local/APP_NAME/bin /usr/bin/APP_ANME //為目錄做鏈接
第二種方法:修改 /etc/profile 文件中的PATH變數( /etc/profile 文件在 shell 啟動時會自動執行)
#vim /etc/profile export PATH="$PATH:/APP_PATH" //在文末後面加上該行語句 #source /etc/profile //重新載入該文件,使修改生效
第三種方法:在 /etc/profile.d/ 目錄中建立 .sh 文件(在 /etc/profile.d 目錄中存放的是一些應用程式所需的啟動腳本,會被自動執行)
#vim /etc/profile.d/APP_NAME.sh PATH=$PATH:/usr/local/APP_NAME/bin //重啟,使修改生效
- 添加所安裝的應用程式庫文件到系統庫文件路徑( /usr/lib 或 /usr/lib64 )中
第一種方法:為庫文件做鏈接文件( lib對於32bits系統,lib64對應64bits系統 )
#ln -s /usr/local/APP_NAME/lib/* /usr/lib //或: #ln -s /usr/local/APP_NAME/lib /usr/lib/APP_NAME
第二種方法:在 /etc/ld.so.conf.d 目錄下建立 APP_NAME.conf,把應用程式的庫文件位置添加進去( /etc/ld.so.conf.d 用來載入 Linux 系統中的動態庫文件的 )
#ldconfig -v: 載入修改後的配置,使之生效,並顯示載入庫文件過程,可以查看添加的應用程式庫文件能否被成功載入
- 添加應用程式的頭文件到系統頭文件路徑( /usr/include ):
做鏈接文件
#ln -s /usr/local/APP_NAME/include/* /usr/include //或: #ln -s /usr/local/APP_NAME/include /usr/include/APP_NAME
- 添加應用程式的幫助信息
第一種方法:使用 man 時指定幫助信息文件的路徑
man -M APP_PATH bin_name //-M指定幫助信息的位置
第二種方法:修改man配置文件( CentOS7 下man配置文件:/etc/amn_db.conf )
#vim /etc/man_db.conf MANPATH_MAP APP_PATH(命令所在的路徑) HELP_PATH(幫助信息文件的路徑) //在對應的位置添加該行信息
重啟,使修改生效
舉例:在CentOS7下安裝Python3
在CentOS7下預裝的Python版本還是python2
#python -V //查看python版本
下載wget工具
#yum -y install wget
下載python3源代碼包( wget download_url,即可以把down_url鏈接對應的資源下載到當前目錄下)
在Python官網源代碼包下載頁面( https://www.python.org/downloads/source/ )可以找對應源代碼包的下載鏈接
#wget https://www.python.org/ftp/python/3.7.0/Python-3.7.0b3.tgz
對python3的源代碼包進行解壓
#tar xf Python-3.7.0b3.tgz
如果tar文件沒有報錯,就進入解壓得到的源代碼目錄里;如果報錯,可能是python源代碼包下載不完整導致的,建議重新下載,或者更換下載鏈接
#cd Python-3.7.0b3 # ls // aclocal.m4 configure.ac install-sh Mac Objects Programs setup.py // config.guess Doc Lib Makefile.pre.in Parser pyconfig.h.in Tools // config.sub Grammar LICENSE Misc PC Python // configure Include m4 Modules PCbuild README.rst //可以看到有可執行文件configure,沒有makefie文件 //可以通過./configure --help查看該軟體源代碼configure的幫助信息
安裝編譯
#./configure --prefix=/usr/local/python3 //把python3安裝到/usr/local/python3目錄下 //執行./configure後可以ls,發現在當前目錄下已經生成Makefile文件 #make -j 20 //可以省略Makefile,因為make會自動尋找該目錄下的Makefile或makefile文件進行編譯 #make install //安裝python3 //發現報錯: // zipimport.ZipImportError: can't decompress data; zlib not available // make: *** [install] Error 1 //原因是依賴性問題,下載zlibr軟體包和zlib的devel包 #yum -y install zlib zlib-devel #make install //重試 //發現又報錯: //ModuleNotFoundError: No module named '_ctypes' //原因是3.7版本需要一個新的包libffi-devel #yum install libffi-devel -y #make install //重試 //successfully installed pip-9.0.3 setuptools-39.0.1 成功安裝
安裝完後的配置
bin文件:
#vim /etc/profile.d/python3.sh PATH=$PATH:/usr/local/python3/bin //重啟,使修改生效
庫文件:
#vim /etc/ld.so.conf.d/python.conf /usr/local/python #ldconfig -v //載入修改後的配置,並檢查python3庫文件是否被載入進去
頭文件:
#ln -s /usr/local/python3/include /usr/include/python3 //為庫文件做鏈接
幫助信息:
#vim /etc/man_db.conf MANPATH_MAP /usr/local/python3/bin /usr/local/python3/share/man //重啟,使修改生效
檢測:
#vim test.py #!/usr/bin/env python3 print("test successful!") #chmod +x test.py #./test.py >>>test successful!