mysql 多實例案例實戰


其實Mysql多實例就是在一個 mysql 服務上面啟動三個實例,相當於三個分離開來的數據庫,至於為什么要做這個,你也可以選擇分別安裝三個MySQL,只是過於麻煩,多實例中只需要一個配置檔my.cnf,並且通過mysql_330x.sock 便於管理數據庫。

其實MySQL多實例之后也可以做主從同步及讀寫分離,跟原來是一樣的,只是同步的時候端口有變化而已~

下面我來做MySQL多實例的環境搭建,至於如何用,怎么用,那就看你需求了


安裝簡介

  • 用戶名:mysql
  • 安裝目錄:/usr/local/mysql
  • 實例1數據目錄 : /usr/local/mysql/data/dbdata_3306
  • 實例2數據目錄 : /usr/local/mysql/data/dbdata_3307
  • 實例3數據目錄 : /usr/local/mysql/data/dbdata_3308

安裝前步驟

一、添加MySQL用戶
groupadd mysql
useradd -g mysql -s /sbin/nologin mysql

二、yum安裝依賴包
autoconf automake bc bind-utils bzip2 bzip2-devel curl curl-devel dmidecode e2fsprogs-devel expat expat-devel freetype* gcc gcc-c++ gettext gettext-devel glib2 glib2-devel glibc glibc-devel hdparm krb5-devel libaio libaio-devel libidn-devel libjpeg libpng libxml2 libxml2-devel lrzsz mlocate ncurses ncurses-devel net-snmp net-snmp-devel net-snmp-libs net-snmp-utils ntp openssh-clients openssl-devel pam-devel rsync rsyslog-relp screen smartmontools strace sysstat telnet vim* vixie-cron wget yum-fastestmirror zip zlib-devel

三、解包
tar zxf mysql-5.6.14.tar.gz -C /usr/src
cd /usr/src/mysql-5.6.14

四、創建數據目錄
mkdir -p /usr/local/mysql/data

五、cmake配置
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_MYISAM_STORAGE_ENGING=1 -DWITH_INNOBASE_STORAGE_ENGING=1 -DWITH_SSL=yes

六、編譯及安裝
make && make install

七、拷貝配置文件
cp support-files/my-default.cnf /usr/local/mysql/data/my.cnf

八、初始化數據庫

/usr/local/mysql/scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data/dbdata_3306 --user=mysql
/usr/local/mysql/scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data/dbdata_3307 --user=mysql
/usr/local/mysql/scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data/dbdata_3308 --user=mysql

