程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> linux上源碼安裝MySQL詳解

linux上源碼安裝MySQL詳解

編輯:MySQL綜合教程

linux上源碼安裝MySQL詳解


最近需要使用MySQL Fabric,這貨是MySQL5.6.10之後才出現的utility。手頭機器裝的是MySQL5.1,所以需要先把舊版MySQL升級成5.6版本。之前沒有玩過MySQL,所以這次稍微費了點事。在此,把過程記錄下來,希望能給有需求的人提供一點幫助。下面我們就正式開始。

1. 刪除老版本MySQL

其實刪除老版MySQL是一件很簡單的事,但是開始時候由於擔心各個包的依賴會導致各種問題,亦步亦趨來得很慢。其實只需要做到這麼幾步就可以了:

1.1 查看已安裝的mysql版本並刪除

查看已安裝的mysql版本:rpm -qa | grep -i mysql

只要將client/server兩個rpm包卸載就可以,過程中可能會提示某個包的依賴,加上--nodeps即可。

1.2 刪除數據文件

刪除/etc/my.cnf以及安裝目錄/usr/local/mysql/(該目錄位置是安裝時指定的)下的數據文件。 rm -r /etc/my.cnf rm -rf /usr/local/mysql

1.3 查看當前是否有mysql在運行

這一步經常會被忽視掉,所以需要稍微注意下。若有則kill掉。使用命令:ps -fe | grep mysql查看。
經過上面的三個步驟,基本就可以把舊版mysql卸載掉了。其他遺留部分在後續安裝新版mysql時,會提示有不兼容的情況,到時候再逐個刪除即可。

2. 源碼安裝MySQL5.6

前提一:既然是源碼安裝,肯定要先下載一份MySQL源碼了。這個大家根據自己的需求下載,在此就不贅述了。前提二:安裝cmake。MySQL的編譯是使用的cmake,所以需要提前安裝好。這個過程也很簡單,就不說了。上面的准備工作都OK之後,就開始正式安裝的過程了。

2.1 編譯

與linux上其他的工程一樣,MySQL的編譯也就是make/make install。

2.1.1 cmake

在代碼路徑下執行:
cmake ./ -DCMAKE_INSTALL_PREFIX=/usr/local/mysql  \
-DMYSQL_DATADIR=/usr/local/mysql/data             \
-DSYSCONFDIR=/etc                                 \
-DWITH_MYISAM_STORAGE_ENGINE=1                    \
-DWITH_INNOBASE_STO…
上面的編譯參數,有幾個在後續的安裝過程中需要使用,在此說明一下。其他的可以不用管,直接復制即可。 DCMAKE_INSTALL_PREFIX:MySQL的安裝路徑,安裝完成後就是MySQL的工作路徑。
DMYSQL_DATADIR:MySQL的數據文件位置。
DSYSCONFDIR:MySQL的配置文件位置。

2.1.2 make && make install

這個用過linux的都知道吧。。到此,編譯的過程就完成了。

2.2 安裝

# cd /usr/local/mysql
# chown -R mysql:mysql .
# chown -R mysql:mysql ./data
# scripts/mysql_install_db --defaults-file=/etc/my.cnf
# cp support-files/my-default.cnf /etc/my.cnf
上面這些都是MySQL的配置過程,其中的路徑必須和上面cmake的參數保持一致。其中mysql的配置文件/etc/my.cnf需要注意,下面是我的配置文件,基本保持這樣就可以了。
[mysql]
socket = /tmp/mysqld.sock

[mysqld]
user = mysql
datadir = /usr/local/mysql/data
port=3306

2.3 啟動MySQL

有三種方法可以啟動MySQL,分別如下:
方法一:
# bin/mysqld_safe --defaults-file=/etc/my.cnf
方法二:
# bin/mysqld
方法三:
cp support-files/msql.server /etc/init.d/mysql
service mysql start
相信大家對第三種方法更熟悉,使用start|restart|stop來啟動/重啟/停止一個服務的操作,在linux中使用的十分廣泛。我也習慣使用這種方法,但是在使用過程中發現一個情況。使用service mysql start時,如果服務啟動失敗,基本不會有什麼錯誤log輸出,所以想判斷是什麼原因導致的啟動失敗就比較困難。這時候推薦使用方法二來啟動,它會將錯誤原因輸出,對於勘誤難說容易的多。 查看啟動是否成功:ps -ef | grep mysql

2.4 修改root密碼

# ./bin/mysqladmin -u root password
兩遍輸入密碼即可。修改完密碼之後,需要重啟一下mysql。到此,MySQL從老版本升級的過程就完成了。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved