複製的步驟:
1.在主庫上開啓二進制日誌,把數據更改記錄到二進制日誌(binary log)中.
mysql會按照事物提交的順序而非每條語句的執行順序來記錄二進制日誌,在記錄二進制日誌後,主庫會告訴存儲引擎能夠提交事物。
2.從庫將主庫上的二進制日誌複製到本身的中繼日誌(relay log)中
從庫會啓動一個I/O線程,I/O線程跟主庫創建一個客戶端鏈接,而後主庫上會啓動一個binary dump線程,用來讀取主庫上的二進制日誌中的事件。不會對事件進行輪詢,若是該線程同步上主庫,進入休眠狀態,直到主庫發送信號量通知其有新的事件產生纔會被喚醒。
3.從庫讀取中繼日誌的事件,將其重放到從庫上執行,從而時間從庫數據的更新。
複製解決的問題:
1.數據庫分佈:能夠隨意中止或開始複製,並在不一樣的地理位置來分佈數據備份,儘可能保持網絡環境的穩定,低延遲鏈接。
負載均衡:在讀取操做分佈到多臺從服務器上,實現對密集型應用的優化。
備份:對備份來講是技術上的補充。
高可用和故障切換:避免MYSQL單點故障,設計良好的故障切換可以縮短宕機時間。
複製的方式:
statement/row/mixed
基於row複製是從mysql5.1版本加入。兩種方式都是經過在主庫上記錄二進制日誌,在從庫重放日誌的方式來實現異步的數據複製。大的語句可能致使從庫產生幾秒,甚至幾分鐘的延遲。
####mysql複製
(1)dump thread:當從服務器來複制時,dump會去讀取二進制日誌的語句併發送給從服務器
(2)io thread:在從服務器由io thread到主服務上去請求二進制日誌中語句的內容。每隔一段時間就會啓動,io thread到主服務器上查看二進制日誌是否有變化。若是有變化則就請求傳輸,一條語句複製過來。
(3)SQL thread(單線程):io thread獲取到以後將其存儲到relay log中。一條語句一條語句執行。
Mysql複製有三個種方式:異步,同步,半同步
1)異步:主服務器的修改操做本地完成就認爲完成。至於後面的事,並不理會
2)同步指定是:主服務器涉及的修改操做,要等待從服務器也完成
3)半同步:在一主多從的環境中,只等待一臺從服務器同步完成操做。設置一個等待超時時間,若是超過這個時間,則降級爲異步。在5.5可使用半同步,google公司提供一個補丁。半同步若是沒法在指定時間完成-->自動 降到異步模式。
mysql
####mysql複製
一.搭建一個master對應1個slave
mysql5.5複製配置
1.規劃網絡和主從機器
master:10.10.54.64
slave:10.10.54.67
2.master config
log-bin=master-bin
server-id=1
binlog_formate=mixed
3.slave config
log-bin=slave-bin
binlog_formate=mixed
server-id=10
必須大於主
4.在master上面建立一個複製用戶並授予權限
mysql> grant replication slave on *.* to 'gyf'@'10.10.54.67' identified by 'aaa12345';
mysql> flush privileges;
//在從上測試是否能用複製用戶登陸
[root@gyf ~]# mysql -ugyf -paaa12345 -h10.10.54.64
5.查看master上二進制日誌和position位置
mysql> show master status;
+-------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+-------------------+----------+--------------+------------------+
| master-bin.000001 | 107 | | |
+-------------------+----------+--------------+------------------+
CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=107;
拓展:重置master reset master
6.備份master上的數據,把備份maste數據庫還原到從庫上
[root@gyf ~]# mysqldump -uroot -paaa12345 --databases employees |mysql -uroot -paaa12345 -h10.10.54.67
[root@nan86 tmp]# mysqldump -uroot -paaa12345 --master-data=2 --single-transaction --flush-logs --database employees >employees.sql
[root@gyf ~]# mysqldump -uroot -paaa12345 --databases employees |mysql -uroot -paaa12345 -h10.10.54.67
[root@gyf tmp]# mysql -uroot -paaa12345 -h10.10.54.67<employees.sql
ERROR 1130 (HY000): Host '10.10.54.64' is not allowed to connect to this MySQL server
mysql> grant all privileges on *.* to root@10.10.54.64 identified by 'aaa12345';
mysql> flush privileges;
[root@nan86 tmp]# mysql -uroot -paaa12345 -h10.10.54.67<employees.sql
7.在slave上面change master操做
mysql> change master to master_host='10.10.54.64',master_user='gyf',
master_password='aaa12345',
master_log_file='master-bin.000001',master_log_pos=107;
8.查看slave狀態
肯定slave上的I/O線程和SQL線程狀態爲YES
mysql> show slave status\G;
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 10.10.54.64
Master_User: gyf
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: master-bin.000001
Read_Master_Log_Pos: 107
Relay_Log_File: nan85-relay-bin.000004
Relay_Log_Pos: 254
Relay_Master_Log_File: master-bin.000003
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
//能夠單獨停掉某一個線程
mysql> STOP SLAVE IO_THREAD;
mysql> STOP SLAVE SQL_THREAD;
9.在slave上啓動slave
mysql> start slave;
###測試
在master上
mysql> create database a ;
Query OK, 1 row affected (0.00 sec)
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| a |
| employees |
| master |
| mysql |
| performance_schema |
| test |
| tt |
+--------------------+
在slave上顯示
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| a |
| employees |
| master |
| mysql |
| performance_schema |
| test |
| tt |
+--------------------+
6 rows in set (0.00 sec)
在master上建立刪除添加數據,在slave上都能同步。
sql