日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

RPC框架Dubbo分析

發(fā)布時間:2023/12/1 编程问答 59 豆豆
生活随笔 收集整理的這篇文章主要介紹了 RPC框架Dubbo分析 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
1,背景 隨著互聯(lián)網(wǎng)的發(fā)展,網(wǎng)站應(yīng)用的規(guī)模不斷擴(kuò)大,常規(guī)的垂直應(yīng)用架構(gòu)已無法應(yīng)對,分布式服務(wù)架構(gòu)以及流動計(jì)算架構(gòu)勢在必行,亟需一個治理系統(tǒng)確保架構(gòu)有條不紊的演進(jìn)
  • 單一應(yīng)用架構(gòu)
  • 當(dāng)網(wǎng)站流量很小時,只需一個應(yīng)用,將所有功能都部署在一起,以減少部署節(jié)點(diǎn)和成本
  • 此時,用于簡化增刪改查工作量的?數(shù)據(jù)訪問框架(ORM)?是關(guān)鍵
  • 垂直應(yīng)用架構(gòu)
  • 當(dāng)訪問量逐漸增大,單一應(yīng)用增加機(jī)器帶來的加速度越來越小,將應(yīng)用拆成互不相干的幾個應(yīng)用,以提升效率
  • 此時,用于加速前端頁面開發(fā)的?Web框架(MVC)?是關(guān)鍵
  • 分布式服務(wù)架構(gòu)
  • 當(dāng)垂直應(yīng)用越來越多,應(yīng)用之間交互不可避免,將核心業(yè)務(wù)抽取出來,作為獨(dú)立的服務(wù),逐漸形成穩(wěn)定的服務(wù)中心,使前端應(yīng)用能更快速的響應(yīng)多變的市場需求
  • 此時,用于提高業(yè)務(wù)復(fù)用及整合的?分布式服務(wù)框架(RPC)?是關(guān)鍵
  • 分布式服務(wù)RPC框架
  • 按業(yè)務(wù)線拆分
  • 部署分離
  • 每次發(fā)布只部署部分服務(wù)器
  • 每個節(jié)點(diǎn)可根據(jù)不同需求伸縮擴(kuò)展
  • 每個應(yīng)用之間更新,部署,運(yùn)行不影響
    • 團(tuán)隊(duì)分離
    • 數(shù)據(jù)分離
    • 停止RPC濫用,垂直業(yè)務(wù)內(nèi)優(yōu)先通過本地jar調(diào)用,跨業(yè)務(wù)才采用RPC調(diào)用
    • 正確的識別業(yè)務(wù)邏輯的歸屬,讓各個模塊最大化內(nèi)聚,從性能,可用性和維護(hù)性上減少耦合
  • 流動計(jì)算架構(gòu)
  • 當(dāng)服務(wù)越來越多,容量的評估,小服務(wù)資源的浪費(fèi)等問題逐漸顯現(xiàn),此時需增加一個調(diào)度中心基于訪問壓力實(shí)時管理集群容量,提高集群利用率
  • 此時,用于提高機(jī)器利用率的資源調(diào)度和治理中心(SOA)是關(guān)鍵
2,需求 在大規(guī)模服務(wù)化之前,應(yīng)用可能只是通過RMI或Hessian等工具,簡單的暴露和引用遠(yuǎn)程服務(wù),通過配置服務(wù)的URL地址進(jìn)行調(diào)用,通過F5等硬件進(jìn)行負(fù)載均衡
  • 當(dāng)服務(wù)越來越多時,服務(wù)URL配置管理變得非常困難,F5硬件負(fù)載均衡器的單點(diǎn)壓力也越來越大
  • 此時需要一個服務(wù)注冊中心,動態(tài)的注冊和發(fā)現(xiàn)服務(wù),使服務(wù)的位置透明
  • 并通過在消費(fèi)方獲取服務(wù)提供方地址列表,實(shí)現(xiàn)軟負(fù)載均衡和Failover,降低對F5硬件負(fù)載均衡器的依賴,也能減少部分成本
  • 當(dāng)進(jìn)一步發(fā)展,服務(wù)間依賴關(guān)系變得錯蹤復(fù)雜,甚至分不清哪個應(yīng)用要在哪個應(yīng)用之前啟動,架構(gòu)師都不能完整的描述應(yīng)用的架構(gòu)關(guān)系
  • 這時,需要自動畫出應(yīng)用間的依賴關(guān)系圖,以幫助架構(gòu)師理清理關(guān)系
  • 接著,服務(wù)的調(diào)用量越來越大,服務(wù)的容量問題就暴露出來,這個服務(wù)需要多少機(jī)器支撐?什么時候該加機(jī)器?
  • 為了解決這些問題,第一步,要將服務(wù)現(xiàn)在每天的調(diào)用量,響應(yīng)時間,都統(tǒng)計(jì)出來,作為容量規(guī)劃的參考指標(biāo)
  • 其次,要可以動態(tài)調(diào)整權(quán)重,在線上,將某臺機(jī)器的權(quán)重一直加大,并在加大的過程中記錄響應(yīng)時間的變化,直到響應(yīng)時間到達(dá)閥值,記錄此時的訪問量,再以此訪問量乘以機(jī)器數(shù)反推總?cè)萘?/li>
3,Dubbo架構(gòu)
  • Dubbo分層
  • 層次結(jié)構(gòu)
  • Business
  • Service
    • RPC
  • Config
  • Proxy
  • Registry
  • Cluster
  • Monitor
  • Protocol
    • Remoting
  • Exchange
  • Transport
  • Serialize
    • 層說明
  • config(配置層 )
  • 對外配置接口
  • 以ServiceConfig,?ReferenceConfig為中心,可以直接new配置類,也可以通過spring解析配置生成配置類
    • proxy(服務(wù)代理層)
  • 服務(wù)接口透明代理,生成服務(wù)的客戶端Stub和服務(wù)器端Skeleton
  • 以ServiceProxy為中心,擴(kuò)展接口為ProxyFactory
  • 選擇
  • Javassist?ProxyFactory
  • Jdk?ProxyFactory
    • registry( 注冊中心層)
  • 封裝服務(wù)地址的注冊與發(fā)現(xiàn)
  • 以服務(wù)URL為中心,擴(kuò)展接口為RegistryFactory,?Registry,?RegistryService
  • 選擇
  • Zookeeper
  • 支持基于網(wǎng)絡(luò)的集群方式,有廣泛周邊開源產(chǎn)品,建議使用dubbo-2.3.3以上版本(推薦使用)
  • 依賴于Zookeeper的穩(wěn)定性
    • Redis
  • 支持基于客戶端雙寫的集群方式,性能高
  • 要求服務(wù)器時間同步,用于檢查心跳過期臟數(shù)據(jù)
    • Multicast
  • 去中心化,不需要安裝注冊中心
  • 依賴于網(wǎng)絡(luò)拓普和路由,跨機(jī)房有風(fēng)險(xiǎn)
    • Simple
  • Dogfooding,注冊中心本身也是一個標(biāo)準(zhǔn)的RPC服務(wù)
  • 沒有集群支持,可能單點(diǎn)故障
    • cluster( 路由層)
  • 封裝多個提供者的路由及負(fù)載均衡,并橋接注冊中心
  • 以Invoker為中心,擴(kuò)展接口為Cluster,?Directory,?Router,?LoadBalance
  • Cluster選擇
  • Failover
  • 失敗自動切換,當(dāng)出現(xiàn)失敗,重試其它服務(wù)器,通常用于讀操作(推薦使用)
  • 重試會帶來更長延遲
    • Failfast
  • 快速失敗,只發(fā)起一次調(diào)用,失敗立即報(bào)錯,通常用于非冪等性的寫操作
  • 如果有機(jī)器正在重啟,可能會出現(xiàn)調(diào)用失敗
    • Failsafe
  • 失敗安全,出現(xiàn)異常時,直接忽略,通常用于寫入審計(jì)日志等操作
  • 調(diào)用信息丟失
    • Failback
  • 失敗自動恢復(fù),后臺記錄失敗請求,定時重發(fā),通常用于消息通知操作
  • 不可靠,重啟丟失
    • Forking
  • 并行調(diào)用多個服務(wù)器,只要一個成功即返回,通常用于實(shí)時性要求較高的讀操作
  • 需要浪費(fèi)更多服務(wù)資源
    • Broadcast
  • 廣播調(diào)用所有提供者,逐個調(diào)用,任意一臺報(bào)錯則報(bào)錯,通常用于更新提供方本地狀態(tài)
  • 速度慢,任意一臺報(bào)錯則報(bào)錯
    • Router選擇
  • Random
  • 隨機(jī),按權(quán)重設(shè)置隨機(jī)概率(推薦使用)
  • 在一個截面上碰撞的概率高,重試時,可能出現(xiàn)瞬間壓力不均
    • RoundRobin
  • 輪循,按公約后的權(quán)重設(shè)置輪循比率
  • 存在慢的機(jī)器累積請求問題,極端情況可能產(chǎn)生雪崩
    • LeastActive
  • 最少活躍調(diào)用數(shù),相同活躍數(shù)的隨機(jī),活躍數(shù)指調(diào)用前后計(jì)數(shù)差,使慢的機(jī)器收到更少請求
  • 不支持權(quán)重,在容量規(guī)劃時,不能通過權(quán)重把壓力導(dǎo)向一臺機(jī)器壓測容量
    • ConsistentHash
  • 一致性Hash,相同參數(shù)的請求總是發(fā)到同一提供者,當(dāng)某一臺提供者掛時,原本發(fā)往該提供者的請求,基于虛擬節(jié)點(diǎn),平攤到其它提供者,不會引起劇烈變動
  • 壓力分?jǐn)偛痪?/li>
    • 路由規(guī)則
  • 條件路由
  • 基于條件表達(dá)式的路由規(guī)則,功能簡單易用
  • 有些復(fù)雜多分支條件情況,規(guī)則很難描述
    • 腳本路由
  • 基于腳本引擎的路由規(guī)則,功能強(qiáng)大
  • 沒有運(yùn)行沙箱,腳本能力過于強(qiáng)大,可能成為后門
    • 容器
  • Spring
  • 自動加載META-INF/spring目錄下的所有Spring配置
    • Jetty
  • 啟動一個內(nèi)嵌Jetty,用于匯報(bào)狀態(tài)
  • 大量訪問頁面時,會影響服務(wù)器的線程和內(nèi)存
    • Log4j
  • 自動配置log4j的配置,在多進(jìn)程啟動時,自動給日志文件按進(jìn)程分目錄
  • 用戶不能控制log4j的配置,不靈活
    • monitor( 監(jiān)控層)
  • RPC調(diào)用次數(shù)和調(diào)用時間監(jiān)控
  • 以Statistics為中心,擴(kuò)展接口為MonitorFactory,?Monitor,?MonitorService
    • protocol( 遠(yuǎn)程調(diào)用層)
  • 封裝RPC調(diào)用
  • 以Invocation,?Result為中心,擴(kuò)展接口為Protocol,?Invoker,?Exporter
  • 選擇
  • Dubbo協(xié)議
  • 采用NIO復(fù)用單一長連接,并使用線程池并發(fā)處理請求,減少握手和加大并發(fā)效率,性能較好(推薦使用)
  • 適合于小數(shù)據(jù)量大并發(fā)的服務(wù)調(diào)用,以及服務(wù)消費(fèi)者機(jī)器數(shù)遠(yuǎn)大于服務(wù)提供者機(jī)器數(shù)的情況
  • Dubbo缺省協(xié)議不適合傳送大數(shù)據(jù)量的服務(wù),比如傳文件,傳視頻等,除非請求量很低
  • Dubbo協(xié)議缺省每服務(wù)每提供者每消費(fèi)者使用單一長連接,如果數(shù)據(jù)量較大,可以使用多個連接
  • 為防止被大量連接撐掛,可在服務(wù)提供方限制大接收連接數(shù),以實(shí)現(xiàn)服務(wù)提供方自我保護(hù)
  • 在大文件傳輸時,單一連接會成為瓶頸
  • 總結(jié)
  • 連接個數(shù):單連接
  • 連接方式:長連接
  • 傳輸協(xié)議:TCP
  • 傳輸方式:NIO異步傳輸
  • 序列化:Hessian二進(jìn)制序列化
  • 適用范圍:傳入傳出參數(shù)數(shù)據(jù)包較小(建議小于100K),消費(fèi)者比提供者個數(shù)多,單一消費(fèi)者無法壓滿提供者,盡量不要用dubbo協(xié)議傳輸大文件或超大字符串。
  • 適用場景:常規(guī)遠(yuǎn)程服務(wù)方法調(diào)用
    • Rmi協(xié)議
  • 可與原生RMI互操作,基于TCP協(xié)議
  • 偶爾會連接失敗,需重建Stub
    • Hessian協(xié)議
  • 可與原生Hessian互操作,基于HTTP協(xié)議
  • 需hessian.jar支持,http短連接的開銷大
  • Hessian協(xié)議用于集成Hessian的服務(wù),Hessian底層采用Http通訊,采用Servlet暴露服務(wù),Dubbo缺省內(nèi)嵌Jetty作為服務(wù)器實(shí)現(xiàn)
  • 可以和原生Hessian服務(wù)互操作
  • 提供者用Dubbo的Hessian協(xié)議暴露服務(wù),消費(fèi)者直接用標(biāo)準(zhǔn)Hessian接口調(diào)用
  • 或者提供方用標(biāo)準(zhǔn)Hessian暴露服務(wù),消費(fèi)方用Dubbo的Hessian協(xié)議調(diào)用
  • 基于Hessian的遠(yuǎn)程調(diào)用協(xié)議
    • 總結(jié)
  • 連接個數(shù):多連接
  • 連接方式:短連接
  • 傳輸協(xié)議:HTTP
  • 傳輸方式:同步傳輸
  • 序列化:Hessian二進(jìn)制序列化
  • 適用范圍:傳入傳出參數(shù)數(shù)據(jù)包較大,提供者比消費(fèi)者個數(shù)多,提供者壓力較大,可傳文件
  • 適用場景:頁面?zhèn)鬏?#xff0c;文件傳輸,或與原生hessian服務(wù)互操作
    • 約束
  • 參數(shù)及返回值需實(shí)現(xiàn)Serializable接口
  • 參數(shù)及返回值不能自定義實(shí)現(xiàn)List, Map, Number, Date, Calendar等接口,只能用JDK自帶的實(shí)現(xiàn),因?yàn)閔essian會做特殊處理,自定義實(shí)現(xiàn)類中的屬性值都會丟失
    • exchange( 信息交換層)
  • 封裝請求響應(yīng)模式,同步轉(zhuǎn)異步
  • 以Request, Response為中心,擴(kuò)展接口為Exchanger,?ExchangeChannel,?ExchangeClient,?ExchangeServer
    • transport( 網(wǎng)絡(luò)傳輸層)
  • 抽象mina和netty為統(tǒng)一接口
  • 以Message為中心,擴(kuò)展接口為Channel,?Transporter,?Client,?Server,?Codec
  • 選擇
  • Netty
  • 性能較好(推薦使用)
  • 一次請求派發(fā)兩種事件,需屏蔽無用事件
    • Mina
  • 老牌NIO框架,穩(wěn)定
  • 待發(fā)送消息隊(duì)列派發(fā)不及時,大壓力下,會出現(xiàn)FullGC
    • Grizzly
  • Sun的NIO框架,應(yīng)用于GlassFish服務(wù)器中
  • 線程池不可擴(kuò)展,Filter不能攔截下一Filter
    • serialize( 數(shù)據(jù)序列化層)
  • 可復(fù)用的一些工具
  • 擴(kuò)展接口為Serialization,?ObjectInput,?ObjectOutput,?ThreadPool
  • 選擇
  • Hessian
  • 性能較好,多語言支持(推薦使用)
  • Hessian的各版本兼容性不好,可能和應(yīng)用使用的Hessian沖突,Dubbo內(nèi)嵌了hessian3.2.1的源碼
    • Dubbo
  • 通過不傳送POJO的類元信息,在大量POJO傳輸時,性能較好
  • 當(dāng)參數(shù)對象增加字段時,需外部文件聲明
    • Json
  • 純文本,可跨語言解析,缺省采用FastJson解析
  • 性能較差
    • Java
  • Java原生支持
  • 性能較差
    • 關(guān)系說明
  • 在RPC中,Protocol是核心層,也就是只要有Protocol + Invoker + Exporter就可以完成非透明的RPC調(diào)用,然后在Invoker的主過程上Filter攔截點(diǎn)。
  • 圖中的Consumer和Provider是抽象概念,只是想讓看圖者更直觀的了解哪些類分屬于客戶端與服務(wù)器端,不用Client和Server的原因是Dubbo在很多場景下都使用Provider, Consumer, Registry, Monitor劃分邏輯拓普節(jié)點(diǎn),保持統(tǒng)一概念。
  • 而Cluster是外圍概念,所以Cluster的目的是將多個Invoker偽裝成一個Invoker,這樣其它人只要關(guān)注Protocol層Invoker即可,加上Cluster或者去掉Cluster對其它層都不會造成影響,因?yàn)橹挥幸粋€提供者時,是不需要Cluster的。
  • Proxy層封裝了所有接口的透明化代理,而在其它層都以Invoker為中心,只有到了暴露給用戶使用時,才用Proxy將Invoker轉(zhuǎn)成接口,或?qū)⒔涌趯?shí)現(xiàn)轉(zhuǎn)成Invoker,也就是去掉Proxy層RPC是可以Run的,只是不那么透明,不那么看起來像調(diào)本地服務(wù)一樣調(diào)遠(yuǎn)程服務(wù)。
  • 而Remoting實(shí)現(xiàn)是Dubbo協(xié)議的實(shí)現(xiàn),如果你選擇RMI協(xié)議,整個Remoting都不會用上,Remoting內(nèi)部再劃為Transport傳輸層和Exchange信息交換層,Transport層只負(fù)責(zé)單向消息傳輸,是對Mina,Netty,Grizzly的抽象,它也可以擴(kuò)展UDP傳輸,而Exchange層是在傳輸層之上封裝了Request-Response語義。
  • Registry和Monitor實(shí)際上不算一層,而是一個獨(dú)立的節(jié)點(diǎn),只是為了全局概覽,用層的方式畫在一起
  • Dubbo模塊分包
  • 模塊
  • dubbo-common 公共邏輯模塊,包括Util類和通用模型。
  • dubbo-remoting 遠(yuǎn)程通訊模塊,相當(dāng)于Dubbo協(xié)議的實(shí)現(xiàn),如果RPC用RMI協(xié)議則不需要使用此包。
  • dubbo-rpc 遠(yuǎn)程調(diào)用模塊,抽象各種協(xié)議,以及動態(tài)代理,只包含一對一的調(diào)用,不關(guān)心集群的管理。
  • dubbo-cluster 集群模塊,將多個服務(wù)提供方偽裝為一個提供方,包括:負(fù)載均衡,?容錯,路由等,集群的地址列表可以是靜態(tài)配置的,也可以是由注冊中心下發(fā)。
  • dubbo-registry 注冊中心模塊,基于注冊中心下發(fā)地址的集群方式,以及對各種注冊中心的抽象。
  • dubbo-monitor 監(jiān)控模塊,統(tǒng)計(jì)服務(wù)調(diào)用次數(shù),調(diào)用時間的,調(diào)用鏈跟蹤的服務(wù)。
  • dubbo-config 配置模塊,是Dubbo對外的API,用戶通過Config使用Dubbo,隱藏Dubbo所有細(xì)節(jié)。
  • dubbo-container 容器模塊,是一個Standlone的容器,以簡單的Main加載Spring啟動,因?yàn)榉?wù)通常不需要Tomcat/JBoss等Web容器的特性,沒必要用Web容器去加載服務(wù)
    • 與分層的不同點(diǎn)在于
  • container為服務(wù)容器,用于部署運(yùn)行服務(wù),沒有在層中畫出。
  • protocol層和proxy層都放在rpc模塊中,這兩層是rpc的核心,在不需要集群時(只有一個提供者),可以只使用這兩層完成rpc調(diào)用。
  • transport層和exchange層都放在remoting模塊中,為rpc調(diào)用的通訊基礎(chǔ)。
  • serialize層放在common模塊中,以便更大程度復(fù)用
  • 模型
  • Protocol是服務(wù)域,它是Invoker暴露和引用的主功能入口,它負(fù)責(zé)Invoker的生命周期管理
  • Invoker是實(shí)體域,它是Dubbo的核心模型,其它模型都向它靠擾,或轉(zhuǎn)換成它,它代表一個可執(zhí)行體,可向它發(fā)起invoke調(diào)用,它有可能是一個本地的實(shí)現(xiàn),也可能是一個遠(yuǎn)程的實(shí)現(xiàn),也可能一個集群實(shí)現(xiàn)
  • Invocation是會話域,它持有調(diào)用過程中的變量,比如方法名,參數(shù)等
  • 基本原則
  • 采用Microkernel + Plugin模式,Microkernel只負(fù)責(zé)組將Plugin,Dubbo自身的功能也是通過擴(kuò)展點(diǎn)實(shí)現(xiàn)的,也就是Dubbo的所有功能點(diǎn)都可被用戶自定義擴(kuò)展所替換
  • 采用URL作為配置信息的統(tǒng)一格式,所有擴(kuò)展點(diǎn)都通過傳遞URL攜帶配置信息
  • 擴(kuò)展點(diǎn)加載
  • Dubbo的擴(kuò)展點(diǎn)加載從JDK標(biāo)準(zhǔn)的SPI(Service Provider Interface)擴(kuò)展點(diǎn)發(fā)現(xiàn)機(jī)制加強(qiáng)而來
  • 在擴(kuò)展類的jar包內(nèi),放置擴(kuò)展點(diǎn)配置文件:META-INF/dubbo/接口全限定名,內(nèi)容為:配置名=擴(kuò)展實(shí)現(xiàn)類全限定名,多個實(shí)現(xiàn)類用換行符分隔
  • 注意:這里的配置文件是放在你自己的jar包內(nèi),不是dubbo本身的jar包內(nèi),Dubbo會全ClassPath掃描所有jar包內(nèi)同名的這個文件,然后進(jìn)行合并
  • Provider暴露服務(wù)的過程
  • 具體服務(wù)到Invoker的轉(zhuǎn)換
  • ServiceConfig:ref對外提供服務(wù)實(shí)際類
  • ProxyFactory:getInvoker()
  • JavassistProxyFactory
  • JdkProxyFactory
    • Invoker轉(zhuǎn)換為Exporter
  • Invoker:AbstractProxyInvoker的實(shí)例
  • Protocal:export()
  • DubboProtocol
  • Dubbo協(xié)議的Invoker轉(zhuǎn)為Exporter發(fā)生在DubboProtocol類的export方法,它主要是打開socket偵聽服務(wù),并接收客戶端發(fā)來的各種請求,通訊細(xì)節(jié)由Dubbo自己實(shí)現(xiàn)
    • HessianProtocol
    • InjvmProtocol
  • 它通過Spring或Dubbo或JDK來實(shí)現(xiàn)RMI服務(wù),通訊細(xì)節(jié)這一塊由JDK底層來實(shí)現(xiàn),這就省了不少工作量
    • RmiProtocol
    • WebServiceProtocol
    • Export
  • Consumer消費(fèi)服務(wù)的過程
  • 把遠(yuǎn)端服務(wù)轉(zhuǎn)為Invoker
  • ReferenceConfig
  • Protocol:refer()
  • DubboProtocol
  • HessianProtocol
  • InjvmProtocol
  • RmiProtocol
  • WebServiceProtocol
    • 把Invoker轉(zhuǎn)為客戶端需要的接口
  • Invoker
  • DubboInvoker
  • HessianInvoker
  • InjvmInvoker
  • RmiInvoker
  • WebServiceInvoker
    • ProxyFactory:getProxy()
  • JavassistProxyFactory
  • JdkProxyFactory
    • ref
    • 過程:首先ReferenceConfig類的init方法調(diào)用Protocol的refer方法生成Invoker實(shí)例(如上圖中的紅色部分),這是服務(wù)消費(fèi)的關(guān)鍵。接下來把Invoker轉(zhuǎn)換為客戶端需要的接口
  • 無處不在的Invoker
  • 由于Invoker是Dubbo領(lǐng)域模型中非常重要的一個概念,很多設(shè)計(jì)思路都是向它靠攏
  • 服務(wù)消費(fèi)者Invoker
  • 用戶代碼通過這個proxy調(diào)用其對應(yīng)的Invoker(DubboInvoker、 HessianRpcInvoker、 InjvmInvoker、 RmiInvoker、 WebServiceInvoker中的任何一個),而該Invoker實(shí)現(xiàn)了真正的遠(yuǎn)程服務(wù)調(diào)用
    • 服務(wù)提供者Invoker
  • 被封裝成為一個AbstractProxyInvoker實(shí)例,并新生成一個Exporter實(shí)例。這樣當(dāng)網(wǎng)絡(luò)通訊層收到一個請求后,會找到對應(yīng)的Exporter實(shí)例,并調(diào)用它所對應(yīng)的AbstractProxyInvoker實(shí)例,從而真正調(diào)用了服務(wù)提供者的代碼
  • 線程模型
  • 過程
  • Proxy
  • Client
  • Transporter
  • Header ->?Codec
  • Body ->?Serialization
    • Server
    • Dispatcher
    • ThreadPool
    • Implementation
    • Dispatcher
  • all?所有消息都派發(fā)到線程池,包括請求,響應(yīng),連接事件,斷開事件,心跳等
  • direct?所有消息都不派發(fā)到線程池,全部在IO線程上直接執(zhí)行
  • message?只有請求響應(yīng)消息派發(fā)到線程池,其它連接斷開事件,心跳等消息,直接在IO線程上執(zhí)行
  • execution?只請求消息派發(fā)到線程池,不含響應(yīng),響應(yīng)和其它連接斷開事件,心跳等消息,直接在IO線程上執(zhí)行
  • connection?在IO線程上,將連接斷開事件放入隊(duì)列,有序逐個執(zhí)行,其它消息派發(fā)到線程池
    • ThreadPool
  • fixed?固定大小線程池,啟動時建立線程,不關(guān)閉,一直持有。(缺省)
  • cached?緩存線程池,空閑一分鐘自動刪除,需要時重建
  • limited?可伸縮線程池,但池中的線程數(shù)只會增長不會收縮。(為避免收縮時突然來了大流量引起的性能問題)
4,增強(qiáng)功能
  • 并發(fā)控制
  • 連接控制: 連接數(shù)控制
  • 分組聚合: 分組聚合返回值,用于菜單聚合等服務(wù)
  • 泛化引用: 泛化調(diào)用,無需業(yè)務(wù)接口類進(jìn)行遠(yuǎn)程調(diào)用,用于測試平臺,開放網(wǎng)關(guān)橋接等
  • 異步調(diào)用
  • 延遲暴露: 延遲暴露服務(wù),用于等待應(yīng)用加載warmup數(shù)據(jù),或等待spring加載完成
  • 延遲連接: 延遲建立連接,調(diào)用時建立
  • 隱私傳參: 附加參數(shù)
5,Dubbo擴(kuò)展
  • 方法
  • OSGI
  • Equinox
  • Eclipse, HSF
  • META-INF/MANIFEST.MF
    • IoC
  • Spring
  • META-INF/spring/beans.xml
    • SPI
  • java.util.ServiceProvider
  • JDBC, MessageDigest, ScriptEngine
  • META-INF/services/com.xx.Xxx
  • Dubbo SPI
  • Microkernel & SPI
  • Protocol & ProxyFactory & Filter
  • Cluster & Directory & Router & LoadBalance
  • Transporter & Serialization & ThreadPool
  • TelnetHandler & StatusChecker
6,Dubbo設(shè)計(jì)原則
  • 模塊分包原則
  • 復(fù)用度
  • 包中的類應(yīng)該有同樣的重用可能性
  • 緊密協(xié)作的類應(yīng)該放在一個包
  • 對于變化因子,包中的類應(yīng)全改或全不改
  • 變化應(yīng)在包內(nèi)終止,而不傳播到其它包
  • 發(fā)布的粒度和復(fù)用度相同
    • 穩(wěn)定度
  • 被依賴的包應(yīng)該總是比依賴者更穩(wěn)定
  • 不要讓一個穩(wěn)定的包依賴于不穩(wěn)定包
  • 單向依賴,無環(huán)依賴
    • 抽象度
  • 越穩(wěn)定的包應(yīng)該越抽象
  • 穩(wěn)定的包不抽象將導(dǎo)致擴(kuò)展性極差
  • 抽象的包不穩(wěn)定將導(dǎo)致其依賴包跟隨變化
  • 框架擴(kuò)展原則
  • 微核 +插件體系
  • OSGI
  • IoC
  • SPI
    • 平等對待第三方?
  • Dogfooding
  • 框架自己的功能也要擴(kuò)展點(diǎn)實(shí)現(xiàn)
  • 甚至微核的加載方式也可以擴(kuò)展
    • Autowire
  • 裝配邏輯由擴(kuò)展點(diǎn)之間互助完成
  • 杜絕硬編碼的橋接和中間代碼
    • Cascading
  • 層疊擴(kuò)展粒度,逐級細(xì)分
  • 由大的擴(kuò)展點(diǎn)加載小的擴(kuò)展點(diǎn)
    • Law of Demeter
  • 只與觸手可及的擴(kuò)展點(diǎn)交互,間接轉(zhuǎn)發(fā)
  • 保持行為單一,輸入輸出明確
    • 外置生命周期
  • API傳入?yún)?shù),SPI擴(kuò)展點(diǎn)實(shí)例
  • 盡量引用外部對象的實(shí)例,而不類元
  • 正確:userInstance.xxx()
  • 錯誤:Class.forName(userClass).newInstance().xxx()
    • 盡量使用IoC注入,減少靜態(tài)工廠方法調(diào)用
  • 正確:setXxx(xxx)
  • 錯誤:XxxFactory.getXxx();?applicationContext.getBean(“xxx”)
    • 最少化概念模型
    • 一致性數(shù)據(jù)模型
  • Dubbo統(tǒng)一URL模型
  • 所有配置信息都轉(zhuǎn)換成URL的參數(shù)
  • 所有的元信息傳輸都采用URL
  • 所有接口都可以獲取到URL
  • 領(lǐng)域劃分原則
  • 服務(wù)域
  • 指產(chǎn)品主要功能入口,同時負(fù)責(zé)實(shí)體域和會話域的生命周期管理。
  • Velocity的Engine
  • Spring的BeanFactory
    • 實(shí)體域
  • 表示你要操作的對象模型,不管什么產(chǎn)品,總有一個核心概念,大家都繞圍它轉(zhuǎn)。
  • Velocity的Template
  • Spring的Bean
    • 會話域
  • 表示每次操作瞬時狀態(tài),操作前創(chuàng)建,操作后銷毀。
  • Velocity的Context
  • Spring的Invocation
    • 領(lǐng)域模型劃分優(yōu)勢
  • 結(jié)構(gòu)清晰,可直接套用
  • 充血模型,實(shí)體域帶行為
  • 可變與不可變狀態(tài)分離,可變狀態(tài)集中
  • 所有領(lǐng)域線程安全,不需要加鎖
    • 領(lǐng)域模型線程安全性
  • 服務(wù)域
  • 通常服務(wù)域是無狀態(tài),或者只有啟動時初始化不變狀態(tài),所以天生線程安全,只需單一實(shí)例運(yùn)行
    • 實(shí)體域
  • 通常設(shè)計(jì)為不變類,所有屬性只讀,或整個類引用替換,所以是線程安全的
    • 會話域
  • 保持所有可變狀態(tài),且會話域只在線程棧內(nèi)使用,即每次調(diào)用都在線程棧內(nèi)創(chuàng)建實(shí)例,調(diào)用完即銷毀,沒有競爭,所以線程安全
  • 接口分離原則
  • API & SPI
  • 聲明式API(Dubbo API):描述需要什么
  • ServiceConfig
  • ReferenceConfig
  • RpcContext
    • 過程式SPI(Dubbo SPI):描述怎么實(shí)現(xiàn)
  • Protocol
  • Transporter
  • LoadBalance
    • API可配置,一定可編程
  • 配置用于簡化常規(guī)使用
  • 編程接口用于框架集成
    • API區(qū)分命令與查詢
  • 命令:無返回值表示命令,有副作用
  • 查詢:有返回值表示查詢,保持冪等,無副作用
  • 組件協(xié)作原則
  • 管道 v.s. 派發(fā)
  • 管道
  • 組合行為
  • 主功能以截面實(shí)現(xiàn)
  • 比如:Servlet
    • 派發(fā)
  • 策略行為
  • 主功能以事件實(shí)現(xiàn)
  • 比如:?Swing
    • 分布 v.s. 共享
  • 分布
  • 在行為交互為主的系統(tǒng)是適用
  • 狀態(tài)通過行為傳遞
    • 共享
  • 在以管理狀態(tài)為主的系統(tǒng)中適用
  • 狀態(tài)通過倉庫共享
    • 主過程攔截
  • Web框架的請求響應(yīng)流
  • ORM框架的SQL執(zhí)行
  • Service框架的調(diào)用過程
  • 反例:IBatis2在SQL執(zhí)行過程中沒有設(shè)攔截點(diǎn),導(dǎo)致添加安全或日志攔截,執(zhí)行前修改分頁SQL等,不得不hack源代碼
    • 事件派發(fā)
  • 過程
  • 執(zhí)行前后
  • 觸發(fā)附帶非關(guān)鍵行為
    • 狀態(tài)
  • 值的變化
  • 觸發(fā)狀態(tài)觀察者行為
    • 關(guān)鍵路徑
  • 關(guān)鍵路徑
  • 采用攔截鏈分離職責(zé)
  • 保持截面功能單一,不易出問題
    • 非關(guān)鍵路徑
  • 采用后置事件派發(fā)
  • 確保派發(fā)失敗,不影響主過程運(yùn)行
    • 協(xié)作防御
  • 可靠性分離
  • 可靠操作
  • 不可靠操作 (盡量縮小)
    • 狀態(tài)分離
  • 無狀態(tài)
  • 有狀態(tài) (盡量縮小)
  • 不可變類 (盡量final)
    • 狀態(tài)驗(yàn)證
  • 盡早失敗
  • 前置斷言 + 后置斷言 + 不變式
    • 異常防御,但不忽略異常
  • 異常信息給出解決方案
  • 日志信息包含環(huán)境信息
    • 降低修改時的誤解性,不埋雷
  • 避免基于異常類型的分支流程
  • 保持null和empty語義一致
  • 功能演進(jìn)原則
  • 開閉原則
  • 對擴(kuò)展開放
  • 對修改關(guān)閉
  • 軟件質(zhì)量的下降,來源于修改
  • 替換整個實(shí)現(xiàn)類,而不是修改其中的某行
    • 增量式 v.s.擴(kuò)充式
  • Dubbo增量式擴(kuò)展
  • Remoting
  • Transport:
  • 單向消息發(fā)送,抽象Mina/Netty
    • Exchange:
  • 封裝Request-Respose語義
  • 調(diào)用兩次單向消息發(fā)送完成
    • RPC
  • Portocol:
  • 協(xié)議實(shí)現(xiàn),不透明,點(diǎn)對點(diǎn)
    • Cluster:
  • 將集群中多個提供者偽裝成一個
    • Proxy:
  • 透明化接口,橋接動態(tài)代理
    • 在高階附加功能
  • 盡可能少的依賴低階契約,用最少的抽象概念實(shí)現(xiàn)功能
  • 當(dāng)?shù)碗A切換實(shí)現(xiàn)時,高階功能可以繼續(xù)復(fù)用
7,Dubbo編碼約定
  • 異常和日志:
  • 盡可能攜帶完整的上下文信息,比如出錯原因,出錯的機(jī)器地址,調(diào)用對方的地址,連的注冊中心地址,使用Dubbo的版本等。
  • 盡量將直接原因?qū)懺谧钋懊?#xff0c;所有上下文信息,在原因后用鍵值對顯示。
  • 拋出異常的地方不用打印日志,由最終處理異常者決定打印日志的級別,吃掉異常必需打印日志。
  • 打印ERROR日志表示需要報(bào)警,打印WARN日志表示可以自動恢復(fù),打印INFO表示正常信息或完全不影響運(yùn)行。
  • 建議應(yīng)用方在監(jiān)控中心配置ERROR日志實(shí)時報(bào)警,WARN日志每周匯總發(fā)送通知。
  • RpcException是Dubbo對外的唯一異常類型,所有內(nèi)部異常,如果要拋出給用戶,必須轉(zhuǎn)為RpcException。
  • RpcException不能有子類型,所有類型信息用ErrorCode標(biāo)識,以便保持兼容。
  • 配置和URL:
  • 配置對象屬性首字母小寫,多個單詞用駝峰命名(Java約定)。
  • 配置屬性全部用小寫,多個單詞用"-"號分隔(Spring約定)。
  • URL參數(shù)全部用小寫,多個單詞用"."號分隔(Dubbo約定)。
  • 盡可能用URL傳參,不要自定義Map或其它上下文格式,配置信息也轉(zhuǎn)成URL格式使用。
  • 盡量減少URL嵌套,保持URL的簡潔性。
  • 單元和集成測試:
  • 單元測試統(tǒng)一用JUnit和EasyMock,集成測試用TestNG,數(shù)據(jù)庫測試用DBUnit。
  • 保持單元測試用例的運(yùn)行速度,不要將性能和大的集成用例放在單元測試中。
  • 保持單元測試的每個用例都用try...finally或tearDown釋放資源。
  • 減少while循環(huán)等待結(jié)果的測試用例,對定時器和網(wǎng)絡(luò)的測試,用以將定時器中的邏輯抽為方法測試。
  • 對于容錯行為的測試,比如failsafe的測試,統(tǒng)一用LogUtil斷言日志輸出。
  • 擴(kuò)展點(diǎn)基類與AOP:
  • AOP類都命名為XxxWrapper,基類都命名為AbstractXxx。
  • 擴(kuò)展點(diǎn)之間的組合將關(guān)系由AOP完成,ExtensionLoader只負(fù)載加載擴(kuò)展點(diǎn),包括AOP擴(kuò)展。
  • 盡量采用IoC注入擴(kuò)展點(diǎn)之間的依賴,不要直接依賴ExtensionLoader的工廠方法。
  • 盡量采用AOP實(shí)現(xiàn)擴(kuò)展點(diǎn)的通用行為,而不要用基類,比如負(fù)載均衡之前的isAvailable檢查,它是獨(dú)立于負(fù)載均衡之外的,不需要檢查的是URL參數(shù)關(guān)閉。
  • 對多種相似類型的抽象,用基類實(shí)現(xiàn),比如RMI,Hessian等第三方協(xié)議都已生成了接口代理,只需將將接口代理轉(zhuǎn)成Invoker即可完成橋接,它們可以用公共基類實(shí)現(xiàn)此邏輯。
  • 基類也是SPI的一部分,每個擴(kuò)展點(diǎn)都應(yīng)該有方便使用的基類支持。
  • 模塊與分包:
  • 基于復(fù)用度分包,總是一起使用的放在同一包下,將接口和基類分成獨(dú)立模塊,大的實(shí)現(xiàn)也使用獨(dú)立模塊。
  • 所有接口都放在模塊的根包下,基類放在support子包下,不同實(shí)現(xiàn)用放在以擴(kuò)展點(diǎn)名字命名的子包下。
  • 盡量保持子包依賴父包,而不要反向。
8,Dubbo高性能之道
  • 參考文章“【總結(jié)】Netty(RPC高性能之道)原理剖析 ”

轉(zhuǎn)載于:https://www.cnblogs.com/yangqiong1989/p/6882470.html

總結(jié)

以上是生活随笔為你收集整理的RPC框架Dubbo分析的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

中文字幕一区二区三区在线播放 | 手机看片国产日韩 | 国产天天综合 | 成人宗合网 | 一区二区精品在线 | 成人黄色小说网 | 国产精品videoxxxx | 国产日本亚洲高清 | 四虎影视久久久 | 天天躁天天躁天天躁婷 | 日韩有码网站 | 精品国产理论片 | 日本三级中文字幕在线观看 | 国产精品成人品 | 日韩色在线 | 国产美女精品视频免费观看 | 国产一区二区手机在线观看 | 成年人精品| 又爽又黄又无遮挡网站动态图 | 国产黄色精品视频 | 久久激情视频 久久 | 精品国模一区二区 | 黄色一级动作片 | 久久er99热精品一区二区三区 | 中文字幕亚洲欧美日韩 | 91网免费观看 | 亚洲精品视频中文字幕 | 日韩69视频 | 99资源网| 最近中文字幕视频完整版 | 国产一级免费视频 | 日本久久久久久科技有限公司 | 91视频 - 114av| 激情电影在线观看 | 久久亚洲福利视频 | 免费av试看| 五月婷婷导航 | 国产黄色免费在线观看 | 久草在线视频首页 | 中文字幕在线字幕中文 | 91视频黄色| 人人爽久久涩噜噜噜网站 | 亚洲免费成人 | 一本色道久久精品 | 成人av片免费看 | 色在线免费 | 久久亚洲免费视频 | 天天操天天插 | 国产精品一区二区三区四区在线观看 | 久久久久久久久久影院 | www久久99| 天天干天天操天天射 | 欧美亚洲成人免费 | www五月婷婷 | 91麻豆操 | 天天添夜夜操 | 精品国精品自拍自在线 | 六月色丁香 | 一区二区不卡视频在线观看 | 国产一级精品视频 | 国内综合精品午夜久久资源 | 国产午夜精品一区二区三区欧美 | 国产色视频一区二区三区qq号 | 国产精品va在线观看入 | 日韩av偷拍 | 国产精品理论在线观看 | 在线免费av网站 | 日韩免费视频在线观看 | 久久国语露脸国产精品电影 | 久久se视频 | 亚洲精品在线观看的 | 激情五月色播五月 | 欧美日韩另类在线 | 久久天天躁夜夜躁狠狠躁2022 | 亚洲免费视频在线观看 | av在线直接看 | 亚洲国产精品久久久久婷婷884 | 精品在线你懂的 | 日韩三级视频在线看 | 欧美日韩高清在线一区 | 973理论片235影院9 | 国产一级特黄毛片在线毛片 | 欧美一级特黄aaaaaa大片在线观看 | 在线播放亚洲激情 | 日韩精品电影在线播放 | 久久久久国产视频 | 国产不卡视频在线 | 日韩两性视频 | 麻豆传媒视频观看 | 美女视频黄在线 | 人人揉人人揉人人揉人人揉97 | 欧美a级一区二区 | 美女视频黄免费网站 | 欧美久久久久久久久久 | 人成午夜视频 | 中文一区二区三区在线观看 | 久草在线免费在线观看 | 久久精品这里热有精品 | 精品一区二区免费视频 | 婷香五月 | 国产剧情久久 | 中文字幕在线观看免费观看 | 天天综合在线观看 | 六月丁香婷婷网 | 天天操天天干天天玩 | 成人一区电影 | 91男人影院 | 国产精品九九九九九 | 欧美二区三区91 | 18久久久 | 欧美在线视频第一页 | 五月天av在线 | 亚洲精品乱码久久久久久按摩 | 91网在线看| 欧美一二区在线 | 91精品毛片| 中文字幕资源站 | av免费福利 | 亚洲国产精品一区二区尤物区 | 欧美夫妻生活视频 | 一级黄色在线视频 | 久久久资源 | 在线免费观看涩涩 | 91中文视频 | 午夜精品视频一区二区三区在线看 | 区一区二在线 | 国产高清一区二区 | 国产精品久久久久国产精品日日 | 婷婷av网 | 午夜 免费 | 国产不卡在线 | 日韩大片在线免费观看 | 黄av资源 | 国产日产在线观看 | 精品国产中文字幕 | 久99久精品视频免费观看 | 久久这里精品视频 | 在线观看911视频 | 免费欧美 | 天天综合婷婷 | 国产99久久久国产精品免费看 | 丁香六月激情婷婷 | 三级av片 | 开心激情网五月天 | 菠萝菠萝蜜在线播放 | 国产精品一区二区免费 | 超碰97公开 | 精品国产1区 | 国产精品电影一区二区 | 日日躁你夜夜躁你av蜜 | 色视频在线免费 | 国产亚洲婷婷免费 | 日韩欧美电影 | 四川bbb搡bbb爽爽视频 | 亚洲电影毛片 | 99夜色| 三级av片 | 国产精品高潮呻吟久久久久 | av网站在线观看播放 | 日韩电影在线一区二区 | 久久久久亚洲精品成人网小说 | 久久久久国产免费免费 | 亚洲va欧美va人人爽春色影视 | 成人免费网视频 | 免费在线电影网址大全 | 国产91aaa| 成人网页在线免费观看 | 久久国产精彩视频 | 男女激情片在线观看 | av电影免费| 最新在线你懂的 | 日韩理论在线观看 | 亚洲日本va在线观看 | 日韩免费电影在线观看 | 麻豆视频在线播放 | 狠狠躁日日躁夜夜躁av | 激情伊人 | 一级电影免费在线观看 | 天天天干夜夜夜操 | 亚洲国产日韩一区 | 日韩和的一区二在线 | 亚洲激情 | 色妞久久福利网 | 三级av中文字幕 | 五月婷婷久久丁香 | 久久午夜网 | 国产午夜精品视频 | 国产字幕在线播放 | 国产日产精品一区二区三区四区 | 美女精品在线观看 | 美女视频是黄的免费观看 | 丁香婷婷综合激情 | 国产精品日韩精品 | 久久久国产精品成人免费 | 99这里只有 | 亚洲日本精品 | 亚洲国产97在线精品一区 | 亚洲免费av网站 | 色wwww| 亚洲黄色成人 | 国产精品视频内 | 在线观看免费日韩 | 麻豆系列在线观看 | 中文字幕专区高清在线观看 | 久久久999精品视频 国产美女免费观看 | 天堂av在线免费 | 色综合久久精品 | 日本韩国精品在线 | av在线最新 | 国产精品男女 | 国产精品小视频网站 | 天天射狠狠干 | 青春草视频| 国产在线观看免费av | 成人高清在线观看 | 国产黄色免费电影 | 久久综合狠狠狠色97 | 在线看成人| 国产无遮挡猛进猛出免费软件 | www视频免费在线观看 | 天天色天天射天天综合网 | 成人av在线网址 | 久久成人免费视频 | 婷婷综合导航 | 欧美一级免费在线 | 99久久www免费 | 国产免费观看久久 | www最近高清中文国语在线观看 | 揉bbb玩bbb少妇bbb| 国产一区视频在线 | 日韩精品一区电影 | 热久久免费视频精品 | 黄色资源在线观看 | 久久精品91久久久久久再现 | 狠狠干 狠狠操 | 欧美视频日韩 | 中国老女人日b | 久久久久久国产精品 | 碰超在线| 亚洲小视频在线观看 | 婷婷色中文字幕 | 精品国产片 | 国产精品久久久免费看 | 国产最顶级的黄色片在线免费观看 | 国产精品区在线观看 | 蜜臀av夜夜澡人人爽人人桃色 | 免费在线电影网址大全 | 午夜视频久久久 | 久久精品免费看 | 在线导航av | 日本少妇视频 | 国产中的精品av小宝探花 | www天天操| 婷婷五情天综123 | 国产午夜免费视频 | 亚洲国产精品久久久 | 97偷拍视频 | 国产精品日韩欧美一区二区 | 成人在线免费看 | 99热官网 | 亚洲成人999 | 欧美成人h版在线观看 | 日韩综合在线观看 | 久久免费国产精品 | 欧美日韩在线播放 | 久久伦理影院 | 五月婷婷在线视频观看 | 久久高清av| 国产精品嫩草影院123 | 欧美成人91 | 人人添人人| 色网站在线观看 | 999成人| 国产高清视频在线观看 | 欧美日韩视频在线一区 | 欧洲激情在线 | 欧美激情视频一二三区 | 婷婷六月天天 | 国产成人av一区二区三区在线观看 | 99这里只有久久精品视频 | a v在线视频 | 日本系列中文字幕 | 亚洲黄色一级视频 | 午夜精品av在线 | 五月激情婷婷丁香 | 日韩欧美综合精品 | 亚洲黄色在线观看 | av电影在线不卡 | 性色av一区二区三区在线观看 | а天堂中文最新一区二区三区 | 人人射网站 | 操少妇视频 | 亚洲成aⅴ人片久久青草影院 | 国产一级片一区二区三区 | 日韩av午夜在线观看 | 99精品系列 | 亚洲精品久久久久久久不卡四虎 | 亚洲资源一区 | 五月av在线| 国产精品97| 国产精品国产三级国产不产一地 | 中文字幕一区在线观看视频 | 99久久婷婷国产精品综合 | 激情网在线观看 | 黄色av一区二区三区 | 国产一区二区在线播放视频 | 青青射| 国产精品成人在线观看 | 成片免费观看视频999 | 精品乱码一区二区三四区 | 麻豆极品| 五月天综合网 | 激情影院在线 | 国产成人精品一区二 | 五月天婷婷在线观看视频 | 亚洲综合网站在线观看 | 中文字幕免费高清在线观看 | 午夜精品成人一区二区三区 | 久久亚洲影院 | 亚洲视频精选 | 一级黄毛片 | 久久高清 | 在线观看视频你懂的 | 99热在线精品观看 | 精品视频免费久久久看 | 天天性天天草 | 91精品天码美女少妇 | 区一区二在线 | 69夜色精品国产69乱 | 国产精品一码二码三码在线 | 精品国产一区二区三区蜜臀 | 四虎在线免费观看 | 啪啪免费观看网站 | 久草免费在线观看 | 日韩精品一区二区三区免费视频观看 | 精品国产一区二区三区在线 | 久久精品成人热国产成 | 99re6热在线精品视频 | 久插视频| 中文字幕第一页在线播放 | 成人在线观看网址 | 久久久久观看 | 婷婷色av| 久久激情视频免费观看 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 免费在线电影网址大全 | 国产成人精品一区二区三区免费 | 国产精品一区二区在线播放 | 日韩专区在线播放 | 亚洲国产中文字幕在线 | 色婷婷午夜 | 亚洲性少妇性猛交wwww乱大交 | 蜜臀av免费一区二区三区 | 午夜精品三区 | 久久呀| 色多多在线观看 | 黄色毛片视频免费观看中文 | 国产一区二区免费在线观看 | a级国产乱理论片在线观看 特级毛片在线观看 | 色婷婷亚洲精品 | 国产一级性生活 | 午夜美女网站 | av免费看在线| 操操操日日 | 黄污视频大全 | 开心激情综合网 | 国产精品国内免费一区二区三区 | 亚洲乱码一区 | 久久少妇免费视频 | 亚洲欧美日韩在线一区二区 | 午夜av免费在线观看 | 在线视频福利 | 黄色av电影在线 | 最近字幕在线观看第一季 | 日本黄色大片免费看 | 国产精品九九久久久久久久 | 97成人在线视频 | 国产精品毛片一区视频播不卡 | 青青草国产成人99久久 | 精品影院 | 国产手机视频在线播放 | japanesefreesex中国少妇 | 国产色婷婷 | 四虎国产精品免费 | 久久久国产99久久国产一 | 国产成人99av超碰超爽 | 欧美在线aa| 亚洲a免费 | 激情图片qvod| 亚州精品在线视频 | 日韩精品2区 | 国产精品久久久久久久久久久久久 | 成人毛片一区 | 高清精品在线 | 日韩欧美视频免费看 | 国产精品一码二码三码在线 | 国产精品久久久久一区二区国产 | 日本久久高清视频 | 国产精品成人久久久久 | 久久国产系列 | 九色福利视频 | 91九色在线观看 | 国产成人在线观看免费 | 久久综合欧美精品亚洲一区 | 亚洲精品国产自产拍在线观看 | 国产免费观看久久 | 五月婷婷在线综合 | 亚洲精选视频在线 | 久久国产精品久久w女人spa | 国产99亚洲 | 视频在线观看日韩 | 亚洲天堂网在线播放 | 日本爽妇网 | 国产精品日韩欧美一区二区 | 日韩视频在线不卡 | av免费电影在线观看 | 六月婷操 | 欧美亚洲国产日韩 | 午夜视频在线网站 | 天堂网在线视频 | 中文字幕在线看视频国产 | 亚洲精品在线视频网站 | 最新日韩在线观看 | 日韩精品久久久久久 | 色网站国产精品 | 成人黄色片免费 | 亚洲精品色婷婷 | 四虎成人精品永久免费av | 国产97免费 | 亚洲成人免费观看 | 日韩视频免费在线观看 | 精品视频久久久久久 | 日韩视频在线观看视频 | 五月天综合激情 | 四虎在线免费观看 | 91视频免费播放 | 91在线蜜桃臀 | 国产性天天综合网 | 九九热99视频 | 91亚洲免费| 中文字幕在线观看完整版电影 | 免费网址你懂的 | www.亚洲激情.com | 国产精品一区二区三区视频免费 | 丁香婷婷基地 | 精品视频9999| 日韩和的一区二在线 | 国产91综合一区在线观看 | 日批视频在线播放 | 97超碰福利久久精品 | 99久热在线精品视频成人一区 | 亚洲一区动漫 | 四虎最新入口 | 最近中文字幕高清字幕在线视频 | 亚洲精品久久久久中文字幕二区 | 久久国产电影 | av成人在线网站 | 精品黄色在线观看 | 国产综合福利在线 | 精品久久久久久一区二区里番 | 涩涩网站在线播放 | 久草在线中文视频 | 97超碰人人澡人人爱学生 | 韩国av在线播放 | 中文日韩在线视频 | 啪啪资源 | 国产高清久久 | 99久久这里只有精品 | 欧美一级久久久 | 一本之道乱码区 | 天天玩天天干天天操 | 天天射天天舔天天干 | 天天射射天天 | 日日操日日操 | 成人性生交大片免费看中文网站 | 久久久在线视频 | 五月激情站 | 精品久久久久久久久久久久久久久久久久 | 黄色在线观看免费网站 | 91成人在线视频 | 97av影院 | 成人黄色电影在线 | 波多野结衣亚洲一区二区 | 亚洲激情在线播放 | 欧美一级裸体视频 | 日韩色高清 | 一区三区视频在线观看 | 色综合久久久久久久 | 国产亚洲精品电影 | 久久久国产一区二区三区 | 久久精品久久99精品久久 | 美女福利视频一区二区 | 超碰在线9 | 99人成在线观看视频 | 欧美性做爰猛烈叫床潮 | 婷婷综合网 | 日本性高潮视频 | 丰满少妇对白在线偷拍 | 去看片 | 欧美亚洲专区 | 91欧美国产 | 在线观看视频一区二区 | 国产在线高清精品 | 亚洲aaa毛片 | 在线观看91av | 奇米影视8888在线观看大全免费 | 香蕉免费| 亚洲一级片av | 免费在线观看一区二区三区 | 久久欧美在线电影 | 欧美一级片在线播放 | 欧美巨大 | 亚洲成aⅴ人在线观看 | 久久久久伊人 | 国产精品亚州 | 成人午夜影院在线观看 | 91香蕉视频720p | 欧美伦理一区二区 | 久草在线免 | 久久精品播放 | 国产精品视频你懂的 | 亚洲欧美视频在线观看 | 97超碰中文字幕 | 免费在线观看污 | 99久久久久国产精品免费 | 三级免费黄 | 日本精品视频免费观看 | 国产精品免费小视频 | 久久福利影视 | 有码中文字幕在线观看 | 81国产精品久久久久久久久久 | 夜夜躁狠狠躁日日躁视频黑人 | 天天综合天天做 | 婷婷色站 | 久久伊人色综合 | 精品国产伦一区二区三区 | 一区二区三区手机在线观看 | 亚洲精品午夜视频 | 亚洲人人av | 在线视频 91 | 亚洲狠狠操 | av三级av | 午夜精品久久久久久久爽 | 国产婷婷在线观看 | 久久黄色成人 | 国产精品一区二区三区免费视频 | 精品国产不卡 | 国产一区在线精品 | 91x色| 国产视频日本 | 日韩视频一二三区 | 一区 二区 精品 | 久草视频免费播放 | 欧美午夜久久久 | 亚洲作爱 | 人人爽人人爽人人片av | 99精品色| 久久精品高清 | 深爱婷婷| 日韩视频免费观看高清完整版在线 | 久久国产网 | 国产女v资源在线观看 | 欧美性春潮 | 亚洲成av片人久久久 | av在线免费观看不卡 | av久久久| 日韩av看片 | 国产精品久久网站 | 在线观看黄色av | 色播五月激情综合网 | 手机看片| 天天做夜夜做 | 91香蕉视频720p | 91视频啪 | a级国产乱理伦片在线播放 久久久久国产精品一区 | www好男人 | 久久久久伊人 | 国产精品成人a免费观看 | 黄色成人影院 | 日本中文字幕在线电影 | 黄色亚洲免费 | 探花视频免费观看 | 成人免费在线观看av | 国产手机在线精品 | 亚洲日本在线一区 | 美女免费视频网站 | 精品国产精品一区二区夜夜嗨 | 91精品国产一区 | av福利在线播放 | 久久免费视频国产 | 字幕网资源站中文字幕 | 人人干人人做 | 欧美成人中文字幕 | 中文字幕一区三区 | 349k.cc看片app| 亚洲精品在线播放视频 | 成人亚洲免费 | 亚洲女裸体| av一本久道久久波多野结衣 | 久久九九免费 | av大片网址 | 五月婷婷开心中文字幕 | 国产99久久九九精品免费 | 亚洲无人区小视频 | 中文字幕免费一区二区 | 精品久久精品 | 国产精品永久 | 国产精品刺激对白麻豆99 | 国产精品 日韩精品 | 日韩精品一区二区三区高清免费 | 亚洲精品欧美专区 | 成人av资源网站 | 久久婷综合 | 美女视频黄免费的久久 | 91免费高清观看 | av高清免费 | 丁香婷婷电影 | 91九色蝌蚪在线 | 97国产情侣爱久久免费观看 | 91传媒91久久久 | 成人久久免费 | 黄色资源在线观看 | 99色资源 | 国产视频在| 久久中国精品 | 天天玩天天干 | 国产精品综合久久久 | av天天草| 日本精品一区二区三区在线播放视频 | 亚洲一区二区精品 | 亚州人成在线播放 | 人人干人人模 | 欧美aaa视频 | 91传媒在线看 | 色噜噜狠狠色综合中国 | 毛片永久免费 | 91在线最新 | 五月婷婷亚洲 | 五月天亚洲激情 | 中文av不卡 | 我爱av激情网 | 欧美小视频在线观看 | 349k.cc看片app | 91福利试看 | 丁香六月久久综合狠狠色 | 久久精品一区 | 激情 一区二区 | 中文字幕高清av | 在线你懂 | 成年人免费在线观看网站 | 日韩高清一区 | 91桃色国产在线播放 | 国产在线播放一区 | 久久久久久久久久久国产精品 | 超碰精品在线 | 免费三级网 | 久久99久国产精品黄毛片入口 | 色婷婷色 | 香蕉网站在线观看 | 99中文视频在线 | 99热最新| 久热精品国产 | 去干成人网 | 夜又临在线观看 | 亚洲无线视频 | 美女久久久久久久 | 久久综合九色综合欧美就去吻 | 精品在线视频播放 | 999久久久久久久久 69av视频在线观看 | 日韩 国产 | 国产在线毛片 | 日韩一级成人av | 99热这里精品 | 国产成人61精品免费看片 | 视频一区亚洲 | 久草在线免费在线观看 | 国产精品久久久久久久午夜 | 成人免费在线电影 | 日韩av一区二区三区在线观看 | 日韩av偷拍| 丰满少妇在线观看网站 | 国产中文字幕大全 | 91视频在线自拍 | 精品久久久久免费极品大片 | 一区二区三区在线免费播放 | 亚洲欧美激情插 | 国产精品99久久99久久久二8 | www国产亚洲精品久久麻豆 | 色wwww| 亚洲传媒在线 | 国际精品久久久 | 天天激情综合 | 免费特级黄毛片 | 91高清视频免费 | 久久久久久久久久电影 | 久久久久久久久黄色 | 97色婷婷 | 婷婷日| 亚洲黄色av一区 | 婷婷久久久久 | 中文字幕观看视频 | 91免费高清| 国产在线视频不卡 | 九七视频在线观看 | 四虎永久国产精品 | 国产视频亚洲精品 | 九九热久久免费视频 | 日韩av一区二区三区在线观看 | 欧美视频二区 | 天天激情在线 | 国产短视频在线播放 | 亚洲一区二区三区四区精品 | www免费| 超碰人人乐 | 美女视频黄的免费的 | 波多野结衣在线视频一区 | 久久久www成人免费精品张筱雨 | 一级成人在线 | 国产一区二区三区在线 | 成人播放器| 国产高清在线免费观看 | 成人三级视频 | 久久久高清免费视频 | 欧美国产日韩在线视频 | 丰满少妇一级 | 日韩电影一区二区在线 | 国产成人精品一区二区在线观看 | 99视频精品免费视频 | 日韩av偷拍 | 天天干天天做 | 精品在线小视频 | 日韩视频一区二区三区在线播放免费观看 | 国产精品久久久久久久电影 | 超碰97人人干 | 国产xxxxx在线观看 | 福利av影院 | 中文在线亚洲 | 国产一区二区三区在线免费观看 | 国产精品成人aaaaa网站 | 日本一区二区三区免费看 | 欧美日韩xx | 免费黄色看片 | 综合网婷婷| 欧美在线视频a | 日韩色在线 | 天天爽天天射 | 国产精品久久99综合免费观看尤物 | 玖玖在线播放 | 亚洲国产视频a | 日韩区在线观看 | 在线导航福利 | 婷婷综合五月天 | 中文字幕欧美日韩va免费视频 | 狂野欧美激情性xxxx | 97国产在线播放 | 婷婷去俺也去六月色 | 粉嫩一区二区三区粉嫩91 | 久久成人精品视频 | 成人一区二区三区中文字幕 | 成人精品一区二区三区中文字幕 | 国产精品久久久久久久99 | 69人人| 特级黄录像视频 | 精品一区二区在线免费观看 | 久草视频在线免费播放 | 中文不卡视频在线 | 探花视频网站 | 国产九色在线播放九色 | 免费v片| 久草在线资源观看 | 欧美激情在线看 | 狠色在线 | 国产精品一区二区av | 天堂v中文| 亚洲国产日韩在线 | 欧美性色xo影院 | 亚洲视频在线免费看 | 久久久久久久18 | 成人黄色片免费看 | 国产人成精品一区二区三 | 97网| 欧美一区二区三区不卡 | 一区二区三区免费在线观看视频 | 国产麻豆精品传媒av国产下载 | 国产色秀视频 | 天天操天天射天天插 | 91久久偷偷做嫩草影院 | 亚洲国产高清在线观看视频 | 91九色蝌蚪 | 亚洲欧美乱综合图片区小说区 | 亚洲高清在线视频 | 超碰97免费观看 | 国产永久免费 | 91av在线精品 | 在线视频区 | 97色噜噜 | 欧美精品久久天天躁 | 日本在线观看一区 | 成人黄视频 | 国产又粗又猛又色又黄网站 | 在线观看免费高清视频大全追剧 | 伊人婷婷激情 | 日韩二区精品 | 丝袜+亚洲+另类+欧美+变态 | 91大片网站 | 麻豆国产精品va在线观看不卡 | 日韩久久久久久 | 国产黄色精品在线 | 成人蜜桃视频 | 久久夜色精品国产欧美乱 | 精品亚洲免a | 国产精品毛片久久久久久久 | 99精品国产一区二区三区麻豆 | 免费网站观看www在线观看 | 精品国产乱码久久 | 国产精品一区二区精品视频免费看 | 高清不卡一区二区三区 | 亚洲国产精品激情在线观看 | 中文字幕久久精品 | 国产亚洲精品电影 | 在线成人免费电影 | 精品国产一区二 | 色在线免费 | 奇米四色影狠狠爱7777 | 亚洲视频在线观看 | 久久av免费 | 久久艹精品 | 欧美夫妻生活视频 | 欧美91精品国产自产 | 日本黄色免费在线观看 | av在线电影免费观看 | 91精品伦理 | 免费在线观看一级片 | 日韩高清在线一区二区 | 久久精品一区二区三区视频 | 免费高清无人区完整版 | 美女黄视频免费看 | 婷婷久久综合网 | 色综合人人 | 国产精品久久久久三级 | 色综合久久综合网 | 国产一级片不卡 | 国产黄色av | 涩涩网站在线播放 | 婷婷伊人综合 | 91片黄在线观看 | 免费观看性生活大片 | 日日骑 | 操操操夜夜操 | 日韩在线观看 | 狠狠精品 | 毛片视频网址 | 特级西西444www高清大视频 | 福利一区在线 | 国产呻吟在线 | 亚洲乱码在线观看 | 成人av教育 | 中文字幕在线日亚洲9 | av在线不卡观看 | 成 人 黄 色 视频免费播放 | 免费观看国产视频 | 国产精品永久在线观看 | 精品国产一区二区在线 | 二区三区毛片 | 香蕉视频在线免费看 | 亚洲国内精品在线 | 免费亚洲精品视频 | 国产视频一区二区三区在线 | 区一区二在线 | 波多野结衣一区三区 | 久久在线影院 | 精品国产一区二区三区久久久 | 超碰av在线播放 | 色99中文字幕 | 天天草综合网 | 在线国产视频 | 五月丁色 | 亚洲精品视频观看 | 精品国产一区二区三区噜噜噜 | 欧美一级片免费在线观看 | 狠狠色伊人亚洲综合成人 | 高清精品视频 | 97超碰中文 | 国产免费叼嘿网站免费 | 91大神dom调教在线观看 | 麻豆成人小视频 | 99久久www | 日本精品久久久久影院 | 黄色网在线免费观看 | 国内精品在线一区 | 国产黄色理论片 | 成人免费在线观看入口 | www.五月天 | www国产亚洲精品 | 亚洲国产婷婷 | 国产精品久久久久久久久久ktv | 在线小视频 | 免费在线观看的av网站 | 国产精品久久久久一区二区 | 在线视频18在线视频4k | 99精品视频精品精品视频 | 青青河边草免费观看完整版高清 | 91最新在线观看 | 伊人影院在线观看 | 久草在线观看视频免费 | 中文字幕亚洲欧美 | 欧美性色网站 | 欧美激情第一区 | 一区二区三区精品在线视频 | 91一区啪爱嗯打偷拍欧美 | 98涩涩国产露脸精品国产网 | 大型av综合网站 | 伊人官网| 日日日网| 久久综合免费视频影院 | 狠狠色网 | 不卡的一区二区三区 | 国产高清精品在线观看 | 国产精品欧美激情在线观看 | 国产精品久久久网站 | 国产美女免费观看 | 国产中文字幕精品 | 一区二区三区久久精品 | 日韩精品在线观看av | 国产精品永久免费在线 | 激情久久小说 | 麻豆视频在线看 | 亚州欧美精品 | 精品国产一区二区三区久久久 | 激情五月婷婷激情 | 欧美精品视 | 国产精品久久久久久久久久不蜜月 | 91av视频网| 九九免费观看全部免费视频 | 久久这里只有精品视频99 | 成人小视频免费在线观看 | 亚洲免费资源 | 国产精品第一视频 | 精品成人网 | 在线看黄色的网站 | 超黄视频网站 | 中中文字幕av在线 | 精品视频在线免费观看 | 中文一区在线 | 欧美一区在线观看视频 | 青青河边草观看完整版高清 | 欧美91片| www.av在线播放 | 91精品第一页 | av在线影片 | 国产精品成人av电影 | 安徽妇搡bbbb搡bbbb | 欧美视频不卡 | 午夜黄色大片 | 国产成人福利在线 | 色爱成人网 | 久久福利精品 | 久久国产高清视频 | 中文字幕av在线 | 日本最新中文字幕 | 久草在线视频免费资源观看 | 亚州黄色一级 | 国产精品理论在线观看 | 日日射天天射 | 亚洲成人av电影 | 亚洲一级二级三级 | 91丨精品丨蝌蚪丨白丝jk | 久久久www成人免费毛片 | 手机在线看a | 日韩有码欧美 | 国产在线视频一区二区三区 | 欧美激情另类 | 久久婷婷一区二区三区 | 国产精品久久亚洲 | www色com | 黄色成人在线观看 | 国产成视频在线观看 | 97色se| 欧美精品久久人人躁人人爽 | 色婷婷色 | 摸bbb搡bbb搡bbbb| 成x99人av在线www | 一区二区三区视频在线 | 久 久久影院| 久久噜噜少妇网站 | 精品一二三四在线 | 久久国产精品99久久久久久丝袜 | 免费观看9x视频网站在线观看 | 九九九国产 | 在线高清av | 亚洲一区网| 精品久久久精品 | 中文字幕在线免费97 | 在线黄av| 热久久免费视频 | 免费黄色在线播放 | 麻豆视频免费观看 | 一区二区三区四区五区六区 |