欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Centos下安裝多個(gè)mysql數(shù)據(jù)庫(kù)的配置實(shí)例詳解

 更新時(shí)間:2025年04月07日 08:17:51   作者:牛肉胡辣湯  
在實(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í)例,希望對(duì)大家有所幫助

在實(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)文章

  • MySQL日志的詳細(xì)分析實(shí)例

    MySQL日志的詳細(xì)分析實(shí)例

    MySQL日志記錄了MySQL數(shù)據(jù)庫(kù)日常操作和錯(cuò)誤信息,下面這篇文章主要給大家介紹了關(guān)于MySQL日志的詳細(xì)分析,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-04-04
  • mysql5.5 master-slave(Replication)主從配置

    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觸發(fā)器同步表的數(shù)據(jù)方式

    mysql觸發(fā)器同步表的數(shù)據(jù)方式

    這篇文章主要介紹了mysql觸發(fā)器同步表的數(shù)據(jù)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • MySQL不能顯示中文問題及解決

    MySQL不能顯示中文問題及解決

    這篇文章主要介紹了MySQL不能顯示中文問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Mysql中的sql優(yōu)化實(shí)踐詳解

    Mysql中的sql優(yōu)化實(shí)踐詳解

    這篇文章主要介紹了Mysql中的sql優(yōu)化實(shí)踐詳解,SQL優(yōu)化是指通過改進(jìn)SQL語句的編寫和查詢計(jì)劃的設(shè)計(jì)來提高數(shù)據(jù)庫(kù)查詢性能的過程,在優(yōu)化SQL時(shí),可以采取一些措施來提升查詢性能,需要的朋友可以參考下
    2023-09-09
  • MySQL MGR搭建過程中常遇見的問題及解決辦法

    MySQL MGR搭建過程中常遇見的問題及解決辦法

    這篇文章主要介紹了MySQL MGR搭建過程中常遇見的問題及解決辦法,幫助大家更好的理解和學(xué)習(xí)使用MySQL,感興趣的朋友可以了解下
    2021-03-03
  • MySQL中索引優(yōu)化distinct語句及distinct的多字段操作

    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真正的不同之處

    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中crash safe數(shù)據(jù)完整性機(jī)制面試精講

    這篇文章主要為大家介紹了MySQL數(shù)據(jù)完整性crash safe特性面試精講,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-10-10
  • MySQL查看表和清空表的常用命令總結(jié)

    MySQL查看表和清空表的常用命令總結(jié)

    這篇文章主要介紹了MySQL查看表和清空表的常用命令總結(jié),是MySQL入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-11-11

最新評(píng)論