其實(shí)Mysql多實(shí)例就是在一個(gè) mysql 服務(wù)上面啟動(dòng)三個(gè)實(shí)例,相當(dāng)于三個(gè)分離開來的數(shù)據(jù)庫,至于為什么要做這個(gè),你也可以選擇分別安裝三個(gè)MySQL,只是過于麻煩,多實(shí)例中只需要一個(gè)配置檔my.cnf,并且通過mysql_330x.sock 便于管理數(shù)據(jù)庫。
其實(shí)MySQL多實(shí)例之后也可以做主從同步及讀寫分離,跟原來是一樣的,只是同步的時(shí)候端口有變化而已~
下面我來做MySQL多實(shí)例的環(huán)境搭建,至于如何用,怎么用,那就看你需求了
安裝簡(jiǎn)介
用戶名:mysql
安裝目錄:/usr/local/mysql
實(shí)例1數(shù)據(jù)目錄 : /usr/local/mysql/data/dbdata_3306
實(shí)例2數(shù)據(jù)目錄 : /usr/local/mysql/data/dbdata_3307
實(shí)例3數(shù)據(jù)目錄 : /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
四、創(chuàng)建數(shù)據(jù)目錄?
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
八、初始化數(shù)據(jù)庫
/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
九、設(shè)置鏈接?
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/
十、設(shè)置權(quán)限?
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_safemysqladmin = /usr/local/mysql/bin/mysqladminuser = rootpassword = 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#忽略應(yīng)用程序想要設(shè)置的其他字符集
init-connect='SET NAMES utf8'#連接時(shí)執(zhí)行的SQL
character-set-server=utf8#服務(wù)端默認(rèn)字符集
wait_timeout=1800#請(qǐng)求的最大連接時(shí)間
interactive_timeout=1800#和上一參數(shù)同時(shí)修改才會(huì)生效
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES#sql模式
log-bin= mysql-bin#打開二進(jìn)制功能,MASTER主服務(wù)器必須打開此項(xiàng)
relay-log= mysql-bin#文件名格式
relay-log-index= mysql-bin.index#index文件名
##MySQL5.6.10版本提供了更方便的基于GTID的復(fù)制功能,MySQL可以通過GTID自動(dòng)識(shí)別上次同步的點(diǎn),極大地方便了運(yùn)維人員,減少出錯(cuò)的幾率。
binlog-format=ROW#binlog格式
log-slave-updates=true#表示如果一個(gè)MASTER掛掉的話,另外一個(gè)馬上接管
gtid-mode=on#用于啟動(dòng)GTID及滿足附屬的其它需求
enforce-gtid-consistency=true#
#report-port=port? ? ? ? ? ? ? ? ? ? ? ? ? #從屬服務(wù)器的端口
#report-host=host? ? ? ? ? ? ? ? ? ? ? ? ? #從屬服務(wù)器的主機(jī)名
master-info-repository=TABLE#啟用此兩項(xiàng),可用于實(shí)現(xiàn)在崩潰時(shí)保證二進(jìn)制及從服務(wù)器安全的功能
relay-log-info-repository=TABLE#
sync-master-info=1#啟用之可確保無信息丟失
slave-parallel-workers=2#設(shè)定從服務(wù)器的SQL線程數(shù);0表示關(guān)閉多線程復(fù)制功能
binlog-checksum=CRC32#
master-verify-checksum=1#
slave-sql-verify-checksum=1#啟用復(fù)制有關(guān)的所有校驗(yàn)功能
binlog-rows-query-log_events=1###MySQL5.6.10版本提供了更方便的基于GTID的復(fù)制功能,MySQL可以通過GTID自動(dòng)識(shí)別上次同步的點(diǎn),極大地方便了運(yùn)維人員,減少出錯(cuò)的幾率。
expire_logs_day=5#超過5天的binlog刪除
max_binlog_size=104857600
#replicate-ignore-db = mysql? ? ? ? ? ? ? ? ? ? ? ? #忽略不同步主從的數(shù)據(jù)庫
#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#主從忽略錯(cuò)誤數(shù)
##注釋掉,使用默認(rèn)設(shè)置
#skip-external-locking
##innodb_force_recovery =1
key_buffer_size =256Mmax_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
##慢查詢?cè)O(shè)置
slow-query-log=on
long_query_time =2
#log-queries-not-using-indexes
##注釋掉,使用默認(rèn)設(shè)置
##ForInnoDB
innodb_buffer_pool_size =1G
#innodb_additional_mem_pool_size =128M
##Set.._log_file_sizeto25%ofbuffer poolsize
#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#忽略應(yīng)用程序想要設(shè)置的其他字符集
init-connect='SET NAMES utf8'#連接時(shí)執(zhí)行的SQLcharacter-set-server=utf8#服務(wù)端默認(rèn)字符集
wait_timeout=1800#請(qǐng)求的最大連接時(shí)間
interactive_timeout=1800#和上一參數(shù)同時(shí)修改才會(huì)生效
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES#sql模式
log-bin= mysql-bin#打開二進(jìn)制功能,MASTER主服務(wù)器必須打開此項(xiàng)
relay-log= mysql-bin#文件名格式
relay-log-index= mysql-bin.index#index文件名
#MySQL5.6.10版本提供了更方便的基于GTID的復(fù)制功能,MySQL可以通過GTID自動(dòng)識(shí)別上次同步的點(diǎn),極大地方便了運(yùn)維人員,減少出錯(cuò)的幾率。
binlog-format=ROW#binlog格式
log-slave-updates=true#表示如果一個(gè)MASTER掛掉的話,另外一個(gè)馬上接管
gtid-mode=on#用于啟動(dòng)GTID及滿足附屬的其它需求
enforce-gtid-consistency=true#
#report-port=port? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? #從屬服務(wù)器的端口
#report-host=host? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? #從屬服務(wù)器的主機(jī)名
master-info-repository=TABLE#啟用此兩項(xiàng),可用于實(shí)現(xiàn)在崩潰時(shí)保證二進(jìn)制及從服務(wù)器安全的功能
relay-log-info-repository=TABLE#
sync-master-info=1#啟用之可確保無信息丟失
slave-parallel-workers=2#設(shè)定從服務(wù)器的SQL線程數(shù);0表示關(guān)閉多線程復(fù)制功能
binlog-checksum=CRC32#
master-verify-checksum=1#
slave-sql-verify-checksum=1#啟用復(fù)制有關(guān)的所有校驗(yàn)功能
binlog-rows-query-log_events=1###MySQL5.6.10版本提供了更方便的基于GTID的復(fù)制功能,MySQL可以通過GTID自動(dòng)識(shí)別上次同步的點(diǎn),極大地方便了運(yùn)維人員,減少出錯(cuò)的幾率。expire_logs_day=5#超過5天的binlog刪除
max_binlog_size=104857600
#replicate-ignore-db = mysql? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? #忽略不同步主從的數(shù)據(jù)庫
#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#主從忽略錯(cuò)誤數(shù)
##注釋掉,使用默認(rèn)設(shè)置
#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
##慢查詢?cè)O(shè)置
slow-query-log=on
long_query_time =2
#log-queries-not-using-indexes
##注釋掉,使用默認(rèn)設(shè)置
##ForInnoDB
innodb_buffer_pool_size =1G
#innodb_additional_mem_pool_size =128M
##Set.._log_file_sizeto25%ofbuffer poolsize
#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=1skip-character-set-client-handshake#忽略應(yīng)用程序想要設(shè)置的其他字符集
init-connect='SET NAMES utf8'#連接時(shí)執(zhí)行的SQL
character-set-server=utf8#服務(wù)端默認(rèn)字符集
wait_timeout=1800#請(qǐng)求的最大連接時(shí)間
interactive_timeout=1800#和上一參數(shù)同時(shí)修改才會(huì)生效
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES#sql模式
log-bin= mysql-bin#打開二進(jìn)制功能,MASTER主服務(wù)器必須打開此項(xiàng)
relay-log= mysql-bin#文件名格式
relay-log-index= mysql-bin.index#index文件名
#MySQL5.6.10版本提供了更方便的基于GTID的復(fù)制功能,MySQL可以通過GTID自動(dòng)識(shí)別上次同步的點(diǎn),極大地方便了運(yùn)維人員,減少出錯(cuò)的幾率。
binlog-format=ROW#binlog格式
log-slave-updates=true#表示如果一個(gè)MASTER掛掉的話,另外一個(gè)馬上接管
gtid-mode=on#用于啟動(dòng)GTID及滿足附屬的其它需求
enforce-gtid-consistency=true#
#report-port=port? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? #從屬服務(wù)器的端口
#report-host=host? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? #從屬服務(wù)器的主機(jī)名
master-info-repository=TABLE#啟用此兩項(xiàng),可用于實(shí)現(xiàn)在崩潰時(shí)保證二進(jìn)制及從服務(wù)器安全的功能
relay-log-info-repository=TABLE#
sync-master-info=1#啟用之可確保無信息丟失
slave-parallel-workers=2#設(shè)定從服務(wù)器的SQL線程數(shù);0表示關(guān)閉多線程復(fù)制功能
binlog-checksum=CRC32#
master-verify-checksum=1#
slave-sql-verify-checksum=1#啟用復(fù)制有關(guān)的所有校驗(yàn)功能
binlog-rows-query-log_events=1###MySQL5.6.10版本提供了更方便的基于GTID的復(fù)制功能,MySQL可以通過GTID自動(dòng)識(shí)別上次同步的點(diǎn),極大地方便了運(yùn)維人員,減少出錯(cuò)的幾率。expire_logs_day=5#超過5天的binlog刪除
max_binlog_size=104857600
#replicate-ignore-db = mysql? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? #忽略不同步主從的數(shù)據(jù)庫
#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#主從忽略錯(cuò)誤數(shù)
##注釋掉,使用默認(rèn)設(shè)置
#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
##慢查詢?cè)O(shè)置
slow-query-log=on
long_query_time =2
#log-queries-not-using-indexes
##注釋掉,使用默認(rèn)設(shè)置
##ForInnoDB
innodb_buffer_pool_size =1G
#innodb_additional_mem_pool_size =128M
##Set.._log_file_sizeto25%ofbuffer poolsize
#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]quickmax_allowed_packet =256M[mysql]no-auto-rehash
prompt=\\u@\\d\\R:\\m>
# Remove thenextcommentcharacterifyouarenotfamiliarwithSQL
#safe-updates
[myisamchk]
key_buffer_size =512M
sort_buffer_size =512M
read_buffer =8M
write_buffer =8M
[mysqlhotcopy]
interactive-timeout
十二、啟動(dòng)所有實(shí)例?
/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多實(shí)例?
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>grantallprivilegeson*.*toroot@'localhost'identifiedby'password';root@(none)16:09>grantallprivilegeson*.*toroot@'127.0.0.1'identifiedby'password';root@(none)16:09>grantallprivilegeson*.*toroot@'%'identifiedby'password';
其實(shí)這里有一點(diǎn)問題,就是[mysqld_multi]中設(shè)置的賬戶,其實(shí)它是用來管理mysqld_multi(多實(shí)例進(jìn)程的啟動(dòng)與關(guān)閉)的,如果這邊的賬戶和當(dāng)前庫(實(shí)例中的所有庫)的賬戶不匹配,則會(huì)發(fā)生一些奇怪的問題,例如你可以開啟這個(gè)mysql多實(shí)例進(jìn)程,但無法關(guān)閉,甚至是kill ${PID}之后它又會(huì)重新啟動(dòng)。
那么,以后就可以通過下面方式來連接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
轉(zhuǎn)載:https://www.cnblogs.com/jpfss/p/8143564.html