溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

MySQL5.1.72編譯安裝的具體過程

發(fā)布時(shí)間:2020-05-08 10:12:45 來源:億速云 閱讀:232 作者:三月 欄目:數(shù)據(jù)庫

本文主要給大家簡(jiǎn)單講講MySQL5.1.72編譯安裝的具體過程,相關(guān)專業(yè)術(shù)語大家可以上網(wǎng)查查或者找一些相關(guān)書籍補(bǔ)充一下,這里就不涉獵了,我們就直奔主題吧,希望MySQL5.1.72編譯安裝的具體過程這篇文章可以給大家?guī)硪恍?shí)際幫助。

版本號(hào):5.1.72
OS:RHEL6.5
安裝方式:源碼編譯安裝
過程:
1. 訪問http://www.mysql.com/downloads/,選擇MySQL Community Server,Select Platform中選擇source code,下載Generic Linux下的mysql-5.1.72.tar.gz文件。
2. 上傳mysql-5.1.72.tar.gz到云服務(wù)器,解壓。
3. 進(jìn)入解壓得到的目錄里,在該路徑下運(yùn)行以下命令:

./configure --prefix=/usr/local/mysql \
--with-charset=utf8 \ 默認(rèn)字符集
--with-extra-charsets=all \ 安裝額外的字符集
--with-unix-socket-path=/share/data/mysql.sock \ 使用套接字
--with-named-curses-libs=/lib64/libncursesw.so.5

注:
1)需要事先安裝一些編譯需要的軟件:

yum install gcc gcc-c++ perl
yum install cmake

(從5.6.10開始,MySQL使用CMAKE替代了configure安裝方式,因此對(duì)于5.1.72來說,這個(gè)軟件包可能并不需要,待考證)

yum install ncurses-devel

(--with-named-curses-libs=/lib64/libncursesw.so.5 據(jù)說不指定該參數(shù),編譯安裝會(huì)失敗,該庫文件由ncurses-devel軟件包提供)
2)/share/data是我計(jì)劃放置數(shù)據(jù)庫的目錄,為了方便查找和啟用,這里將通信用的套接字目錄也指定到了這里。

3)(很關(guān)鍵)前幾次的編譯安裝結(jié)束后,我在登錄MySQL時(shí)出現(xiàn)了問題,提示段錯(cuò)誤 (Segmentation fault),后來在網(wǎng)上查找了一個(gè)方法,需要對(duì)源碼包中一個(gè)文件進(jìn)行修改并重新編譯安裝,之后再次登錄就沒有遇到這個(gè)錯(cuò)誤了:

1. 在源碼包里,編輯文件 cmd-line-utils/libedit/terminal.c
2. 找到代碼段類似 char buf[TC_BUFSIZE]; 的,將其注釋,并找到下面的變量 area = buf; 
將其更改為 area = NULL;
更正后的代碼類似:
865 protected int
866 terminal_set(EditLine *el, const char *term)
867 {
868 int i;
869 /*char buf[TC_BUFSIZE];*/
870 char *area;
871 const struct termcapstr *t;
872 sigset_t oset, nset;
873 int lins, cols;
874
875 (void) sigemptyset(&nset);
876 (void) sigaddset(&nset, SIGWINCH);
877 (void) sigprocmask(SIG_BLOCK, &nset, &oset);
878
879 area = NULL;
該方法來自http://www.111cn.net/database/mysql/79897.htm

4. make && make install
5. MySQL 5.1.72編譯安裝完成,接下來是啟動(dòng)MySQL服務(wù)和初始化數(shù)據(jù)庫:
建議使用系統(tǒng)用戶mysql來啟停mysql服務(wù),因此需要在操作系統(tǒng)中添加mysql用戶和mysql組,并將mysql安裝位置和數(shù)據(jù)庫存放位置的目錄屬主屬組修改為mysql:

chown -R mysql:mysql /usr/loca/mysql
chown -R mysql:mysql /share/data/

6. 進(jìn)入/usr/local/mysql/,進(jìn)行數(shù)據(jù)庫初始化操作:

/usr/local/mysql/bin/mysql_install_db \
--basedir=/usr/local/mysql/ \ prefix 
--datadir=/share/data/ \ 數(shù)據(jù)庫所在位置
--user=mysql \ 使用mysql用戶啟停mysql服務(wù)

7. 啟動(dòng)mysql服務(wù)

/usr/local/mysql/bin/mysqld_safe --basedir=/usr/local/mysql \
--datadir=/share/data \
--user=mysql &

8. 查看進(jìn)程和端口,驗(yàn)證是否安裝成功:

# /usr/local/mysql/bin/mysql -uroot -p
Enter password: \ 此時(shí)不需要輸入密碼
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.1.72 Source distribution
Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql>

出現(xiàn)提示符,安裝成功。

注:
1)進(jìn)入源碼所在目錄下的support-files目錄下,查找*.cnf名稱的文件,這是mysql提供的不同運(yùn)行環(huán)境的配置文件,拷貝一個(gè)合適的到/etc/下,命名為默認(rèn)的配置文件my.cnf:

cp ~/mysql-5.1.72/support-files/my-small.cnf /etc/my.cnf

有必要對(duì)/etc/init.d/mysqld中的相關(guān)變量值進(jìn)行修改或指定,如修改如下項(xiàng):

[client]
socket          = /share/data/mysql.sock
[mysqld]
socket          = /share/data/mysql.sock

2)該目錄下還有一個(gè)mysql.server文件,該文件是mysql提供的LSB腳本,可以將其拷貝到/etc/init.d/下,重命名為mysqld:

cp ~/mysql-5.1.72/support-files/mysql.server /etc/init.d/mysqld

有必要對(duì)/etc/init.d/mysqld中的相關(guān)變量值進(jìn)行修改或指定,如修改如下項(xiàng):

basedir=/usr/local/mysql/
datadir=/share/data/

后記:

1. 可以將datadir指定為共享目錄提供給多臺(tái)mysql云服務(wù)器來使用,此時(shí)只需在一臺(tái)機(jī)器上運(yùn)行mysql_install_db操作,其他云服務(wù)器即可以通過mysql服務(wù)進(jìn)行訪問。

2. 編譯安裝一次不成功很正常,多次嘗試終會(huì)成功。

MySQL5.1.72編譯安裝的具體過程就先給大家講到這里,對(duì)于其它相關(guān)問題大家想要了解的可以持續(xù)關(guān)注我們的行業(yè)資訊。我們的板塊內(nèi)容每天都會(huì)捕捉一些行業(yè)新聞及專業(yè)知識(shí)分享給大家的。


向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI