中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Mysql數據庫的主從復制是怎樣的

發布時間:2021-09-28 11:42:41 來源:億速云 閱讀:140 作者:柒染 欄目:MySQL數據庫

這篇文章將為大家詳細講解有關Mysql數據庫的主從復制是怎樣的,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

需求
在實際生產環境中,如果對數據庫的讀寫都在同一塊數據庫服務器中操作,無論是在安全性、高可用性,還是高并發等各個方面都是完全不能滿足實際需求的

解決方案
一般都是通過主從復制(Master- Slave) 的方式來同步數據,再通過讀取分離來提升數據庫的并發負載能力

主從復制原理
Mysql數據庫的主從復制是怎樣的

1.在每個事務更新數據完成之前,主服務器在二進制文件記錄這些改變,寫入二進制日志文件完成后,主服務器通知儲存引擎提交事務。

2.Slave將Master的Binary log復制到其中繼日志。首先,Slave開始一個工作線程---I/O線程,I/O線程在Master上打開一個普通的連接,然后開始Binlog dump process。Binlog dump process從Master的二進制日志中讀取事件,如果已經跟上Master,它會睡眠并等待Master產生新的事件。I/O線程將這些事件寫入中繼日志。

3.SQL slave thread(SQL從線程)處理該過程的最后一步。SQL線程從中繼日志讀取事件,并重放其中的事件而更新Slave的數據,使其與Master中的數據一致。只要該線程與I/O線程保持一致,中繼日志通常會位于OS的緩存中,所以中繼日志的開銷很小

實驗環境

主機名    操作系統       IP地址         軟件包
master  CentOS 7.4  192.168.65.138  mysql-5.5.24.tar.gz
Slave1  CentOS 7.4  192.168.65.159  mysql-5.5.24.tar.gz
Slave2  CentOS 7.4  192.168.65.142  mysql-5.5.24.tar.gz

實驗目標
實現mysql數據庫主從復制

實驗步驟
一、建立時間同步環境,在主節點上搭建時間同步服務器
1.安裝NTP (系統默認已安裝)
2.配置NTP

vim /etc/ntp.conf                                 #添加如下2行
server 127.127.65.0                         #本地是時鐘源
fudge 127.127.65.0 stratum 8          #設置時間層級為8

3.啟動服務
systemctl start ntpd

4.在從節點上進行時間同步

yum install ntp ntpdate -y
/usr/sbin/ntpdate 192.168.65.138    #進行時間同步

5.關閉防火墻,啟動服務

systemctl start ntpd.service
systemctl stop firewalld.service 
setenforce 0

二、在master,slave1,slave2上安裝MySQL數據庫
在3個服務器上同時配置:
1.解壓軟件包
tar zxvf mysql-5.5.24.tar.gz -C /opt/

2.安裝環境包
yum install gcc  gcc-c++  make cmake  ncurses-devel bison libaio-devel  -y

3.添加mysql用戶并加入到mysql組

useradd  -s /sbin/nologin mysql
mkdir /usr/local/mysql

4.編譯安裝
cd /opt/mysql-5.5.24.tar.gz
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql      
-DMYSQL_UNIX_ADDR=/home/mysql/mysql.sock            
-DDEFAULT_CHARSET=utf8                            
-DDEFAULT_COLLATION=utf8_general_ci
-DWITH_EXTRA_CHARSETS=all                          
-DWITH_MYISAM_STORAGE_ENGINE=1                      
-DWITH_INNOBASE_STORAGE_ENGINE=1
-DWITH_MEMORY_STORAGE_ENGINE=1
-DWITH_READLINE=1                                  
-DENABLED_LOCAL_INFILE=1                            
-DMYSQL_DATADIR=/home/mysql                        
-DMYSQL_USER=mysql                                    
-DMYSQL_TCP_PORT=3306

make   &    make install

5.修改mysql安裝目錄的所有者,所屬組
chown -R mysql.mysql /usr/local/mysql

6.優化調整

