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

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

 更新時間:2025年04月07日 08:17:51   作者:牛肉胡辣湯  
在實際的開發(fā)和運維場景中,有時我們需要在同一臺服務(wù)器上運行多個MySQL數(shù)據(jù)庫實例,本文將詳細介紹如何在CentOS系統(tǒng)中安裝并配置多個MySQL數(shù)據(jù)庫實例,希望對大家有所幫助

在實際的開發(fā)和運維場景中,有時我們需要在同一臺服務(wù)器上運行多個MySQL數(shù)據(jù)庫實例。本文將詳細介紹如何在CentOS系統(tǒng)中安裝并配置多個MySQL數(shù)據(jù)庫實例。

1. 環(huán)境準(zhǔn)備

操作系統(tǒng):CentOS 7.x

MySQL版本:5.7.x

2. 安裝MySQL

首先,確保你的系統(tǒng)已經(jīng)安裝了MySQL。如果沒有安裝,可以使用以下命令進行安裝:

sudo yum update -y
sudo yum install -y mysql-server

安裝完成后,啟動MySQL服務(wù)并設(shè)置開機自啟:

sudo systemctl start mysqld
sudo systemctl enable mysqld

3. 創(chuàng)建多個MySQL實例

3.1 創(chuàng)建目錄結(jié)構(gòu)

為了管理方便,我們?yōu)槊總€MySQL實例創(chuàng)建獨立的數(shù)據(jù)目錄和日志目錄。假設(shè)我們要創(chuàng)建兩個實例:??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??命令初始化每個實例的數(shù)據(jù)目錄:

sudo mysqld --initialize-insecure --user=mysql --datadir=/var/lib/mysql1
sudo mysqld --initialize-insecure --user=mysql --datadir=/var/lib/mysql2

3.3 配置文件

為每個實例創(chuàng)建獨立的配置文件。例如,??/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ù)文件

為每個實例創(chuàng)建獨立的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 啟動并啟用服務(wù)

sudo systemctl start mysqld@1
sudo systemctl start mysqld@2
sudo systemctl enable mysqld@1
sudo systemctl enable mysqld@2

4. 驗證安裝

可以通過以下命令驗證兩個實例是否正常運行:

sudo systemctl status mysqld@1
sudo systemctl status mysqld@2

還可以通過MySQL客戶端連接到這兩個實例:

mysql -u root -p -S /var/lib/mysql1/mysql.sock
mysql -u root -p -S /var/lib/mysql2/mysql.sock

5. 注意事項

  • 確保每個實例的端口不沖突。
  • 確保每個實例的配置文件路徑正確。
  • 如果需要遠程訪問,確保防火墻規(guī)則允許相應(yīng)的端口。

6.方法補充

