mysql在linux上的安裝之二(mysql源碼安裝),mysql源碼
1.下載相應的mysql安裝源碼包
地址為:http://dev.mysql.com/downloads/mysql/5.1.html
2.如果以前安裝過則卸載無用過舊的已安裝的mysql
由於很多linux發行版,都預裝了相應的mysql,一般都是rpm形式的安裝,且mysql的版本都是比較低的(這個可能是由於相容性測試的考慮吧)。因此在自己親自安裝mysql之前,請先卸載這些過舊的mysql,保證我們系統的“純淨”。
使用如下命令查詢系統中安裝的mysql:
rpm -qa|grep mysql
此命令會模糊比對軟體名有mysql的rpm安裝包,列出來的這些都可以把他們刪掉,一次性刪掉,可使用如下的一個指令碼命令:
for i in `rpm -qa | grep "mysql"`; do rpm -e --allmatches $i; done
執行完上面命令後,如果還有頑固分子沒有被刪除,那就一個一個利用下面的命令來刪除:
rpm -e --allmatches packet-name
如果發現循環相依性問題,那麼packet-name就列出這些循環相依性的安裝包,一次性全部刪除,如:
[root@test root]# rpm -e --allmatches mysql
安裝原始碼版本的MySQL
3.添加mysql使用者組
groupadd mysql
4.添加mysql使用者,並指定到mysql使用者組
useradd -g mysql mysql
5.解壓縮mysql-version.tar.gz
gunzip < mysql-VERSION.tar.gz | tar -xvf -
6.安裝mysql
cd mysql-VERSION
./configure --prefix=/usr/local/mysql --with-charset=gbk --with-extra-charsets=armscii8,ascii,big5,cp1250,cp1251,cp1256,cp1257,cp850,cp852,cp866,cp932,dec8,eucjpms,euckr,gb2312,gbk,geostd8,greek,hebrew,hp8,keybcs2,koi8r,koi8u,latin1,latin2,latin5,latin7,macce,macroman,sjis,swe7,tis620,ucs2,ujis,utf8 --with-plugins=innodb_plugin
make
make install
7.複製設定檔
shell> cp support-files/my-medium.cnf /etc/my.cnf
8.執行mysql系統資料庫初始化指令碼
cd /usr/local/mysql
bin/mysql_install_db --user=mysql
9.設定mysql安裝目錄許可權,設定owner為mysql
chown -R mysql var
chgrp -R mysql .
10.啟動mysql應用
/usr/local/mysql/bin/mysqld_safe --user=mysql &
11.設定root密碼(資料庫的DBA)
bin/mysqladmin -u root password ‘root’
12.登入mysql
bin/mysql -uroot -p
Enter password:
登入成功會看到:
Welcome to the MySQL monitor. Commands end with ; or g.
Your MySQL connection id is 229
Server version: 5.1.40-log MySQL Community Server (GPL)
Type ‘help;’ or ‘h’ for help. Type ‘c’ to clear the current input statement.
mysql>
這時mysql已經裝好了,可以查看資料庫了,但在正式使用資料庫開發與部署的時候還需要做一些工作:
1.設定設定檔my.cnf
按照需求copy my-***.cnf到/etc/my.cnf
2.修改預設字元集utf8
(1).[client]下加入default-character-set=utf8
(2).[mysqld]下加入default-character-set=utf8
#不改動儲存引擎的話,3、4步可以略過
3.啟動InnoDB引擎的方法如下:
1)關閉mysql的服務
2)修改my.ini
將default-storage-engine=INNODB前的注釋(#)去掉
將skip-innodb這行注釋(加上#)
4.配置innodb參數
1).找到# Uncomment the following if you are using InnoDB tables
去掉innodb_*下的所有#
2).如果安裝mysql的目錄不是預設的,則需要修改
# mysql 預設安裝目錄為 /usr/local/mysql/
# mysql 預設資料表空間目錄安裝目錄為 /usr/local/mysql/var/
innodb_data_home_dir=/usr/local/database/mysql/var/
innodb_log_group_home_dir=/usr/local/database/mysql/var/
3).儲存後重啟mysql服務。
5.設定系統服務
讓linux啟動的時候就啟動mysql服務
shell> cd /usr/local/mysql/
shell> cp support-files/mysql.server /etc/init.d/mysql
shell> chmod 777 /etc/init.d/mysql
shell> chkconfig --add mysql
shell> chkconfig --level 35 mysql on
6.重啟MySQL服務
shell> service mysql restart
目前最新版的mysql在Linux下源碼編譯安裝的方法具體參數的含義一併說明
有話好說,以下是CentOS Linux 5的配置經驗:
添加mysql帳號
groupadd mysql
useradd -r -g mysql mysql
編譯必需先安裝
cmake-2.8.4 和 bison-2.4.3
安裝成功後解壓mysql-5.5.15.tar.gz:
在源碼根目錄開啟終端輸入以下配置參數並斷行符號
cmake -DCMAKE_INSTALL_PREFIX=/etc/mysql \
-DMYSQL_UNIX_ADDR=/etc/mysql/mysql.sock \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_EXTRA_CHARSETS:STRING=utf8,gbk \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_MEMORY_STORAGE_ENGINE=1 \
-DWITH_READLINE=1 \
-DENABLED_LOCAL_INFILE=1 \
-DMYSQL_DATADIR=/var/mysql/data \
-DMYSQL_USER=mysql
成功執行以下命令後在最後會見到 (/root/Desktop/是你的源碼目錄,視你的情況定)
-- Build files have been written to: /root/Desktop/mysql-5.5.15
運行make安裝:
make
make install
以下步驟就不一一解說了:
cd /mysql/mysql
chown -R mysql:mysql .
scripts/mysql_install_db --user=mysql
chown -R root .
chown -R mysql data
cp ./support-files/my-small.cnf ./my.cnf
cp support-files/mysql.server mysql; chmod +x mysql
chown -R mysql:root .
./mysql start
./bin/mysqladmin -u root -p 123456
添加開機啟動服務
chkconfig --add mysql
chkconfig mysql on
service mysql start
順利的話到這裡完成了,祝你成功。
linux中源碼方式安裝mysql的時為何要先建一個mysql使用者
為了安全。。這樣做的好處是,當別人黑了你的資料庫的時候,只能得到系統的mysql許可權,還得不到整個root的許可權。。這樣。。就安全多了。。不僅僅是mysql,像apache,等很多軟體都有這樣的設定。。說明這樣的軟體是好軟體。。