日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

rpm安装两个mysql_MySQL通过rpm安装及其单机多实例部署

發布時間:2024/10/8 数据库 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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安装及其单机多实例部署的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。