rpm安装两个mysql_MySQL通过rpm安装及其单机多实例部署
1. CentOS 下安裝 MySQL
Oracle 收購(gòu) MySQL 后,CentOS 為避免 MySQL 閉源的風(fēng)險(xiǎn),改用 MySQL 的分支 MariaDB;
MariaDB 完全兼容 MySQL,包括API和命令行,但還是有些地方不一樣(比如命令行提示符);
要想使用傳統(tǒng)的官方版本 MySQL Community,需要手工下載并安裝。
1.1 安裝與啟動(dòng)
1.1.1 自動(dòng)方法,國(guó)內(nèi)下載慢(90min)
1
2
3
4
5
## https://dev.mysql.com/downloads/repo/yum/
## cat /etc/redhat-release ## CentOS Linux release 7.3.1611
wget --tries=0 --retry-connrefused http://repo.mysql.com//mysql57-community-release-el7-9.noarch.rpm
sudo yum -y install mysql57-community-release-el7-9.noarch.rpm
sudo yum -y install mysql-server
1.1.2 手動(dòng)方法,下載速度快
使用迅雷等多線程下載工具,下載各安裝包至 PC,再上傳至 Linux 主機(jī):
然后按下面順序安裝(有依賴關(guān)系):
1
2
3
4
5
sudo yum -y remove mariadb-libs
sudo yum -y install mysql-community-common-5.7.17-1.el7.x86_64.rpm
sudo yum -y install mysql-community-libs-5.7.17-1.el7.x86_64.rpm
sudo yum -y install mysql-community-client-5.7.17-1.el7.x86_64.rpm
sudo yum -y install mysql-community-server-5.7.17-1.el7.x86_64.rpm
1.2 啟動(dòng) MySQL 服務(wù)進(jìn)程
1
2
3
sudo systemctl enable mysqld # 加入開機(jī)啟動(dòng)
sudo systemctl start mysqld # 立即啟動(dòng)
sudo netstat -natp | grep mysqld ## 檢測(cè)監(jiān)聽端口
1.3 日志文件時(shí)間格式
查看日志文件/var/log/mysqld.log,發(fā)現(xiàn)時(shí)間格式為2016-12-21T13:15:11.097632Z,為 UTC 格式,與北京時(shí)間相差 8 小時(shí);
1
2
3
4
### sudo vim /etc/my.cnf
[mysqld]
log_timestamps=SYSTEM # log time zone
explicit_defaults_for_timestamp=true
調(diào)整后重啟 mysqld,日志中變?yōu)楸本r(shí)間,形如“2016-12-22T11:52:12.499593+08:00”,但格式非預(yù)期,沒能找到解決辦法,但尚能授受。
1.4 修改密碼
1.4.1 已知 root 密碼時(shí)
1
2
3
4
5
6
7
8
## MySQL 首次啟動(dòng)時(shí)隨機(jī)生成 root 密碼,要求修改后才能繼續(xù)使用
## MySQL 5.7 密碼要求: 8位以上、大小寫、數(shù)字、字符
sudo grep "temporary password" /var/log/mysqld.log | awk -F'root@localhost: ' '{print $2}' # 查詢初始密碼
mysql -uroot -p
MySQL> SET PASSWORD = 'MySQL5.7';
MySQL> SHOW VARIABLES LIKE 'validate_password%'; ## 查看密碼要求
MySQL> GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.168.%' IDENTIFIED BY 'MySQL5.7' WITH GRANT OPTION;
MySQL> SHOW GRANTS FOR 'root'@'192.168.%'; ## 查看授權(quán)結(jié)果
1.4.2 忘記密碼時(shí)
首先,修改 MySQL 配置,跳過(guò)授權(quán)驗(yàn)證,安全起見同時(shí)關(guān)閉網(wǎng)絡(luò)防止外部主機(jī)連接:
1
2
3
4
## sudo vim /etc/my.cnf
[mysqld]
skip-networking
skip-grant-tables
重啟 MySQL 服務(wù):
1
sudo systemctl restart mysqld
重新設(shè)置 root 密碼:
1
2
3
mysql -uroot # 此時(shí)可無(wú)密碼登錄
MySQL> UPDATE mysql.user SET authentication_string=password('MySQL5.7') WHERE user='root';
MySQL> FLUSH PRIVILEGES; EXIT;
恢復(fù)之前的 MySQL 配置,并重啟服務(wù),操作完畢:
1
2
3
sudo vim /etc/my.cnf # 撤消剛剛的修改
sudo systemctl restart mysqld
mysql -uroot -p # 此時(shí)指定新設(shè)密碼登錄
1.5 防火墻放行
1
2
3
### sudo vim /etc/sysconfig/iptables
-A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT
### 重啟生效: sudo systemctl restart iptables
1.6 驗(yàn)證連接
在 Windows 上連接 MySQL 來(lái)驗(yàn)證:
DOS> mysql -uroot -hcentos -pMySQL5.7 -P3306 -e “SELECT user(), @@port”
輸出 root@192.168.214.1 | 3306, 驗(yàn)證通過(guò)。
1.7 卸載 MySQL
若要重新安裝 MySQL 服務(wù),需要先卸載:
1
2
3
4
5
# 注意:如果重裝版本號(hào)不變,則可以不卸載 mysql57-community-release
sudo systemctl stop mysqld
sudo systemctl disable mysqld
sudo yum -y remove mysql-server mysql-client mysql-common mysql-libs
sudo rm -rf /var/lib/mysql /usr/share/mysql /etc/my.cnf /var/log/mysqld.log
執(zhí)行完畢后,檢查卸載是否徹底:
1
2
rpm -qa | grep -i mysql
sudo find / -name "mysql*"
2. Linux 單機(jī)啟動(dòng)多個(gè) MySQL 實(shí)例
單機(jī)多實(shí)例是指,單個(gè) Linux 的單個(gè) MySQL 安裝,啟動(dòng)多個(gè) MySQL 服務(wù)進(jìn)程,監(jiān)聽多個(gè)端口提供多個(gè)數(shù)據(jù)庫(kù)服務(wù)。
早期版本只能使用mysqld_multi實(shí)現(xiàn)多實(shí)例,從 MySQL 5.7.13 開始,只能使用systemd實(shí)現(xiàn)。
下面的多實(shí)例實(shí)現(xiàn)單機(jī)主從庫(kù),把原實(shí)例作為 master 庫(kù),新增實(shí)例作為 slave 庫(kù)。
2.1 關(guān)于 mysqld_multi 命令
mysqld_multi 用來(lái)管理多個(gè) mysqld 進(jìn)程,各個(gè)進(jìn)程以 GNR(Group Number) 標(biāo)識(shí)。
命令格式為:mysqld_multi [options] {start|stop|reload|report} [GNR[,GNR] ...]
[options]: 對(duì)應(yīng)于 my.cnf 中的 [mysqld_multi] 段;
可以執(zhí)行的命令包括 start(啟動(dòng)), stop(停止), reload(重啟), report(報(bào)告)
GNR 必須為正整數(shù),對(duì)應(yīng)于 /etc/my.cnf 中 [mysqld{GNR}] 的 {GNR}
可以指定單個(gè)或多個(gè) GNR(逗號(hào)分隔),不指定 GNR 時(shí),表示所有 GNR;
2.2 關(guān)閉 SELinux 模式
1
2
3
4
# sudo vim /etc/selinux/config
# mode of SELinux: enforcing=enable, permissive=disable
# SELINUX=enforcing
SELINUX=permissive
Linuxsudo reboot之后生效。
如果漏掉此操作,啟動(dòng)實(shí)例時(shí)會(huì)報(bào)錯(cuò):
1
2
3
4
[ERROR] InnoDB: Operating system error number 13 in a file operation.
[ERROR] InnoDB: The error means mysqld does not have the access right s to the directory.
[ERROR] InnoDB: os_file_get_status() failed on './ibdata1'. Can~t determine file permissions
[ERROR] InnoDB: Plugin initialization aborted with error Generic error
2.3 MySQL 配置文件中增加實(shí)例配置
1
2
3
4
5
6
7
8
## sudo vim /etc/my.cnf
[mysqld@slave]
port=33061
datadir=/var/lib/mysql-slave
socket=/var/lib/mysql-slave/mysql.sock
log-error=/var/log/mysqld-slave.log
explicit_defaults_for_timestamp=true
log_timestamps=SYSTEM
2.4 啟動(dòng)新實(shí)例
1
2
sudo systemctl enable mysqld@slave # 加入開機(jī)啟動(dòng)
sudo systemctl start mysqld@slave # 立即啟動(dòng)
2.5 強(qiáng)制本機(jī)客戶端以 TCP 連接
這里有個(gè)大坑,Linux 上使用mysql -uroot -P33061 -p連接時(shí),即使指定了 slave 端口號(hào),仍然連接到 master 庫(kù),百思不得其解;
原來(lái)有個(gè)隱規(guī)則:當(dāng)以 localhost 連接時(shí)(不指定-h時(shí)默認(rèn)為localhost),MySQL 是通過(guò) Unix Socket(而不是 TCP) 連接。此時(shí)指定的端口被忽略。
解決辦法(mysqld 無(wú)需重啟,立即生效):
1
2
3
## sudo vim /etc/my.cnf
[client]
protocol = TCP
2.6 修改密碼
1
2
3
4
5
sudo grep "temporary password" /var/log/mysqld-slave.log | awk -F'root@localhost: ' '{print $2}' # 查詢初始密碼
mysql -uroot -P33061 -p # tBXQh60y
MySQL> SET PASSWORD = 'MySQL5.7';
MySQL> GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.168.%' IDENTIFIED BY 'MySQL5.7' WITH GRANT OPTION;
MySQL> SHOW GRANTS FOR 'root'@'192.168.%'; ## 查看授權(quán)結(jié)果
2.7 防火墻放行
1
2
3
### sudo vim /etc/sysconfig/iptables
-A INPUT -m state --state NEW -m tcp -p tcp --dport 33061 -j ACCEPT
### 重啟生效: sudo systemctl restart iptables
2.8 驗(yàn)證連接
在 Windows 上連接 MySQL 來(lái)驗(yàn)證:
DOS> mysql -uroot -hcentos -pMySQL5.7 -P33061 -e “SELECT user(), @@port”
輸出 root@192.168.214.1 | 33061, 驗(yàn)證通過(guò)
總結(jié)
以上是生活随笔為你收集整理的rpm安装两个mysql_MySQL通过rpm安装及其单机多实例部署的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: gop率是什么意思
- 下一篇: 日利率0.05%月息多少