rpm安装两个mysql_MySQL通过rpm安装及其单机多实例部署
1. CentOS 下安裝 MySQL
Oracle 收購 MySQL 后,CentOS 為避免 MySQL 閉源的風險,改用 MySQL 的分支 MariaDB;
MariaDB 完全兼容 MySQL,包括API和命令行,但還是有些地方不一樣(比如命令行提示符);
要想使用傳統的官方版本 MySQL Community,需要手工下載并安裝。
1.1 安裝與啟動
1.1.1 自動方法,國內下載慢(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 手動方法,下載速度快
使用迅雷等多線程下載工具,下載各安裝包至 PC,再上傳至 Linux 主機:
然后按下面順序安裝(有依賴關系):
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 啟動 MySQL 服務進程
1
2
3
sudo systemctl enable mysqld # 加入開機啟動
sudo systemctl start mysqld # 立即啟動
sudo netstat -natp | grep mysqld ## 檢測監聽端口
1.3 日志文件時間格式
查看日志文件/var/log/mysqld.log,發現時間格式為2016-12-21T13:15:11.097632Z,為 UTC 格式,與北京時間相差 8 小時;
1
2
3
4
### sudo vim /etc/my.cnf
[mysqld]
log_timestamps=SYSTEM # log time zone
explicit_defaults_for_timestamp=true
調整后重啟 mysqld,日志中變為北京時間,形如“2016-12-22T11:52:12.499593+08:00”,但格式非預期,沒能找到解決辦法,但尚能授受。
1.4 修改密碼
1.4.1 已知 root 密碼時
1
2
3
4
5
6
7
8
## MySQL 首次啟動時隨機生成 root 密碼,要求修改后才能繼續使用
## MySQL 5.7 密碼要求: 8位以上、大小寫、數字、字符
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.%'; ## 查看授權結果
1.4.2 忘記密碼時
首先,修改 MySQL 配置,跳過授權驗證,安全起見同時關閉網絡防止外部主機連接:
1
2
3
4
## sudo vim /etc/my.cnf
[mysqld]
skip-networking
skip-grant-tables
重啟 MySQL 服務:
1
sudo systemctl restart mysqld
重新設置 root 密碼:
1
2
3
mysql -uroot # 此時可無密碼登錄
MySQL> UPDATE mysql.user SET authentication_string=password('MySQL5.7') WHERE user='root';
MySQL> FLUSH PRIVILEGES; EXIT;
恢復之前的 MySQL 配置,并重啟服務,操作完畢:
1
2
3
sudo vim /etc/my.cnf # 撤消剛剛的修改
sudo systemctl restart mysqld
mysql -uroot -p # 此時指定新設密碼登錄
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 驗證連接
在 Windows 上連接 MySQL 來驗證:
DOS> mysql -uroot -hcentos -pMySQL5.7 -P3306 -e “SELECT user(), @@port”
輸出 root@192.168.214.1 | 3306, 驗證通過。
1.7 卸載 MySQL
若要重新安裝 MySQL 服務,需要先卸載:
1
2
3
4
5
# 注意:如果重裝版本號不變,則可以不卸載 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
執行完畢后,檢查卸載是否徹底:
1
2
rpm -qa | grep -i mysql
sudo find / -name "mysql*"
2. Linux 單機啟動多個 MySQL 實例
單機多實例是指,單個 Linux 的單個 MySQL 安裝,啟動多個 MySQL 服務進程,監聽多個端口提供多個數據庫服務。
早期版本只能使用mysqld_multi實現多實例,從 MySQL 5.7.13 開始,只能使用systemd實現。
下面的多實例實現單機主從庫,把原實例作為 master 庫,新增實例作為 slave 庫。
2.1 關于 mysqld_multi 命令
mysqld_multi 用來管理多個 mysqld 進程,各個進程以 GNR(Group Number) 標識。
命令格式為:mysqld_multi [options] {start|stop|reload|report} [GNR[,GNR] ...]
[options]: 對應于 my.cnf 中的 [mysqld_multi] 段;
可以執行的命令包括 start(啟動), stop(停止), reload(重啟), report(報告)
GNR 必須為正整數,對應于 /etc/my.cnf 中 [mysqld{GNR}] 的 {GNR}
可以指定單個或多個 GNR(逗號分隔),不指定 GNR 時,表示所有 GNR;
2.2 關閉 SELinux 模式
1
2
3
4
# sudo vim /etc/selinux/config
# mode of SELinux: enforcing=enable, permissive=disable
# SELINUX=enforcing
SELINUX=permissive
Linuxsudo reboot之后生效。
如果漏掉此操作,啟動實例時會報錯:
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 配置文件中增加實例配置
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 啟動新實例
1
2
sudo systemctl enable mysqld@slave # 加入開機啟動
sudo systemctl start mysqld@slave # 立即啟動
2.5 強制本機客戶端以 TCP 連接
這里有個大坑,Linux 上使用mysql -uroot -P33061 -p連接時,即使指定了 slave 端口號,仍然連接到 master 庫,百思不得其解;
原來有個隱規則:當以 localhost 連接時(不指定-h時默認為localhost),MySQL 是通過 Unix Socket(而不是 TCP) 連接。此時指定的端口被忽略。
解決辦法(mysqld 無需重啟,立即生效):
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.%'; ## 查看授權結果
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 驗證連接
在 Windows 上連接 MySQL 來驗證:
DOS> mysql -uroot -hcentos -pMySQL5.7 -P33061 -e “SELECT user(), @@port”
輸出 root@192.168.214.1 | 33061, 驗證通過
總結
以上是生活随笔為你收集整理的rpm安装两个mysql_MySQL通过rpm安装及其单机多实例部署的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: gop率是什么意思
- 下一篇: linux cmake编译源码,linu