日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長(zhǎng)提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請(qǐng)做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線(xiàn)咨詢(xún)客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

目錄
  • 1. 準(zhǔn)備主服務(wù)器
  • 2. 準(zhǔn)備從服務(wù)器
  • 3. 啟動(dòng)主從同步
  • 4. 實(shí)現(xiàn)主從同步
  • 5. 停止和重置

很多人對(duì)主從數(shù)據(jù)庫(kù)有一個(gè)誤區(qū),把多個(gè)MySQL搭建在同一個(gè)服務(wù)器上,性能提升是不是很有限?這個(gè)理念是錯(cuò)誤的,數(shù)據(jù)庫(kù)的性能瓶頸主要是在IO和CPU負(fù)載過(guò)高,在同一臺(tái)服務(wù)器運(yùn)行多個(gè)數(shù)據(jù)庫(kù),能帶來(lái)更低的延遲,還能減少很多其他問(wèn)題,如果不是數(shù)據(jù)量大到了一定程度,在同一臺(tái)服務(wù)器上創(chuàng)建多個(gè)數(shù)據(jù)庫(kù)帶來(lái)的性能提示是非常可觀的。

服務(wù)器規(guī)劃:使用docker方式創(chuàng)建,主從服務(wù)器IP一致,端口號(hào)不一致,密碼都設(shè)置為123456

  • 主服務(wù)器:容器名mysql-master,端口3306
  • 從服務(wù)器:容器名mysql-slave1,端口3307
  • 從服務(wù)器:容器名mysql-slave2,端口3308

1. 準(zhǔn)備主服務(wù)器

docker run -d \
-p 3306:3306 \
-v /xk857/mysql/master/conf:/etc/mysql/conf.d \
-v /xk857/mysql/master/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
--name mysql-master \
mysql:8.0.29

默認(rèn)情況下MySQL的binlog日志是自動(dòng)開(kāi)啟的,可以通過(guò)如下配置定義一些可選配置

vim /xk857/mysql/master/conf/my.cnf

配置如下內(nèi)容,注意和新配置只有三行,其他配置可根據(jù)實(shí)際情況選用。

[mysqld]
# 服務(wù)器唯一id,默認(rèn)值1
server-id=1
# 設(shè)置日志格式,默認(rèn)值ROW
binlog_format=STATEMENT
# 二進(jìn)制日志名,默認(rèn)binlog
# log-bin=binlog
# 設(shè)置需要復(fù)制的數(shù)據(jù)庫(kù),默認(rèn)復(fù)制全部數(shù)據(jù)庫(kù)
#binlog-do-db=mytestdb
# 設(shè)置不需要復(fù)制的數(shù)據(jù)庫(kù)
#binlog-ignore-db=mysql
#binlog-ignore-db=infomation_schema

重啟MySQL容器

docker restart mysql-master

binlog格式說(shuō)明

  • binlog_format=STATEMENT:日志記錄的是主機(jī)數(shù)據(jù)庫(kù)的寫(xiě)指令,性能高,但是now()之類(lèi)的函數(shù)以及獲取系統(tǒng)參數(shù)的操作會(huì)出現(xiàn)主從數(shù)據(jù)不同步的問(wèn)題。
  • binlog_format=ROW(默認(rèn)):日志記錄的是主機(jī)數(shù)據(jù)庫(kù)的寫(xiě)后的數(shù)據(jù),批量操作時(shí)性能較差,解決now()或者 user()或者 @@hostname 等操作在主從機(jī)器上不一致的問(wèn)題。
  • binlog_format=MIXED:是以上兩種level的混合使用,有函數(shù)用ROW,沒(méi)函數(shù)用STATEMENT,但是無(wú)法識(shí)別系統(tǒng)變量

使用命令行登錄MySQL主服務(wù)器:

#進(jìn)入容器:env LANG=C.UTF-8 避免容器中顯示中文亂碼
docker exec -it mysql-master env LANG=C.UTF-8 /bin/bash
#進(jìn)入容器內(nèi)的mysql命令行
mysql -uroot -p123456
#修改默認(rèn)密碼校驗(yàn)方式
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';

主機(jī)中創(chuàng)建slave用戶(hù):

-- 創(chuàng)建slave用戶(hù)
CREATE USER 'xk857_slave'@'%';
-- 設(shè)置密碼
ALTER USER 'xk857_slave'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
-- 授予復(fù)制權(quán)限
GRANT REPLICATION SLAVE ON *.* TO 'xk857_slave'@'%';
-- 刷新權(quán)限
FLUSH PRIVILEGES;

主機(jī)中查詢(xún)master狀態(tài),執(zhí)行完此步驟后不要再操作主服務(wù)器MYSQL,防止主服務(wù)器狀態(tài)值變化

SHOW MASTER STATUS;

