Java知識分享網 - 輕松學習從此開始!????

Java知識分享網

Java1234官方群25:java1234官方群25
Java1234官方群25:838462530
     

GIT視頻教程(結合github,碼云)免費領取

SpringBoot打造全棧在線教育平臺實戰課程

SpringBoot打造企業級進銷存

Java1234 VIP課程

領取微信掃碼登錄Java實現視頻教程

Java1234至尊VIP(特價活動)
當前位置: 主頁 > Java文檔 > Java基礎相關 >

mysql-讀寫分離 PDF 下載


分享到:
時間:2020-08-11 10:31來源:http://www.248787.tw 作者:小鋒  侵權舉報
mysql-讀寫分離 PDF 下載
失效鏈接處理
mysql-讀寫分離 PDF 下載


本站整理下載:
提取碼:ag63 
 
 
相關截圖:
 
主要內容:

Myql主從復制與讀寫分離
主從復制
 
概念
影響MySQL-A數據庫的操作,在數據庫執行后,都會寫入本地的日志系統A中。
 假設,實時的將變化了的日志系統中的數據庫事件操作,在MYSQL-A的3306端口,通過網絡發給MYSQL-B。
 MYSQL-B收到后,寫入本地日志系統B,然后一條條的將數據庫事件在數據庫中完成。
 那么,MYSQL-A的變化,MYSQL-B也會變化,這樣就是所謂的MYSQL的復制,即MYSQL replication。
 在上面的模型中,MYSQL-A就是主服務器,即master,MYSQL-B就是從服務器,即slave。
 日志系統A,其實它是MYSQL的日志類型中的二進制日志,也就是專門用來保存修改數據庫表的所有動作,即bin log。【注意MYSQL會在執行語句之后,釋放鎖之前,寫入二進制日志,確保事務安全】
 日志系統B,并不是二進制日志,由于它是從MYSQL-A的二進制日志復制過來的,并不是自己的數據庫變化產生的,有點接力的感覺,稱為中繼日志,即relay log。
 可以發現,通過上面的機制,可以保證MYSQL-A和MYSQL-B的數據庫數據一致,但是時間上肯定有延遲,即MYSQL-B的數據是滯后的。
【即便不考慮什么網絡的因素,MYSQL-A的數據庫操作是可以并發的執行的,但是MYSQL-B只能從relay log中讀一條,執行下。因此MYSQL-A的寫操作很頻繁,MYSQL-B很可能跟不上。】
解決問題
數據如何不被丟失
備份
讀寫分離
數據庫負載均衡
高可用
 
環境搭建
1.準備環境
兩臺windows操作系統 ip分別為: 172.27.185.1(主)、172.27.185.2(從)
2.連接到主服務(172.27.185.1)服務器上,給從節點分配賬號權限。
GRANT REPLICATION SLAVE ON *.* TO 'root'@'172.27.185.2' IDENTIFIED BY 'root';
3.在主服務my.ini文件新增
server-id=200
log-bin=mysql-bin
relay-log=relay-bin
relay-log-index=relay-bin-index
重啟mysql服務
4.在從服務my.ini文件新增
server-id = 210
replicate-do-db =itmayiedu #需要同步數據庫
重啟mysql服務
5.從服務同步主數據庫
stop slave;
change
master to master_host='172.27.185.1',master_user='root',master_password='root',
master_port=3306, master_log_pos=713, master_log_file='mysql-bin.000001';
start slave;
show slave status;
注意事項
①一定要在同一個局域網中
②使用360WiFi創建局域網
③最好把防火墻全部關閉掉
什么是讀寫分離
在數據庫集群架構中,讓主庫負責處理事務性查詢,而從庫只負責處理select查詢,讓兩者分工明確達到提高數據庫整體讀寫性能。當然,主數據庫另外一個功能就是負責將事務性查詢導致的數據變更同步到從庫中,也就是寫操作。
讀寫分離的好處
 1)分攤服務器壓力,提高機器的系統處理效率
    讀寫分離適用于讀遠比寫的場景,如果有一臺服務器,當select很多時,update和delete會被這些select訪問中的數據堵塞,等待select結束,并發性能并不高,而主從只負責各自的寫和讀,極大程度的緩解X鎖和S鎖爭用;
   假如我們有1主3從,不考慮上述1中提到的從庫單方面設置,假設現在1分鐘內有10條寫入,150條讀取。那么,1主3從相當于共計40條寫入,而讀取總數沒變,因此平均下來每臺服務器承擔了10條寫入和50條讀取(主庫不承擔讀取操作)。因此,雖然寫入沒變,但是讀取大大分攤了,提高了系統性能。另外,當讀取被分攤后,又間接提高了寫入的性能。所以,總體性能提高了,說白了就是拿機器和帶寬換性能;
  2)增加冗余,提高服務可用性,當一臺數據庫服務器宕機后可以調整另外一臺從庫以最快速度恢復服務
 
主從復制原理
 依賴于二進制日志,binary-log.
 二進制日志中記錄引起數據庫發生改變的語句
  Insert 、delete、update、create table
Scale-up與Scale-out區別
Scale Out是指Application可以在水平方向上擴展。一般對數據中心的應用而言,Scale out指的是當添加更多的機器時,應用仍然可以很好的利用這些機器的資源來提升自己的效率從而達到很好的擴展性。
Scale Up是指Application可以在垂直方向上擴展。一般對單臺機器而言,Scale Up值得是當某個計算節點(機器)添加更多的CPU Cores,存儲設備,使用更大的內存時,應用可以很充分的利用這些資源來提升自己的效率從而達到很好的擴展性。
MyCat
什么是  Mycat
是一個開源的分布式數據庫系統,但是因為數據庫一般都有自己的數據庫引擎,而Mycat并沒有屬于自己的獨有數據庫引擎,所有嚴格意義上說并不能算是一個完整的數據庫系統,只能說是一個在應用和數據庫之間起橋梁作用的中間件。
在Mycat中間件出現之前,MySQL主從復制集群,如果要實現讀寫分離,一般是在程序段實現,這樣就帶來了一個問題,即數據段和程序的耦合度太高,如果數據庫的地址發生了改變,那么我的程序也要進行相應的修改,如果數據庫不小心掛掉了,則同時也意味著程序的不可用,而對于很多應用來說,并不能接受;
 
  引入Mycat中間件能很好地對程序和數據庫進行解耦,這樣,程序只需關注數據庫中間件的地址,而無需知曉底層數據庫是如何提供服務的,大量的通用數據聚合、事務、數據源切換等工作都由中間件來處理;
  Mycat中間件的原理是對數據進行分片處理,從原有的一個庫,被切分為多個分片數據庫,所有的分片數據庫集群構成完成的數據庫存儲,有點類似磁盤陣列中的RAID0.


 

------分隔線----------------------------
鋒哥公眾號


鋒哥微信


關注公眾號
【Java資料站】
回復 666
獲取 
66套java
從菜雞到大神
項目實戰課程
体育彩票开奖时间