題外話:這是一篇教程貼,不僅學的是mysql的編譯,還是一些編譯的知識.我也是一個菜鳥,寫一些感悟和心得,有什么問題可以批評指正,謝謝!
如果只是為了安裝請移到我的另一篇安裝貼: Mysql安裝貼
環境:
OS: CentOS 6.6x64 mini
mysql: mysql-5.6.25
1. mysql 下載:
http://dev.mysql.com/downloads/mysql/
說明:這個網站有時候JS被牆,你選擇了Source Code會沒有反應,所以可以考慮翻翻翻翻翻翻Q或者直接點下邊的鏈接
下載地址: http://cdn.mysql.com/Downloads/MySQL-5.6/mysql-5.6.27.tar.gz
2.安裝:
☆ 禁掉selinx
★ 使用下邊命令獲取selinux:
[root@centos ~]# getenforce
Disabled
Disabled 已經禁用了,可以跳過這步了
Enforcing 開啟狀態
Permissive 臨時禁用
★ 使用下邊命令禁用selinux (第一條臨時禁用,第二條永久禁用)
[root@centos ~]# setenforce 0 [root@centos ~]# sed -i 's/SELINUX=enforcing/SELINUX=disabled/' /etc/selinux/config
★ 檢查下是否修改正確
[root@centos ~]# getenforce Permissive [root@centos ~]# cat /etc/selinux/config
確認里邊 SELINUX=disabled (selinux配置文件一定要確保修改正確,如果錯誤系統就無法正常啟動.)
☆ 創建mysql賬戶
groupadd mysql
useradd -g mysql mysql
☆ 依賴包
yum install cmake wget gcc -y
Cmake: 因為mysql 5.6支持cmake安裝所以我們采用cmake安裝.
wget是linux下載工具,下邊就是下載mysql源碼包(下載到當前目錄下)
[root@centos ~]# wget http://101.44.1.118/files/90110000038859AB/nchc.dl.sourceforge.net/project/mysql.mirror/MySQL%205.6.25/mysql-5.6.25.tar.gz
☆ 解壓mysql源碼包,並進入到解壓目錄
[root@centos ~]# tar xvf mysql-5.6.25.tar.gz [root@centos ~]# cd mysql-5.6.25
☆ 配置
cmake \ -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ -DMYSQL_DATADIR=/usr/local/mysql/data \ -DSYSCONFDIR=/etc \ -DWITH_MYISAM_STORAGE_ENGINE=1 \ -DWITH_INNOBASE_STORAGE_ENGINE=1 \ -DWITH_MEMORY_STORAGE_ENGINE=1 \ -DWITH_READLINE=1 \ -DMYSQL_UNIX_ADDR=/var/lib/mysql/mysql.sock \ -DMYSQL_TCP_PORT=3306 \ -DENABLED_LOCAL_INFILE=1 \ -DWITH_PARTITION_STORAGE_ENGINE=1 \ -DEXTRA_CHARSETS=all \ -DDEFAULT_CHARSET=utf8 \ -DDEFAULT_COLLATION=utf8_general_ci
-DCMAKE_INSTALL_PREFIX= 指向mysql安裝目錄(安裝在哪里)
-DMYSQL_DATADIR= mysql的數據目錄
-DSYSCONFDIR= Mysql的配置文件(配置文件放哪里)
這里配置會出錯,請移步后邊的廢話部分,帶你裝逼帶你飛..
☆ 編譯並安裝(過程比較長,耐心等待)
make make install
在群里發現很多人在編譯的時候容易出錯,而且配置編譯完了也不能確定到底有沒有操作成功.雖然下文我有解釋,但是我還是要提一下linux下有個$?.. 執行完了不確定緊接着執行:echo $?
如果返回 0 說明上條命令執行成功,非0的任意數代表有錯誤.
★ 進入到mysql的安裝目錄
[root@centos ~]#cd /usr/local/mysql
★ 設置權限
chown -R mysql . chgrp -R mysql .
★ 初始化數據庫
scripts/mysql_install_db --user=mysql
★ 設置權限
chown -R root . chown -R mysql data
★ 啟動數據庫
bin/mysqld_safe --user=mysql &
很多朋友會說寫個mysql的啟動腳本,干嘛要自己寫,mysql已經提供了:
cp support-files/mysql.server /etc/init.d/mysql.server
這樣就可以了 service mysql.server start
☆ 修改$PATH
$PATH是什么?很多人都不清楚,到底做什么的?這里簡短的說一下,$PATH就是執行文件路徑的變量,當我們執行一個指令的時候,[mysql],系統會依據PATH的設定去每個PATH定義的目錄下搜尋文件名為mysql的可執行文件.如果在 PATH 定義的目錄中含有多個文件名為 ls 的可執行文件, 那么先搜尋到的同名文件先被執行!
[root@centos ~]#which mysql
/usr/bin/which: no mysql in()
沒有找到這個mysql從哪里找就是從PATH加載的這么多目錄里邊去找.
[root@centos ~]#echo $PATH
/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin
這個是系統定義好的PATH目錄:
[root@centos ~]#sed -i '/export PATH/i\\PATH=$PATH:/usr/local/mysql/bin' .bash_profile
[root@centos ~]#source .bash_profile
直接將/usr/local/mysql/bin追加到PATH后邊,我使用sed,為了新手,如果你用vi可以自行編輯..
這樣就可以使用mysql
[root@centos ~]#which mysql
/usr/local/mysql/bin/mysql
教程篇,就得有廢話...廢話開始:
源碼的安裝就在編譯這里,配置編譯,配置什么?怎么配置?如何獲取,最好的方法就是官方文檔,配置就是擴展一些功能,官方文檔有解釋每一個配置項的作用和默認是否被配置進去.還有就是源碼包里有個INstall-Source.txt.寫的很詳細有幾千行,在5000多行的地方<2.9 Installing MySQL from Source>有說如何安裝...
配置是配置,編譯是編譯.安裝是安裝. 配置是用的cmake,編譯是make..安裝是make install.得確保每一步操作成功,進行下一步操作,怎么確認?看配置結束的提示,或者配置結束完緊接着輸入echo $? 如果返回0 就說明操作成功了,非零就是有問題.
編譯不一定能保證100%不出問題,教程貼就是教你改怎么編譯,說一些自己的心得.其他的錯誤就得靠經驗了,沒有辦法把整個錯誤都列出來.
如果你按我操作的步驟肯定編譯會出錯:
錯誤信息的部分:
CMake Error: your C compiler: "CMAKE_C_COMPILER-NOTFOUND" was not found. Please set CMAKE_C_COMPILER to a valid compiler path or name.
CMake Error: your CXX compiler: "CMAKE_CXX_COMPILER-NOTFOUND" was not found. Please set CMAKE_CXX_COMPILER to a valid compiler path or name.
其實看出來是C的問題了,C是干嘛的?這個就要增加自己的知識儲備了,如果不確定自己復制百度下,多看看解決方法:
yum install gcc -y
再來(再次執行CMake),裝完發現第二個Cxx的報錯沒有解決.那就是C++的問題了
yum install gcc-c++
再執行,發現上邊的錯誤沒有了,但是又有新的錯誤了
關鍵字:no suitable type found 百度百度
yum install ncurses-devel
問題沒解決,后來發現是刪除CMakeCache.txt 巨汗...
rm -rf CMakeCache.txt
重新執行Cmake的命令
編譯慢慢等..
中間有很多 found, not found
就是說有些依賴找到了,有些依賴沒有被找到.如果沒有報錯說明都不是致命的錯誤,可以以后某些功能沒裝上(沒有裝上怎么不辦?重新配置編譯安裝加上自己需要的功能,這些功能需要裝什么可以看官方文檔,或者網上找找..)
接下來編譯:
make
安裝:
make install
確定執行成功,返回到配置Mysql,接着配置Mysql
好了到這里了,有什么錯誤的地方,有什么問題可以提出來...
順便貼上網上找到配置項的解釋:
-DCMAKE_INSTALL_PREFIX= 指向mysql安裝目錄
-DINSTALL_SBINDIR=sbin 指向可執行文件目錄(prefix/sbin)
-DMYSQL_DATADIR=/var/lib/mysql 指向mysql數據文件目錄(/var/lib/mysql)
-DSYSCONFDIR=/etc/mysql 指向mysql配置文件目錄(/etc/mysql)
-DINSTALL_PLUGINDIR=lib/mysql/plugin 指向插件目錄(prefix/lib/mysql/plugin)
-DINSTALL_MANDIR=share/man 指向man文檔目錄(prefix/share/man)
-DINSTALL_SHAREDIR=share 指向aclocal/mysql.m4安裝目錄(prefix/share)
-DINSTALL_LIBDIR=lib/mysql 指向對象代碼庫目錄(prefix/lib/mysql)
-DINSTALL_INCLUDEDIR=include/mysql 指向頭文件目錄(prefix/include/mysql)
-DINSTALL_INFODIR=share/info 指向info文檔存放目錄(prefix/share/info)
prefix官方推薦設為/usr
Storage Engine相關
類型csv,myisam,myisammrg,heap,innobase,archive,blackhole
若想啟用某個引擎的支持:-DWITH_<ENGINE>_STORAGE_ENGINE=1
如:
-DWITH_INNOBASE_STORAGE_ENGINE=1
-DWITH_ARCHIVE_STORAGE_ENGINE=1
-DWITH_BLACKHOLE_STORAGE_ENGINE=1
若想禁用某個引擎的支持:-DWITHOUT_<ENGINE>_STORAGE_ENGINE=1
如:
-DWITHOUT_EXAMPLE_STORAGE_ENGINE=1
-DWITHOUT_FEDERATED_STORAGE_ENGINE=1
-DWITHOUT_PARTITION_STORAGE_ENGINE=1
Library相關
-DWITH_READLINE=1 啟用readline庫支持(提供可編輯的命令行)
-DWITH_SSL=system 啟用ssl庫支持(安全套接層)
-DWITH_ZLIB=system 啟用libz庫支持(zib、gzib相關)
-DWTIH_LIBWRAP=0 禁用libwrap庫(實現了通用TCP包裝的功能,為網絡服務守護進程使用)
-DMYSQL_TCP_PORT=3306 指定TCP端口為3306
-DMYSQL_UNIX_ADDR=/tmp/mysqld.sock 指定mysql.sock路徑
-DENABLED_LOCAL_INFILE=1 啟用本地數據導入支持
-DEXTRA_CHARSETS=all 啟用額外的字符集類型(默認為all)
-DDEFAULT_CHARSET=utf8 指定默認的字符集為utf8
-DDEFAULT_COLLATION=utf8_general_ci 設定默認排序規則(utf8_general_ci快速/utf8_unicode_ci准確)
-DWITH_EMBEDDED_SERVER=1 編譯嵌入式服務器支持
-DMYSQL_USER=mysql 指定mysql用戶(默認為mysql)
-DWITH_DEBUG=0 禁用debug(默認為禁用)
-DENABLE_PROFILING=0 禁用Profiling分析(默認為開啟)
-DWITH_COMMENT='string' 一個關於編譯環境的描述性注釋