2. 準(zhǔn)備從服務(wù)器

可以配置多臺(tái)從機(jī)slave1、slave2…,這里以配置slave1slave2為例,映射到主機(jī)的端口為3307

docker run -d \
-p 3307:3306 \
-v /xk857/mysql/slave1/conf:/etc/mysql/conf.d \
-v /xk857/mysql/slave1/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
--name mysql-slave1 \
mysql:8.0.29

docker run -d \
-p 3308:3306 \
-v /xk857/mysql/slave2/conf:/etc/mysql/conf.d \
-v /xk857/mysql/slave2/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
--name mysql-slave2 \
mysql:8.0.29

創(chuàng)建MySQL從服務(wù)器配置文件:

vim /xk857/mysql/slave1/conf/my.cnf
vim /xk857/mysql/slave2/conf/my.cnf

配置如下內(nèi)容:

[mysqld]
# 服務(wù)器唯一id,每臺(tái)服務(wù)器的id必須不同,如果配置其他從機(jī),注意修改id
server-id=2
# 中繼日志名,默認(rèn)xxxxxxxxxxxx-relay-bin
#relay-log=relay-bin

[mysqld]
# 服務(wù)器唯一id,每臺(tái)服務(wù)器的id必須不同,如果配置其他從機(jī),注意修改id
server-id=3
# 中繼日志名,默認(rèn)xxxxxxxxxxxx-relay-bin
#relay-log=relay-bin

重啟MySQL容器

docker restart mysql-slave1
docker restart mysql-slave2

使用命令行登錄MySQL從服務(wù)器:

#進(jìn)入容器:
docker exec -it mysql-slave1 env LANG=C.UTF-8 /bin/bash
#進(jìn)入容器內(nèi)的mysql命令行
mysql -uroot -p123456
#修改默認(rèn)密碼校驗(yàn)方式
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';

#進(jìn)入容器:
docker exec -it mysql-slave2 env LANG=C.UTF-8 /bin/bash
#進(jìn)入容器內(nèi)的mysql命令行
mysql -uroot -p123456
#修改默認(rèn)密碼校驗(yàn)方式
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';

在從機(jī)上執(zhí)行以下SQL操作

CHANGE MASTER TO MASTER_HOST='192.168.31.115', 
MASTER_USER='xk857_slave',MASTER_PASSWORD='123456', MASTER_PORT=3306,
MASTER_LOG_FILE='binlog.000003',MASTER_LOG_POS=1357;

3. 啟動(dòng)主從同步

啟動(dòng)從機(jī)的復(fù)制功能,執(zhí)行SQL:

START SLAVE;
-- 查看狀態(tài)(不需要分號(hào))
SHOW SLAVE STATUS\G

**兩個(gè)關(guān)鍵進(jìn)程:**下面兩個(gè)參數(shù)都是Yes,則說(shuō)明主從配置成功!

使用Docker搭建MySQL主從數(shù)據(jù)庫(kù)的方法步驟

4. 實(shí)現(xiàn)主從同步

在主機(jī)中執(zhí)行以下SQL,在從機(jī)中查看數(shù)據(jù)庫(kù)、表和數(shù)據(jù)是否已經(jīng)被同步

CREATE DATABASE db_user;
USE db_user;
CREATE TABLE t_user (
 id BIGINT AUTO_INCREMENT,
 uname VARCHAR(30),
 PRIMARY KEY (id)
);
INSERT INTO t_user(uname) VALUES('zhang3');
INSERT INTO t_user(uname) VALUES(@@hostname);

5. 停止和重置

需要的時(shí)候,可以使用如下SQL語(yǔ)句

-- 在從機(jī)上執(zhí)行。功能說(shuō)明:停止I/O 線(xiàn)程和SQL線(xiàn)程的操作。
stop slave; 

-- 在從機(jī)上執(zhí)行。功能說(shuō)明:用于刪除SLAVE數(shù)據(jù)庫(kù)的relaylog日志文件,并重新啟用新的relaylog文件。
reset slave;

-- 在主機(jī)上執(zhí)行。功能說(shuō)明:刪除所有的binglog日志文件,并將日志索引文件清空,重新開(kāi)始所有新的日志文件。
-- 用于第一次進(jìn)行搭建主從庫(kù)時(shí),進(jìn)行主庫(kù)binlog初始化工作;
reset master;

分享到:
標(biāo)簽:主從 搭建 數(shù)據(jù)庫(kù) 服務(wù)器 步驟
用戶(hù)無(wú)頭像

網(wǎng)友整理

注冊(cè)時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊(cè)賬號(hào),推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過(guò)答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫(kù),初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績(jī)?cè)u(píng)定2018-06-03

通用課目體育訓(xùn)練成績(jī)?cè)u(píng)定