1. 程式人生 > >Centos7 二進位制安裝mysql5.7

Centos7 二進位制安裝mysql5.7

安裝環境

系統版本:CentOS Linux release 7.5.1804 (Core)

Mysql版本:5.7.24

關閉防火牆並禁止開機自啟

systemctl stop firewalld.service
systemctl disable firewalld

關閉selinux

sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/sysconfig/selinux

重啟 reboot

安裝mysql

1、解除安裝自帶資料庫mariadb

rpm -qa | grep mariadb

rpm -e --nodeps mariadb-libs-5.5.56-2.el7.x86_64

2、規劃安裝路徑

basedir=/usr/local/mysql
datadir=/var/lib/mysql/data
socket=/var/lib/mysql/mysql.sock
log-error=/var/lib/mysql/mysql.log
pid-file=/var/lib/mysql/mysql.pid

3、上傳下載好的二進位制mysql包

注:方式不限,上傳即可!

4、解壓

tar xf mysql-5.7.24-el7-x86_64.tar

注:解壓檔案有兩個,我們使用的是mysql-5.7.24-el7-x86_64.tar.gz

5、繼續解壓mysql

tar xf mysql-5.7.24-el7-x86_64.tar.gz

6、移動解壓包並重命名為mysql

mv mysql-5.7.24-el7-x86_64 /usr/local/mysql

7、新增使用者和組

groupadd mysql

useradd -g mysql mysql

8、建立mysql配置檔案

vi /etc/my.cnf

[mysqld]
user= mysql
port= 3306
socket= /tmp/mysql.sock
basedir=/usr/local/mysql
datadir=/var/lib/mysql/data
log-error=/var/lib/mysql/mysql.log
pid-file=/var/lib/mysql/mysql.pid
character-set-server=utf8
collation-server=utf8_bin

注:從5.7.18開始support-files就沒有my.cnf的模板了,所以要自己寫了配置檔案!

9、建立資料目錄

mkdir -p /var/lib/mysql/data

10、初始化資料庫

1)設定許可權

chown -R mysql:mysql /var/lib/mysql/

2)初始化資料庫

/usr/local/mysql/bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/var/lib/mysql/data/&

注:mysql5.7初始化後,會產生一個 臨時登入密碼,在mysql.log日誌中!

11、啟動資料庫並修改密碼

1)啟動資料庫

/usr/local/mysql/bin/mysql -u root –p

2)登入資料庫

/usr/local/mysql/bin/mysql -u root –p

3)修改密碼

set password=password('123456');

flush privileges;

12、檢查mysql是否正常啟動

1)檢視mysql程序是否正常

ps -ef | grep mysql

2)檢視 3306 埠是否開啟

netstat -antupl | grep 3306

配置全域性環境變數

1、新增環境變數

echo 'export PATH=/usr/local/mysql/bin:$PATH'>>/etc/profile

2、環境變數生效

source /etc/profile

新增mysql全域性啟動指令碼

1、拷貝mysql啟動服務指令碼並重命名mysqld

cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld

2、給予啟動指令碼執行許可權

chmod +x /etc/init.d/mysqld

3、將mysql註冊為系統服務

chkconfig --add mysqld

4、設定mysql開機自啟

chkconfig --level 35 mysqld on