需求
在實際生產環境中,如果對數據庫的讀寫都在同一塊數據庫服務器中操作,無論是在安全性、高可用性,還是高併發等各個方面都是完全不能滿足實際需求的
解決方案
一般都是通過主從複製(Master- Slave) 的方式來同步數據,再通過讀取分離來提升數據庫的併發負載能力
主從複製原理
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.100.0 #本地是時鐘源
fudge 127.127.100.0 stratum 8 #設置時間層級爲8
3.啓動服務
service ntpd start
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.查看主服務器狀態
四.從服務器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='adm',
master_password='123',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='adm',
master_password='123',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;
2.去從服務器1上 show databases;
3.去從服務器2上 show databases;