這對于測試、開發(fā)或生產(chǎn)環(huán)境中的多租戶場景非常有用```在 CentOS 中安裝和配置多個 MySQL 數(shù)據(jù)庫實例是一個相對復(fù)雜的過程,但通過合理地規(guī)劃配置文件和端口,可以實現(xiàn)這一目標(biāo)。以下是一個具體的步驟和示例代碼,用于在 CentOS 上安裝兩個 MySQL 實例(例如:??mysqld1??? 和 ??mysqld2??)。

步驟 1: 安裝 MySQL

首先,確保你的系統(tǒng)已經(jīng)安裝了 MySQL。如果沒有安裝,可以通過以下命令安裝:

sudo yum install -y mysql-server

步驟 2: 創(chuàng)建數(shù)據(jù)目錄

為每個 MySQL 實例創(chuàng)建獨立的數(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 實例

為每個 MySQL 實例創(chuàng)建一個獨立的配置文件。假設(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ù)庫

初始化每個 MySQL 實例的數(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ù)文件

為每個 MySQL 實例創(chuàng)建一個系統(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: 啟動并啟用服務(wù)

啟動并啟用這兩個 MySQL 實例的服務(wù):

sudo systemctl daemon-reload
sudo systemctl start mysqld1
sudo systemctl start mysqld2
sudo systemctl enable mysqld1
sudo systemctl enable mysqld2

步驟 7: 驗證安裝

驗證兩個 MySQL 實例是否正常運行:

sudo systemctl status mysqld1
sudo systemctl status mysqld2

你可以通過以下命令連接到每個實例:

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 上安裝和配置多個 MySQL 實例。希望這些信息對你有幫助!如果有任何問題,請隨時提問。

在 CentOS 中安裝和配置多個 MySQL 數(shù)據(jù)庫實例可以為不同的應(yīng)用程序或項目提供獨立的數(shù)據(jù)庫環(huán)境。以下是一個詳細的步驟指南,包括必要的命令和配置文件修改,以幫助你在 CentOS 上設(shè)置多個 MySQL 實例。

1. 安裝 MySQL

首先,確保你的系統(tǒng)上已經(jīng)安裝了 MySQL。如果沒有,可以通過以下命令安裝:

sudo yum update -y
sudo yum install -y mysql-server

2. 創(chuàng)建多個 MySQL 配置文件

MySQL 使用配置文件來定義每個實例的行為。我們將為每個實例創(chuàng)建一個單獨的配置文件。假設(shè)我們要創(chuàng)建兩個實例:??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ù)目錄和日志目錄

為每個實例創(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ù)庫

使用 ??mysql_install_db?? 工具初始化每個實例的數(shù)據(jù)目錄。請注意,從 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)建啟動腳本

為每個實例創(chuàng)建一個啟動腳本。這些腳本將用于啟動、停止和管理每個實例。

創(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è)置啟動腳本權(quán)限

使啟動腳本可執(zhí)行:

sudo chmod +x /etc/init.d/mysql1
sudo chmod +x /etc/init.d/mysql2

7. 注冊服務(wù)

將服務(wù)注冊到系統(tǒng)啟動項:

sudo chkconfig --add mysql1
sudo chkconfig --add mysql2
sudo chkconfig --level 345 mysql1 on
sudo chkconfig --level 345 mysql2 on

8. 啟動 MySQL 實例

啟動兩個 MySQL 實例:

sudo service mysql1 start
sudo service mysql2 start

9. 驗證實例

驗證每個實例是否正常運行:

sudo netstat -tuln | grep 3306
sudo netstat -tuln | grep 3307

10. 連接到實例

你可以使用 ??mysql?? 客戶端連接到每個實例:

mysql -u root -p -S /var/lib/mysql1/mysql.sock
mysql -u root -p -S /var/lib/mysql2/mysql.sock

通過以上步驟,你可以在 CentOS 上成功配置和運行多個 MySQL 實例。每個實例都有自己的配置文件、數(shù)據(jù)目錄和日志目錄,互不干擾。

以上就是Centos下安裝多個mysql數(shù)據(jù)庫的配置實例詳解的詳細內(nèi)容,更多關(guān)于Centos安裝多個mysql的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • MySQL日志的詳細分析實例

    MySQL日志的詳細分析實例

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

    mysql5.5 master-slave(Replication)主從配置

    在主機master中對test數(shù)據(jù)庫進行sql操作,再查看從機test數(shù)據(jù)庫是否產(chǎn)生同步。
    2011-07-07
  • mysql觸發(fā)器同步表的數(shù)據(jù)方式

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

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

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

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

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

    這篇文章主要介紹了Mysql中的sql優(yōu)化實踐詳解,SQL優(yōu)化是指通過改進SQL語句的編寫和查詢計劃的設(shè)計來提高數(shù)據(jù)庫查詢性能的過程,在優(yōu)化SQL時,可以采取一些措施來提升查詢性能,需要的朋友可以參考下
    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ǔ)知識,需要的朋友可以參考下
    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)時就想怎么不用Replace呢,于是回來就仔細查了下,它們果然還是有區(qū)別的
    2014-02-02
  • MySQL中crash safe數(shù)據(jù)完整性機制面試精講

    MySQL中crash safe數(shù)據(jù)完整性機制面試精講

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

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

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

最新評論