1. 程式人生 > 資料庫 >Linux下安裝mysql的方式(yum和原始碼編譯兩種方式)

Linux下安裝mysql的方式(yum和原始碼編譯兩種方式)

這裡介紹Linux下兩種安裝mysql的方式:yum安裝和原始碼編譯安裝。

1. yum安裝

(1)首先檢視centos自帶的mysql是否被安裝:

# yum list installed |grep mysql 
//若有自帶安裝的mysql,將其解除安裝
# yum -y remove mysql-libs.x86_64

(2)下載MySQL官網的yum倉庫:https://dev.mysql.com/downloads/repo/yum/,

# yum localinstall mysql57-community-release-el6-11.noarch.rpm
//檢視yum倉庫是否成功新增
# yum repolist enabled |grep "mysql.*-community.*"

(3)使用mysql yum倉庫時,預設情況下選擇的最新版本進行安裝,也可以通過手動編輯檔案來選擇一個版本安裝。例如,要安裝mysql5.6版本,則再mysql56-community設定enabled=1,mysql57-community設定enabled=0。

# vim /etc/yum.repos.d/mysql-community.repo
[mysql57-community]
name=MySQL 5.7 Community Server
baseurl=http://repo.mysql.com/yum/mysql-5.7-community/el/6/$basearch/
enabled=0
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-mysql
# Enable to use MySQL 5.6
[mysql56-community]
name=MySQL 5.6 Community Server
baseurl=http://repo.mysql.com/yum/mysql-5.6-community/el/6/$basearch/
enabled=1
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-mysql

(4)安裝mysql

# yum install mysql-community-server

(5)啟動mysql服務

# service mysqld start

若出現下面輸出則表示mysql安裝成功:

Starting mysqld:[ OK ]

2. 原始碼編譯安裝mysql

(1)首先安裝原始碼編譯所需要的包

# yum -y install make gcc-c++ cmake bison-devel ncurses-devel

(2)下載並解壓安裝包

# wget http://cdn.mysql.com/Downloads/MySQL-5.6/mysql-5.6.14.tar.gz

# tar xvf mysql-5.6.14.tar.gz

(3)編譯安裝(編譯引數按實際情況制定)

# cd mysql-5.6.14
# 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
# make && make install

(4)配置mysql

設定許可權:

# useradd mysql
# passwd mysql 
# chown -R mysql:mysql /usr/local/mysql

初始化mysql:

# cd /usr/local/mysql
# scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --user=mysql

注意:在/etc目錄下會存在一個my.cnf,需要將此檔案更名為其他的名字,如:/etc/my.cnf.bak,否則,該檔案會干擾原始碼安裝的MySQL的正確配置,造成無法啟動。

(5)註冊為服務

# cd /usr/local/mysql/support-files
//註冊服務
# cp mysql.server /etc/rc.d/init.d/mysql
//使用預設配置檔案
# cp my-default.cnf /etc/my.cnf
//設定開機啟動
 # chkconfig mysql on

(6)啟動服務

# service mysql start 

3. mysql客戶端

首次進入mysql客戶端時,通常會出現這種錯誤:

解決方案如下:

(1)在/etc/my.cnf檔案中新增如下命令:

(2)重啟mysql服務之後,進入mysql客戶端修改root使用者的密碼:

update mysql.user set authentication_string=password("PASSWORD") where user="root";
flush privileges;

(3)將剛剛新增的那條命令註釋掉,在mysql客戶端重設密碼:

//設定密碼強度和長度
> set global validate_password_policy=0;
> set global validate_password_length=1;
// 更改密碼
> alter user 'root'@'localhost' identified by 'PASSWORD';

(4)若設定root使用者可以遠端訪問,還需執行:

> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'PASSWORD' WITH GRANT OPTION;
> flush privileges;

隨後就可以通過mysql客戶端建立資料庫、表這些了。

總結