Centos下安裝多個(gè)mysql數(shù)據(jù)庫(kù)的配置實(shí)例詳解
在實(shí)際的開發(fā)和運(yùn)維場(chǎng)景中,有時(shí)我們需要在同一臺(tái)服務(wù)器上運(yùn)行多個(gè)MySQL數(shù)據(jù)庫(kù)實(shí)例。本文將詳細(xì)介紹如何在CentOS系統(tǒng)中安裝并配置多個(gè)MySQL數(shù)據(jù)庫(kù)實(shí)例。
1. 環(huán)境準(zhǔn)備
操作系統(tǒng):CentOS 7.x
MySQL版本:5.7.x
2. 安裝MySQL
首先,確保你的系統(tǒng)已經(jīng)安裝了MySQL。如果沒有安裝,可以使用以下命令進(jìn)行安裝:
sudo yum update -y sudo yum install -y mysql-server
安裝完成后,啟動(dòng)MySQL服務(wù)并設(shè)置開機(jī)自啟:
sudo systemctl start mysqld sudo systemctl enable mysqld
3. 創(chuàng)建多個(gè)MySQL實(shí)例
3.1 創(chuàng)建目錄結(jié)構(gòu)
為了管理方便,我們?yōu)槊總€(gè)MySQL實(shí)例創(chuàng)建獨(dú)立的數(shù)據(jù)目錄和日志目錄。假設(shè)我們要?jiǎng)?chuàng)建兩個(gè)實(shí)例:??mysql1?? 和 ??mysql2??。
sudo mkdir -p /var/lib/mysql1 sudo mkdir -p /var/lib/mysql2 sudo chown -R mysql:mysql /var/lib/mysql1 sudo chown -R mysql:mysql /var/lib/mysql2
3.2 初始化數(shù)據(jù)目錄
使用??mysqld??命令初始化每個(gè)實(shí)例的數(shù)據(jù)目錄:
sudo mysqld --initialize-insecure --user=mysql --datadir=/var/lib/mysql1 sudo mysqld --initialize-insecure --user=mysql --datadir=/var/lib/mysql2
3.3 配置文件
為每個(gè)實(shí)例創(chuàng)建獨(dú)立的配置文件。例如,??/etc/my.cnf.d/mysql1.cnf?? 和 ??/etc/my.cnf.d/mysql2.cnf??。
mysql1.cnf [mysqld] datadir=/var/lib/mysql1 socket=/var/lib/mysql1/mysql.sock port=3306 server-id=1 mysql2.cnf [mysqld] datadir=/var/lib/mysql2 socket=/var/lib/mysql2/mysql.sock port=3307 server-id=2
3.4 創(chuàng)建系統(tǒng)服務(wù)文件
為每個(gè)實(shí)例創(chuàng)建獨(dú)立的systemd服務(wù)文件。例如,??/etc/systemd/system/mysqld@.service??。
[Unit] Description=MySQL Server Instance %i After=network.target [Service] User=mysql Group=mysql ExecStart=/usr/sbin/mysqld --defaults-file=/etc/my.cnf.d/mysql%i.cnf --datadir=/var/lib/mysql%i Restart=on-failure PrivateTmp=true [Install] WantedBy=multi-user.target
3.5 重新加載systemd配置
sudo systemctl daemon-reload
3.6 啟動(dòng)并啟用服務(wù)
sudo systemctl start mysqld@1 sudo systemctl start mysqld@2 sudo systemctl enable mysqld@1 sudo systemctl enable mysqld@2
4. 驗(yàn)證安裝
可以通過以下命令驗(yàn)證兩個(gè)實(shí)例是否正常運(yùn)行:
sudo systemctl status mysqld@1 sudo systemctl status mysqld@2
還可以通過MySQL客戶端連接到這兩個(gè)實(shí)例:
mysql -u root -p -S /var/lib/mysql1/mysql.sock mysql -u root -p -S /var/lib/mysql2/mysql.sock
5. 注意事項(xiàng)
- 確保每個(gè)實(shí)例的端口不沖突。
- 確保每個(gè)實(shí)例的配置文件路徑正確。
- 如果需要遠(yuǎn)程訪問,確保防火墻規(guī)則允許相應(yīng)的端口。
6.方法補(bǔ)充
這對(duì)于測(cè)試、開發(fā)或生產(chǎn)環(huán)境中的多租戶場(chǎng)景非常有用```在 CentOS 中安裝和配置多個(gè) MySQL 數(shù)據(jù)庫(kù)實(shí)例是一個(gè)相對(duì)復(fù)雜的過程,但通過合理地規(guī)劃配置文件和端口,可以實(shí)現(xiàn)這一目標(biāo)。以下是一個(gè)具體的步驟和示例代碼,用于在 CentOS 上安裝兩個(gè) MySQL 實(shí)例(例如:??mysqld1??? 和 ??mysqld2??)。
步驟 1: 安裝 MySQL
首先,確保你的系統(tǒng)已經(jīng)安裝了 MySQL。如果沒有安裝,可以通過以下命令安裝:
sudo yum install -y mysql-server
步驟 2: 創(chuàng)建數(shù)據(jù)目錄
為每個(gè) MySQL 實(shí)例創(chuàng)建獨(dú)立的數(shù)據(jù)目錄,并設(shè)置正確的權(quán)限:
sudo mkdir -p /var/lib/mysql1 /var/lib/mysql2 sudo chown -R mysql:mysql /var/lib/mysql1 /var/lib/mysql2
步驟 3: 配置 MySQL 實(shí)例
為每個(gè) MySQL 實(shí)例創(chuàng)建一個(gè)獨(dú)立的配置文件。假設(shè)我們將使用 ??/etc/my.cnf.d/mysqld1.cnf?? 和 ??/etc/my.cnf.d/mysqld2.cnf??。
mysqld1.cnf [mysqld1] datadir=/var/lib/mysql1 socket=/var/lib/mysql1/mysql.sock port=3306 pid-file=/var/run/mysqld/mysqld1.pid mysqld2.cnf [mysqld2] datadir=/var/lib/mysql2 socket=/var/lib/mysql2/mysql.sock port=3307 pid-file=/var/run/mysqld/mysqld2.pid
步驟 4: 初始化數(shù)據(jù)庫(kù)
初始化每個(gè) MySQL 實(shí)例的數(shù)據(jù)目錄:
sudo mysql_install_db --user=mysql --basedir=/usr --datadir=/var/lib/mysql1 sudo mysql_install_db --user=mysql --basedir=/usr --datadir=/var/lib/mysql2
步驟 5: 創(chuàng)建系統(tǒng)服務(wù)文件
為每個(gè) MySQL 實(shí)例創(chuàng)建一個(gè)系統(tǒng)服務(wù)文件。假設(shè)我們將使用 ??/etc/systemd/system/mysqld1.service?? 和 ??/etc/systemd/system/mysqld2.service??。
mysqld1.service [Unit] Description=MySQL Server Instance 1 After=network.target [Service] User=mysql Group=mysql ExecStart=/usr/sbin/mysqld --defaults-file=/etc/my.cnf.d/mysqld1.cnf ExecReload=/bin/kill -HUP $MAINPID ExecStop=/bin/kill -SIGTERM $MAINPID Restart=on-failure [Install] WantedBy=multi-user.target mysqld2.service [Unit] Description=MySQL Server Instance 2 After=network.target [Service] User=mysql Group=mysql ExecStart=/usr/sbin/mysqld --defaults-file=/etc/my.cnf.d/mysqld2.cnf ExecReload=/bin/kill -HUP $MAINPID ExecStop=/bin/kill -SIGTERM $MAINPID Restart=on-failure [Install] WantedBy=multi-user.target
步驟 6: 啟動(dòng)并啟用服務(wù)
啟動(dòng)并啟用這兩個(gè) MySQL 實(shí)例的服務(wù):
sudo systemctl daemon-reload sudo systemctl start mysqld1 sudo systemctl start mysqld2 sudo systemctl enable mysqld1 sudo systemctl enable mysqld2
步驟 7: 驗(yàn)證安裝
驗(yàn)證兩個(gè) MySQL 實(shí)例是否正常運(yùn)行:
sudo systemctl status mysqld1 sudo systemctl status mysqld2
你可以通過以下命令連接到每個(gè)實(shí)例:
mysql -u root -p -S /var/lib/mysql1/mysql.sock mysql -u root -p -S /var/lib/mysql2/mysql.sock
或者通過端口連接:
mysql -u root -p -h 127.0.0.1 -P 3306 mysql -u root -p -h 127.0.0.1 -P 3307
以上步驟和示例代碼展示了如何在 CentOS 上安裝和配置多個(gè) MySQL 實(shí)例。希望這些信息對(duì)你有幫助!如果有任何問題,請(qǐng)隨時(shí)提問。
在 CentOS 中安裝和配置多個(gè) MySQL 數(shù)據(jù)庫(kù)實(shí)例可以為不同的應(yīng)用程序或項(xiàng)目提供獨(dú)立的數(shù)據(jù)庫(kù)環(huán)境。以下是一個(gè)詳細(xì)的步驟指南,包括必要的命令和配置文件修改,以幫助你在 CentOS 上設(shè)置多個(gè) MySQL 實(shí)例。
1. 安裝 MySQL
首先,確保你的系統(tǒng)上已經(jīng)安裝了 MySQL。如果沒有,可以通過以下命令安裝:
sudo yum update -y sudo yum install -y mysql-server
2. 創(chuàng)建多個(gè) MySQL 配置文件
MySQL 使用配置文件來定義每個(gè)實(shí)例的行為。我們將為每個(gè)實(shí)例創(chuàng)建一個(gè)單獨(dú)的配置文件。假設(shè)我們要?jiǎng)?chuàng)建兩個(gè)實(shí)例:??mysql1?? 和 ??mysql2??。
創(chuàng)建配置目錄
sudo mkdir /etc/mysql sudo mkdir /etc/mysql/mysql1 sudo mkdir /etc/mysql/mysql2
創(chuàng)建配置文件
編輯 ??/etc/mysql/mysql1/my.cnf?? 文件:
[mysqld] datadir=/var/lib/mysql1 socket=/var/lib/mysql1/mysql.sock port=3306 pid-file=/var/run/mysqld/mysqld1.pid log-error=/var/log/mysql1/error.log
編輯 ??/etc/mysql/mysql2/my.cnf?? 文件:
[mysqld] datadir=/var/lib/mysql2 socket=/var/lib/mysql2/mysql.sock port=3307 pid-file=/var/run/mysqld/mysqld2.pid log-error=/var/log/mysql2/error.log
3. 創(chuàng)建數(shù)據(jù)目錄和日志目錄
為每個(gè)實(shí)例創(chuàng)建數(shù)據(jù)目錄和日志目錄,并設(shè)置適當(dāng)?shù)臋?quán)限:
sudo mkdir -p /var/lib/mysql1 sudo mkdir -p /var/lib/mysql2 sudo mkdir -p /var/log/mysql1 sudo mkdir -p /var/log/mysql2 sudo chown -R mysql:mysql /var/lib/mysql1 sudo chown -R mysql:mysql /var/lib/mysql2 sudo chown -R mysql:mysql /var/log/mysql1 sudo chown -R mysql:mysql /var/log/mysql2
4. 初始化數(shù)據(jù)庫(kù)
使用 ??mysql_install_db?? 工具初始化每個(gè)實(shí)例的數(shù)據(jù)目錄。請(qǐng)注意,從 MySQL 5.7 開始,推薦使用 ??mysqld --initialize?? 命令:
sudo mysqld --initialize --user=mysql --basedir=/usr --datadir=/var/lib/mysql1 sudo mysqld --initialize --user=mysql --basedir=/usr --datadir=/var/lib/mysql2
5. 創(chuàng)建啟動(dòng)腳本
為每個(gè)實(shí)例創(chuàng)建一個(gè)啟動(dòng)腳本。這些腳本將用于啟動(dòng)、停止和管理每個(gè)實(shí)例。
創(chuàng)建 ??/etc/init.d/mysql1?? 腳本
sudo nano /etc/init.d/mysql1
內(nèi)容如下:
#!/bin/bash
# chkconfig: 345 64 36
# description: MySQL Server 1
. /etc/init.d/functions
MYSQLD=/usr/sbin/mysqld
MYSQLD_OPTS="--defaults-file=/etc/mysql/mysql1/my.cnf"
PIDFILE=/var/run/mysqld/mysqld1.pid
start() {
echo -n "Starting MySQL 1: "
daemon $MYSQLD $MYSQLD_OPTS
RETVAL=$?
echo
[ $RETVAL -eq 0 ] && touch /var/lock/subsys/mysql1
return $RETVAL
}
stop() {
echo -n "Shutting down MySQL 1: "
killproc -p $PIDFILE $MYSQLD
RETVAL=$?
echo
[ $RETVAL -eq 0 ] && rm -f /var/lock/subsys/mysql1
return $RETVAL
}
case "$1" in
start)
start
;;
stop)
stop
;;
restart)
stop
start
;;
*)
echo "Usage: $0 {start|stop|restart}"
exit 1
esac
exit $?創(chuàng)建 ??/etc/init.d/mysql2?? 腳本
sudo nano /etc/init.d/mysql2
內(nèi)容如下:
#!/bin/bash
# chkconfig: 345 65 35
# description: MySQL Server 2
. /etc/init.d/functions
MYSQLD=/usr/sbin/mysqld
MYSQLD_OPTS="--defaults-file=/etc/mysql/mysql2/my.cnf"
PIDFILE=/var/run/mysqld/mysqld2.pid
start() {
echo -n "Starting MySQL 2: "
daemon $MYSQLD $MYSQLD_OPTS
RETVAL=$?
echo
[ $RETVAL -eq 0 ] && touch /var/lock/subsys/mysql2
return $RETVAL
}
stop() {
echo -n "Shutting down MySQL 2: "
killproc -p $PIDFILE $MYSQLD
RETVAL=$?
echo
[ $RETVAL -eq 0 ] && rm -f /var/lock/subsys/mysql2
return $RETVAL
}
case "$1" in
start)
start
;;
stop)
stop
;;
restart)
stop
start
;;
*)
echo "Usage: $0 {start|stop|restart}"
exit 1
esac
exit $?6. 設(shè)置啟動(dòng)腳本權(quán)限
使啟動(dòng)腳本可執(zhí)行:
sudo chmod +x /etc/init.d/mysql1 sudo chmod +x /etc/init.d/mysql2
7. 注冊(cè)服務(wù)
將服務(wù)注冊(cè)到系統(tǒng)啟動(dòng)項(xiàng):
sudo chkconfig --add mysql1 sudo chkconfig --add mysql2 sudo chkconfig --level 345 mysql1 on sudo chkconfig --level 345 mysql2 on
8. 啟動(dòng) MySQL 實(shí)例
啟動(dòng)兩個(gè) MySQL 實(shí)例:
sudo service mysql1 start sudo service mysql2 start
9. 驗(yàn)證實(shí)例
驗(yàn)證每個(gè)實(shí)例是否正常運(yùn)行:
sudo netstat -tuln | grep 3306 sudo netstat -tuln | grep 3307
10. 連接到實(shí)例
你可以使用 ??mysql?? 客戶端連接到每個(gè)實(shí)例:
mysql -u root -p -S /var/lib/mysql1/mysql.sock mysql -u root -p -S /var/lib/mysql2/mysql.sock
通過以上步驟,你可以在 CentOS 上成功配置和運(yùn)行多個(gè) MySQL 實(shí)例。每個(gè)實(shí)例都有自己的配置文件、數(shù)據(jù)目錄和日志目錄,互不干擾。
以上就是Centos下安裝多個(gè)mysql數(shù)據(jù)庫(kù)的配置實(shí)例詳解的詳細(xì)內(nèi)容,更多關(guān)于Centos安裝多個(gè)mysql的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
mysql5.5 master-slave(Replication)主從配置
在主機(jī)master中對(duì)test數(shù)據(jù)庫(kù)進(jìn)行sql操作,再查看從機(jī)test數(shù)據(jù)庫(kù)是否產(chǎn)生同步。2011-07-07
MySQL中索引優(yōu)化distinct語句及distinct的多字段操作
這篇文章主要介紹了MySQL中索引優(yōu)化distinct語句及distinct的多字段操作方法,distinct語句去重功能的使用是MySQL入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2016-01-01
MySQL的Replace into 與Insert into on duplicate key update真正的不同
今天聽同事介紹oracle到mysql的數(shù)據(jù)migration,他用了Insert into ..... on duplicate key update ...,我當(dāng)時(shí)就想怎么不用Replace呢,于是回來就仔細(xì)查了下,它們果然還是有區(qū)別的2014-02-02
MySQL中crash safe數(shù)據(jù)完整性機(jī)制面試精講
這篇文章主要為大家介紹了MySQL數(shù)據(jù)完整性crash safe特性面試精講,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10