九、設置鏈接
ln -s /usr/local/mysql/bin/* /usr/local/bin/
ln -s /usr/local/mysql/include/mysql/* /usr/include/
ln -s /usr/local/mysql/lib/* /usr/lib/
rm -rf /etc/my.cnf
ln -s /usr/local/mysql/data/my.cnf /etc/

十、設置權限
chown -R mysql:mysql /usr/local/mysql/data/dbdata_3306
chown -R mysql:mysql /usr/local/mysql/data/dbdata_3307
chown -R mysql:mysql /usr/local/mysql/data/dbdata_3308

十一、修改my.cnf配置

#!/bin/bash

[mysqld_multi]
mysqld = /usr/local/mysql/bin/mysqld_safe
mysqladmin = /usr/local/mysql/bin/mysqladmin
user = root
password = yunjee0515ueopro1234

[mysqld1]
basedir = /usr/local/mysql
character-set-server = utf8
port = 3306
socket = /tmp/mysql_3306.sock
datadir = /usr/local/mysql/data/dbdata_3306
pid-file = /usr/local/mysql/data/dbdata_3306/mysql.pid
log-error = /usr/local/mysql/data/dbdata_3306/mysql.err
server-id = 1
skip-character-set-client-handshake #忽略應用程序想要設置的其他字符集
init-connect='SET NAMES utf8' #連接時執行的SQL
character-set-server=utf8 #服務端默認字符集
wait_timeout=1800 #請求的最大連接時間
interactive_timeout=1800 #和上一參數同時修改才會生效
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES #sql模式
log-bin = mysql-bin #打開二進制功能,MASTER主服務器必須打開此項
relay-log = mysql-bin #文件名格式
relay-log-index = mysql-bin.index #index文件名
##MySQL 5.6.10版本提供了更方便的基於GTID的復制功能,MySQL可以通過GTID自動識別上次同步的點,極大地方便了運維人員,減少出錯的幾率。
binlog-format=ROW #binlog格式
log-slave-updates=true #表示如果一個MASTER掛掉的話,另外一個馬上接管
gtid-mode=on #用於啟動GTID及滿足附屬的其它需求
enforce-gtid-consistency=true #
#report-port=port #從屬服務器的端口
#report-host=host #從屬服務器的主機名
master-info-repository=TABLE #啟用此兩項,可用於實現在崩潰時保證二進制及從服務器安全的功能
relay-log-info-repository=TABLE #
sync-master-info=1 #啟用之可確保無信息丟失
slave-parallel-workers=2 #設定從服務器的SQL線程數;0表示關閉多線程復制功能
binlog-checksum=CRC32 #
master-verify-checksum=1 #
slave-sql-verify-checksum=1 #啟用復制有關的所有校驗功能
binlog-rows-query-log_events=1 ###MySQL 5.6.10版本提供了更方便的基於GTID的復制功能,MySQL可以通過GTID自動識別上次同步的點,極大地方便了運維人員,減少出錯的幾率。
expire_logs_day=5 #超過5天的binlog刪除
max_binlog_size=104857600
#replicate-ignore-db = mysql #忽略不同步主從的數據庫
#replicate-ignore-db = information_schema
#replicate-ignore-db = performance_schema
#replicate-ignore-db = test
#replicate-ignore-db = zabbix
#replicate-ignore-db = sysbench
#replicate-ignore-db = db_3306
##slave-skip-errors=0 #主從忽略錯誤數
##注釋掉,使用默認設置
#skip-external-locking
##innodb_force_recovery = 1
key_buffer_size = 256M max_allowed_packet = 100M #table_open_cache = 1024
#sort_buffer_size = 128M
#net_buffer_length = 8K
#read_buffer_size = 128M
#read_rnd_buffer_size = 256M
#myisam_sort_buffer_size = 32M
#character-set-server = utf8
skip-name-resolve
max_connections = 10000
##慢查詢設置
slow-query-log=on
long_query_time = 2
#log-queries-not-using-indexes
##注釋掉,使用默認設置
## For InnoDB
innodb_buffer_pool_size = 1G
#innodb_additional_mem_pool_size = 128M
## Set .._log_file_size to 25 % of buffer pool size
#innodb_log_file_size = 128M
#innodb_log_buffer_size = 8M
innodb_flush_log_at_trx_commit = 1
#innodb_lock_wait_timeout = 50
#innodb_file_per_table=1
[mysqld2] basedir = /usr/local/mysql
character-set-server = utf8
port = 3307
socket = /tmp/mysql_3307.sock
datadir = /usr/local/mysql/data/dbdata_3307
pid-file = /usr/local/mysql/data/dbdata_3307/mysql.pid
log-error = /usr/local/mysql/data/dbdata_3307/mysql.err
server-id = 1
skip-character-set-client-handshake #忽略應用程序想要設置的其他字符集
init-connect='SET NAMES utf8' #連接時執行的SQL character-set-server=utf8 #服務端默認字符集
wait_timeout=1800 #請求的最大連接時間
interactive_timeout=1800 #和上一參數同時修改才會生效
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES #sql模式
log-bin = mysql-bin #打開二進制功能,MASTER主服務器必須打開此項
relay-log = mysql-bin #文件名格式
relay-log-index = mysql-bin.index #index文件名
#MySQL 5.6.10版本提供了更方便的基於GTID的復制功能,MySQL可以通過GTID自動識別上次同步的點,極大地方便了運維人員,減少出錯的幾率。
binlog-format=ROW #binlog格式
log-slave-updates=true #表示如果一個MASTER掛掉的話,另外一個馬上接管
gtid-mode=on #用於啟動GTID及滿足附屬的其它需求
enforce-gtid-consistency=true #
#report-port=port #從屬服務器的端口
#report-host=host #從屬服務器的主機名
master-info-repository=TABLE #啟用此兩項,可用於實現在崩潰時保證二進制及從服務器安全的功能
relay-log-info-repository=TABLE #
sync-master-info=1 #啟用之可確保無信息丟失
slave-parallel-workers=2 #設定從服務器的SQL線程數;0表示關閉多線程復制功能
binlog-checksum=CRC32 #
master-verify-checksum=1 #
slave-sql-verify-checksum=1 #啟用復制有關的所有校驗功能
binlog-rows-query-log_events=1 ###MySQL 5.6.10版本提供了更方便的基於GTID的復制功能,MySQL可以通過GTID自動識別上次同步的點,極大地方便了運維人員,減少出錯的幾率。 expire_logs_day=5 #超過5天的binlog刪除
max_binlog_size=104857600
#replicate-ignore-db = mysql #忽略不同步主從的數據庫
#replicate-ignore-db = information_schema #replicate-ignore-db = performance_schema
#replicate-ignore-db = test
#replicate-ignore-db = zabbix
#replicate-ignore-db = sysbench
#replicate-ignore-db = db_3307
##slave-skip-errors=0 #主從忽略錯誤數
##注釋掉,使用默認設置
#skip-external-locking
##innodb_force_recovery = 1
key_buffer_size = 256M
max_allowed_packet = 100M
#table_open_cache = 1024
#sort_buffer_size = 128M
#net_buffer_length = 8K
#read_buffer_size = 128M
#read_rnd_buffer_size = 256M
#myisam_sort_buffer_size = 32M
#character-set-server = utf8
skip-name-resolve
max_connections = 10000
##慢查詢設置
slow-query-log=on
long_query_time = 2
#log-queries-not-using-indexes
##注釋掉,使用默認設置
## For InnoDB
innodb_buffer_pool_size = 1G
#innodb_additional_mem_pool_size = 128M
## Set .._log_file_size to 25 % of buffer pool size
#innodb_log_file_size = 128M
#innodb_log_buffer_size = 8M
innodb_flush_log_at_trx_commit = 1
#innodb_lock_wait_timeout = 50
#innodb_file_per_table=1
[mysqld3] basedir = /usr/local/mysql
character-set-server = utf8
port = 3308
socket = /tmp/mysql_3308.sock
datadir = /usr/local/mysql/data/dbdata_3308
pid-file = /usr/local/mysql/data/dbdata_3308/mysql.pid
log-error = /usr/local/mysql/data/dbdata_3308/mysql.err
server-id = 1 skip-character-set-client-handshake #忽略應用程序想要設置的其他字符集
init-connect='SET NAMES utf8' #連接時執行的SQL
character-set-server=utf8 #服務端默認字符集
wait_timeout=1800 #請求的最大連接時間
interactive_timeout=1800 #和上一參數同時修改才會生效
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES #sql模式
log-bin = mysql-bin #打開二進制功能,MASTER主服務器必須打開此項
relay-log = mysql-bin #文件名格式
relay-log-index = mysql-bin.index #index文件名
#MySQL 5.6.10版本提供了更方便的基於GTID的復制功能,MySQL可以通過GTID自動識別上次同步的點,極大地方便了運維人員,減少出錯的幾率。
binlog-format=ROW #binlog格式
log-slave-updates=true #表示如果一個MASTER掛掉的話,另外一個馬上接管
gtid-mode=on #用於啟動GTID及滿足附屬的其它需求
enforce-gtid-consistency=true #
#report-port=port #從屬服務器的端口
#report-host=host #從屬服務器的主機名
master-info-repository=TABLE #啟用此兩項,可用於實現在崩潰時保證二進制及從服務器安全的功能
relay-log-info-repository=TABLE #
sync-master-info=1 #啟用之可確保無信息丟失
slave-parallel-workers=2 #設定從服務器的SQL線程數;0表示關閉多線程復制功能
binlog-checksum=CRC32 #
master-verify-checksum=1 #
slave-sql-verify-checksum=1 #啟用復制有關的所有校驗功能
binlog-rows-query-log_events=1 ###MySQL 5.6.10版本提供了更方便的基於GTID的復制功能,MySQL可以通過GTID自動識別上次同步的點,極大地方便了運維人員,減少出錯的幾率。 expire_logs_day=5 #超過5天的binlog刪除
max_binlog_size=104857600
#replicate-ignore-db = mysql #忽略不同步主從的數據庫
#replicate-ignore-db = information_schema
#replicate-ignore-db = performance_schema
#replicate-ignore-db = test
#replicate-ignore-db = zabbix
#replicate-ignore-db = sysbench
#replicate-ignore-db = db_3308
##slave-skip-errors=0 #主從忽略錯誤數
##注釋掉,使用默認設置
#skip-external-locking
##innodb_force_recovery = 1
key_buffer_size = 256M
max_allowed_packet = 100M
#table_open_cache = 1024
#sort_buffer_size = 128M
#net_buffer_length = 8K
#read_buffer_size = 128M
#read_rnd_buffer_size = 256M
#myisam_sort_buffer_size = 32M
#character-set-server = utf8
skip-name-resolve
max_connections = 10000
##慢查詢設置
slow-query-log=on
long_query_time = 2
#log-queries-not-using-indexes
##注釋掉,使用默認設置
## For InnoDB
innodb_buffer_pool_size = 1G
#innodb_additional_mem_pool_size = 128M
## Set .._log_file_size to 25 % of buffer pool size
#innodb_log_file_size = 128M
#innodb_log_buffer_size = 8M
innodb_flush_log_at_trx_commit = 1
#innodb_lock_wait_timeout = 50
#innodb_file_per_table=1
[mysqldump] quick max_allowed_packet = 256M [mysql] no-auto-rehash
prompt=\\u@\\d \\R:\\m>
# Remove the next comment character if you are not familiar with SQL
#safe-updates
[myisamchk]
key_buffer_size = 512M
sort_buffer_size = 512M
read_buffer = 8M
write_buffer = 8M
[mysqlhotcopy]
interactive-timeout

十二、啟動所有實例

/usr/local/mysql/bin/mysqld_multi start 1

/usr/local/mysql/bin/mysqld_multi start 2

/usr/local/mysql/bin/mysqld_multi start 3


登錄MySQL多實例
mysql -uroot -S /tmp/mysql_3306.sock

mysql -uroot -S /tmp/mysql_3307.sock

mysql -uroot -S /tmp/mysql_3308.sock


並且修改各自的密碼為my.cnf配置檔中[mysqld_multi]中指定的密碼。


root@(none) 16:09>grant all privileges on *.* to root@'localhost' identified by 'password';
root@(none) 16:09>grant all privileges on *.* to root@'127.0.0.1' identified by 'password';
root@(none) 16:09>grant all privileges on *.* to root@'%' identified by 'password';

其實這里有一點問題,就是[mysqld_multi]中設置的賬戶,其實它是用來管理mysqld_multi(多實例進程的啟動與關閉)的,如果這邊的賬戶和當前庫(實例中的所有庫)的賬戶不匹配,則會發生一些奇怪的問題,例如你可以開啟這個mysql多實例進程,但無法關閉,甚至是kill ${PID}之后它又會重新啟動。

那么,以后就可以通過下面方式來連接MySQL了

mysql -uroot -ppassword -S /tmp/mysql_3306.sock
mysql -uroot -ppassword -S /tmp/mysql_3307.sock
mysql -uroot -ppassword -S /tmp/mysql_3308.sock
            <link rel="stylesheet" href="http://csdnimg.cn/release/phoenix/production/markdown_views-d4dade9c33.css">
                </div>


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM