第1部份 大型分布式系統(tǒng)原理概述
結(jié)合業(yè)界主流的那些開源軟件,介紹和分析分布式系統(tǒng)的基本架構(gòu),組成部分,和實現(xiàn)原理。幾款常用的軟件以及功能功能性對比。
第2部份 分布式系統(tǒng)之網(wǎng)絡(luò)篇
Zookeeper入門
Zookeeper原理: Zookeeper原理介紹
Curator客戶端 : 對Zookeeper知名客戶端Curator進(jìn)行介紹,初步掌握其編程方式和用法。
迷你P2P網(wǎng)絡(luò)服務(wù)案例: 采用Zookeeper打造一個迷你P2P網(wǎng)絡(luò)系統(tǒng),節(jié)點之間相互交換名片,并且實現(xiàn)動態(tài)路由(節(jié)點宕機(jī)后其他節(jié)點自動感知并更新鏈路狀態(tài)),
第3部份 分布式存儲-文件系統(tǒng)篇
傳統(tǒng)的分布式文件系統(tǒng):Lustre、GlusterFS等經(jīng)典分布式文件系統(tǒng)分析
新型分布式文件系統(tǒng):介紹Ceph以及它跟Openstack的關(guān)系
互聯(lián)網(wǎng)領(lǐng)域中的小文件系統(tǒng):GridFS、FastDFS、TFS等分析學(xué)習(xí)
第4部份 分布式存儲-內(nèi)存篇
Hazelcast 詳解與分析
GridGain詳解與分析
MemCache詳解與分析
案例集錦:分布式系統(tǒng)存儲之基于內(nèi)存的兩表Join演示
第5部份 分布式存儲-數(shù)據(jù)庫篇
分布式數(shù)據(jù)庫原理 :介紹分布式數(shù)據(jù)庫的實現(xiàn)原理,特性、優(yōu)缺點、以及難點、熱點問題
Mycat前世今生:介紹目前基于MYSQL的熱門開源數(shù)據(jù)庫血統(tǒng),包括Cobar、tddl、Amoeba、以及目前很火的Mycat
案例集錦:某大型網(wǎng)站每天1億數(shù)據(jù)處的案例剖析
第6部份 分布式系統(tǒng)之云計算篇
主機(jī)虛擬化:介紹主機(jī)虛擬化的技術(shù)
網(wǎng)絡(luò)虛擬化:介紹網(wǎng)絡(luò)虛擬化的技術(shù)
存儲虛擬化:介紹存儲虛擬化的技術(shù)
云計算實踐:VirtualBox虛機(jī)集群搭建
Openstack原理介紹:介紹Openstack的體系、架構(gòu)、以及基本功能
案例集錦:基于RDO實現(xiàn)Openstack的安裝、部署等。
第7部份 分布式計算框架
Map-Reduce原理:介紹Map-Reduce的原理以及限制問題
Apache Storm應(yīng)用:學(xué)習(xí)Storm的原理并搭建測試環(huán)境,掌握基本編程
案例集錦:實現(xiàn)基于Storm的1000萬×1000萬的SQL Join和排序分頁
第8部份 通信機(jī)制的設(shè)計與實現(xiàn)
分布式通信機(jī)制概述:講解分布式通信的幾種常見機(jī)制,RPC調(diào)用、共享遠(yuǎn)程數(shù)據(jù)、消息隊列等。
RPC通信機(jī)制的原理 講解RPC通信機(jī)制的原理和實現(xiàn)方式:
案例集錦:設(shè)計并實現(xiàn)一個XML-RPC框架 動手設(shè)計和實現(xiàn)一個簡單的XML-RPC框架
第9部份 消息隊列
消息隊列機(jī)制介紹: 介紹古典的和新型的消息隊列機(jī)制的相同點和不同點
消息隊列通信的案例分析: 對一些采用消息隊列通信的系統(tǒng)做分析,掌握消息隊列用作分布式通信的一般設(shè)計原則
案例集錦:對知名開源消息中間件Kafka做一個入門學(xué)習(xí),并動手完成一個實際編程案例
第10部份 打造高可用系統(tǒng)(上)
高可用系統(tǒng)常規(guī)方案:介紹高可用系統(tǒng)的一些原理、實現(xiàn)機(jī)制、常規(guī)實現(xiàn)方案,包括基于硬件、軟件中間件、系統(tǒng)架構(gòu)等一些典型方案的實現(xiàn)
HA Proxy入門:介紹業(yè)界常規(guī)的HA Proxy的原理以及用法
實踐篇:Java開發(fā)一個類似HA Proxy的代理中間件
第11部份 打造高可用系統(tǒng)(下)
高可用集群套件中間件:介紹基于Corosync+Pacemaker的高可用集群套件中間件系統(tǒng)的原理、配置以及常見案例
Corosync技術(shù);
Pacemaker技術(shù);
Pacemaker實踐:實現(xiàn)基于Pacemaker的MYSQL高可用方案。
第12部份 Mycat架構(gòu)的分布式演進(jìn)背后的秘密
配置文件的分布式訪問問題:為什么最終選擇了Zookeeper
Mycat負(fù)載均衡的特殊性:為什么標(biāo)準(zhǔn)的HA Proxy還無法滿足Mycat的負(fù)載均衡要求
大數(shù)據(jù)Join背后的難題:數(shù)據(jù)、網(wǎng)絡(luò)、內(nèi)存和計算能力的矛盾和調(diào)和
第13部份 Java分布式系統(tǒng)中的高性能難題
高性能網(wǎng)絡(luò)框架的難題:AIO,NIO,Netty還是自己開發(fā)框架
堆內(nèi)和堆外存儲:堆內(nèi)與堆外存儲的差別,開源的堆外存儲組件為何鳳毛麟角
高性能事件派發(fā)機(jī)制:線程池模型的性能問題以及不為人知的Disruptor模型
第14部份 挑戰(zhàn)自我——全棧架構(gòu)師實踐
本節(jié)部份程的目標(biāo),是挑戰(zhàn)自我,開發(fā)一個基于Zeroc ICE+Zookeeper+Mycat+Android App+ Web系統(tǒng)的“身邊購”平臺,目標(biāo)是支持1億用戶,每天交易訂單為1億,商家自己在手機(jī)上通過Appp注冊自己的店鋪,店鋪包括地理位置信息,后臺審批通過,然后可以拍照上架自己的貨物,定價,發(fā)售。用戶登錄App以后,根據(jù)其地理位置信息,顯示附近的(默認(rèn)3公里)新品、熱門商品、二手商品等,并可以下單。
|