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_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#忽略應用程序想要設置的其他字符集

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文件名

##MySQL5.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###MySQL5.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 =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

##慢查詢設置

slow-query-log=on

long_query_time =2

#log-queries-not-using-indexes

##注釋掉,使用默認設置

##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#忽略應用程序想要設置的其他字符集

init-connect='SET NAMES utf8'#連接時執行的SQLcharacter-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文件名

#MySQL5.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###MySQL5.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

##注釋掉,使用默認設置

##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#忽略應用程序想要設置的其他字符集

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文件名

#MySQL5.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###MySQL5.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

##注釋掉,使用默認設置

##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

十二、啟動所有實例?

/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>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';

其實這里有一點問題,就是[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


轉載:https://www.cnblogs.com/jpfss/p/8143564.html

?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,983評論 6 537
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,772評論 3 422
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,947評論 0 381
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,201評論 1 315
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,960評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,350評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,406評論 3 444
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,104評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,914評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,089評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,647評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,340評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,753評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,007評論 1 289
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,834評論 3 395
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,106評論 2 375

推薦閱讀更多精彩內容