export PATH=$PATH:/usr/local/mysql/bin/   \*開機時刷新*\          
cp support-files/my-medium.cnf /etc/my.cnf                  
cp support-files/mysql.server /etc/init.d/mysqld              
chmod 755 /etc/init.d/mysqld                             
chkconfig --add /etc/init.d/mysqld                      
chkconfig mysqld --level 35 on

7.初始化數據庫
/usr/local/mysql/scripts/mysql_install_db \
--user=mysql \
--ldata=/var/lib/mysql \
--basedir=/usr/local/mysql \
--datadir=/home/mysql

8.直接建立軟連接
ln -s /var/lib/mysql/mysql.sock /home/mysql/mysql.sock

9.修改配置文件

vi /etc/init.d/mysqld
basedir=/usr/local/mysql
datadir=/home/mysql

三.配置主服務器
1.修改配置文件

vim /etc/my.cnf     

server-id       = 11              #id號是唯一的,不能與其他服務器相同
log-bin=master-bin             #主服務器日志文件
log-slave-updates=true      #從服務器更新二進制日志

2.重啟mysql服務器
systemctl restart mysqld.service

3.登錄mysql,給從服務器授權

mysql -u root -p     #登錄mysql

GRANT REPLICATION SLAVE ON *.* TO 'myslave'@'192.168.65.%' IDENTIFIED BY '123456';  #給從服務器授權復制權限

FLUSH PRIVILEGES;      #刷新,讓設置生效

4.查看主服務器狀態
Mysql數據庫的主從復制是怎樣的

四.從服務器slave1配置
1.修改配置文件

vim /etc/my.cnf
server-id       = 22             # id號不能與其他服務器相同
relay-log=relay-log-bin     #從主服務器上同步日志文件記錄到本地
relay-log-index=slave-relay-bin.index   #定義relay-log的位置和名稱

2..登錄mysql,設置主從同步

mysql -u root -p   #登錄mysql

change master to master_host='192.168.65.159',master_user='myslave',
master_password='123456',master_log_file='master-bin.000002',master_log_pos=339;         #設置與主服務器同步

start slave;            #開啟同步
show slave status\G;             #查看狀態
 Slave_IO_Running: Yes          #yes表示io連接成功   
 Slave_SQL_Running: Yes      #yes表示mysql進程同步連接成功

五.從服務器slave2配置
1.修改配置文件

vim /etc/my.cnf

server-id       = 33             # id號不能與其他服務器相同
relay-log=relay-log-bin     #從主服務器上同步日志文件記錄到本地
relay-log-index=slave-relay-bin.index   #定義relay-log的位置和名稱

2..登錄mysql,設置主從同步

mysql -u root -p                #登錄mysql

change master to master_host='192.168.65.142',master_user='myslave',
master_password='123456',master_log_file='master-bin.000002',master_log_pos=339;        #設置主從同步

start slave;         #開啟同步功能
show slave status\G      #縱向查看同步連接狀態
 Slave_IO_Running: Yes          #yes表示io連接成功   
 Slave_SQL_Running: Yes      #yes表示mysql進程同步連接成功

六.驗證主從同步
1.在主服務器上 create database hhhh;
Mysql數據庫的主從復制是怎樣的

2.去從服務器1上 show databases;
Mysql數據庫的主從復制是怎樣的

3.去從服務器2上 show databases;
Mysql數據庫的主從復制是怎樣的

關于Mysql數據庫的主從復制是怎樣的就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

华容县| 江安县| 武平县| 高尔夫| 彰武县| 新民市| 兴城市| 运城市| 石景山区| 武义县| 涿州市| 康乐县| 嘉禾县| 隆尧县| 廉江市| 霸州市| 兴安县| 通化市| 乐昌市| 大新县| 会东县| 台北市| 保亭| 溧水县| 定陶县| 德昌县| 比如县| 皮山县| 张家川| 通山县| 丽水市| 耒阳市| 霍林郭勒市| 丰县| 静乐县| 手游| 花莲市| 海晏县| 诸城市| 克什克腾旗| 定襄县|