国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

DDD分層架構(gòu):有效降低層與層之間的依賴

開發(fā) 架構(gòu)
傳統(tǒng)三層架構(gòu)向 DDD 分層架構(gòu)的演進(jìn),體現(xiàn)了領(lǐng)域驅(qū)動(dòng)設(shè)計(jì)思想的逐步成熟和應(yīng)用。這種演進(jìn)不僅優(yōu)化了架構(gòu)的分層設(shè)計(jì),還提升了系統(tǒng)的靈活性、可維護(hù)性和可擴(kuò)展性。

什么是 DDD 分層架構(gòu)?

DDD(領(lǐng)域驅(qū)動(dòng)設(shè)計(jì))的分層架構(gòu)經(jīng)歷了持續(xù)的演進(jìn)。最初是經(jīng)典的四層架構(gòu);隨后,四層架構(gòu)得到了進(jìn)一步優(yōu)化,實(shí)現(xiàn)了各層與基礎(chǔ)設(shè)施層的解耦;再到后來(lái),在領(lǐng)域?qū)雍蛻?yīng)用層之間引入了上下文環(huán)境(Context)層,從而形成了五層架構(gòu)(DCI,Data-Context-Interaction)

圖片圖片

讓我們來(lái)看一下這張圖。在最早的傳統(tǒng)四層架構(gòu)中,基礎(chǔ)層(Infrastructure Layer)被其他層所依賴,位于架構(gòu)的核心位置。然而,按照分層架構(gòu)的設(shè)計(jì)思想,領(lǐng)域?qū)樱―omain Layer)才是軟件的核心,因此這種依賴關(guān)系顯然存在問(wèn)題。為了解決這一問(wèn)題,我們引入了依賴倒置原則(Dependency Inversion Principle, DIP),對(duì)傳統(tǒng)的四層架構(gòu)進(jìn)行了優(yōu)化,成功實(shí)現(xiàn)了各層對(duì)基礎(chǔ)層的解耦。

我們今天講的 DDD 分層架構(gòu)就是優(yōu)化后的四層架構(gòu)。在下面這張圖中,從上到下依次是:用戶接口層、應(yīng)用層、領(lǐng)域?qū)雍突A(chǔ)層。那 DDD 各層的主要職責(zé)是什么呢?下面我來(lái)逐一介紹一下。

圖片圖片

1. 用戶接口層

用戶接口層的主要職責(zé)是向用戶展示信息并解釋用戶指令。這里的“用戶”不僅限于人類用戶,還包括程序、自動(dòng)化測(cè)試腳本以及批處理腳本等。

2. 應(yīng)用層

應(yīng)用層是一個(gè)相對(duì)較薄的層次,理論上不應(yīng)包含具體的業(yè)務(wù)規(guī)則或邏輯,而是專注于用例和流程相關(guān)的操作。它位于領(lǐng)域?qū)又希?fù)責(zé)協(xié)調(diào)多個(gè)聚合的服務(wù)和領(lǐng)域?qū)ο螅瓿煞?wù)的編排和組合,從而執(zhí)行業(yè)務(wù)操作。此外,應(yīng)用層也是微服務(wù)之間交互的通道,能夠調(diào)用其他微服務(wù)的應(yīng)用服務(wù),實(shí)現(xiàn)跨微服務(wù)的服務(wù)組合和編排。

需要注意的是:在設(shè)計(jì)和開發(fā)過(guò)程中,應(yīng)避免將本應(yīng)屬于領(lǐng)域?qū)拥臉I(yè)務(wù)邏輯錯(cuò)誤地放到應(yīng)用層中實(shí)現(xiàn)。如果應(yīng)用層過(guò)于龐大,會(huì)導(dǎo)致領(lǐng)域模型失去焦點(diǎn),久而久之,微服務(wù)可能會(huì)退化為傳統(tǒng)的三層架構(gòu),業(yè)務(wù)邏輯變得混亂不堪。

應(yīng)用服務(wù)位于應(yīng)用層,其職責(zé)包括:

  • 服務(wù)的組合、編排和轉(zhuǎn)發(fā);
  • 處理業(yè)務(wù)用例的執(zhí)行順序以及結(jié)果的組裝;
  • 通過(guò) API 網(wǎng)關(guān)向前端發(fā)布粗粒度的服務(wù);
  • 執(zhí)行安全認(rèn)證、權(quán)限校驗(yàn)、事務(wù)控制;
  • 發(fā)送或訂閱領(lǐng)域事件等。

3. 領(lǐng)域?qū)?/span>

領(lǐng)域?qū)邮菍?shí)現(xiàn)企業(yè)核心業(yè)務(wù)邏輯的關(guān)鍵層次,通過(guò)各種校驗(yàn)手段確保業(yè)務(wù)的正確性。它主要體現(xiàn)領(lǐng)域模型的業(yè)務(wù)能力,用于表達(dá)業(yè)務(wù)概念、業(yè)務(wù)狀態(tài)和業(yè)務(wù)規(guī)則。領(lǐng)域?qū)影酆细?shí)體、值對(duì)象、領(lǐng)域服務(wù)等領(lǐng)域模型中的核心對(duì)象。

領(lǐng)域?qū)ο蟮年P(guān)系說(shuō)明

  • 實(shí)體領(lǐng)域服務(wù)是領(lǐng)域?qū)又袑?shí)現(xiàn)業(yè)務(wù)邏輯的主要組成部分。

實(shí)體通常采用充血模型,實(shí)現(xiàn)與其相關(guān)的所有業(yè)務(wù)功能。

當(dāng)某些業(yè)務(wù)功能無(wú)法由單一實(shí)體(或值對(duì)象)實(shí)現(xiàn)時(shí),領(lǐng)域服務(wù)會(huì)介入,組合聚合內(nèi)的多個(gè)實(shí)體(或值對(duì)象),完成復(fù)雜的業(yè)務(wù)邏輯。

4. 基礎(chǔ)層

基礎(chǔ)層貫穿于所有層次,其主要職責(zé)是為其他各層提供通用的技術(shù)支持和基礎(chǔ)服務(wù)。這些服務(wù)包括但不限于:

  • 第三方工具和驅(qū)動(dòng);
  • 消息中間件;
  • API 網(wǎng)關(guān);
  • 文件存儲(chǔ);
  • 緩存服務(wù);
  • 數(shù)據(jù)庫(kù)等。

其中,數(shù)據(jù)庫(kù)持久化是基礎(chǔ)層最常見(jiàn)的功能之一。

基礎(chǔ)層通過(guò)依賴倒置設(shè)計(jì),封裝基礎(chǔ)資源服務(wù),實(shí)現(xiàn)應(yīng)用層、領(lǐng)域?qū)优c基礎(chǔ)層的解耦。這種設(shè)計(jì)能夠有效降低外部資源變化對(duì)應(yīng)用的影響。

DDD 分層架構(gòu)最重要的原則是什么?

DDD 分層架構(gòu)有一個(gè)重要的原則:每層只能與位于其下方的層發(fā)生耦合。

根據(jù)耦合的緊密程度,架構(gòu)可以分為兩種類型:嚴(yán)格分層架構(gòu)松散分層架構(gòu)

  • 嚴(yán)格分層架構(gòu)
  • 優(yōu)化后的 DDD 分層架構(gòu)模型屬于嚴(yán)格分層架構(gòu)。在這種架構(gòu)中,任何層只能依賴于其直接下方的層,依賴關(guān)系清晰且易于管理。例如:

領(lǐng)域服務(wù)只能被應(yīng)用服務(wù)調(diào)用;

應(yīng)用服務(wù)只能被用戶接口層調(diào)用。服務(wù)是逐層封裝或組合的,依賴關(guān)系明確,便于維護(hù)和擴(kuò)展。

  • 松散分層架構(gòu):傳統(tǒng)的 DDD 分層架構(gòu)屬于松散分層架構(gòu)。在這種架構(gòu)中,某一層可以依賴于其下方的任意層,依賴關(guān)系復(fù)雜且難以管理。例如:
  • 領(lǐng)域服務(wù)可能同時(shí)被應(yīng)用層和用戶接口層調(diào)用;

  • 核心業(yè)務(wù)邏輯容易外泄,增加了維護(hù)和升級(jí)的難度。

DDD 分層架構(gòu)如何推動(dòng)架構(gòu)演進(jìn)?

1.微服務(wù)架構(gòu)的演進(jìn)

我們了解到領(lǐng)域模型中對(duì)象的層次從內(nèi)到外依次為:值對(duì)象實(shí)體聚合限界上下文

  • 值對(duì)象和實(shí)體的簡(jiǎn)單變更通常不會(huì)對(duì)領(lǐng)域模型和微服務(wù)產(chǎn)生重大影響。
  • 然而,聚合的重組或拆分則可能引發(fā)較大的變化。這是因?yàn)榫酆蟽?nèi)的業(yè)務(wù)功能是高度內(nèi)聚的,能夠獨(dú)立完成特定的業(yè)務(wù)邏輯。

當(dāng)聚合發(fā)生重組或拆分時(shí),業(yè)務(wù)模塊和系統(tǒng)功能往往會(huì)隨之發(fā)生變化。因此,我們可以以聚合為基礎(chǔ)單元,推動(dòng)領(lǐng)域模型和微服務(wù)架構(gòu)的演進(jìn)。

具體來(lái)說(shuō):

  1. 聚合的重組或拆分:聚合可以作為一個(gè)整體,在不同的領(lǐng)域模型之間進(jìn)行重組或拆分。這種調(diào)整能夠更好地適應(yīng)業(yè)務(wù)需求的變化。
  2. 聚合獨(dú)立為微服務(wù):在某些情況下,可以直接將一個(gè)聚合獨(dú)立為一個(gè)微服務(wù)。這種方式能夠進(jìn)一步提升系統(tǒng)的靈活性和可維護(hù)性。

圖片圖片

當(dāng)你發(fā)現(xiàn)微服務(wù) 1 中聚合 a 的功能經(jīng)常被高頻訪問(wèn),以致拖累整個(gè)微服務(wù) 1 的性能時(shí),我們可以把聚合 a 的代碼,從微服務(wù) 1 中剝離出來(lái),獨(dú)立為微服務(wù) 2。這樣微服務(wù) 2 就可輕松應(yīng)對(duì)高性能場(chǎng)景。

在業(yè)務(wù)發(fā)展到一定程度以后,你會(huì)發(fā)現(xiàn)微服務(wù) 3 的領(lǐng)域模型有了變化,聚合 d 會(huì)更適合放到微服務(wù) 1 的領(lǐng)域模型中。這時(shí)你就可以將聚合 d 的代碼整體搬遷到微服務(wù) 1 中。如果你在設(shè)計(jì)時(shí)已經(jīng)定義好了聚合之間的代碼邊界,這個(gè)過(guò)程不會(huì)太復(fù)雜,也不會(huì)花太多時(shí)間。

最后我們發(fā)現(xiàn),在經(jīng)歷模型和架構(gòu)演進(jìn)后,微服務(wù) 1 已經(jīng)從最初包含聚合 a、b、c,演進(jìn)為包含聚合 b、c、d 的新領(lǐng)域模型和微服務(wù)了。

2.微服務(wù)內(nèi)服務(wù)的演進(jìn)

在微服務(wù)內(nèi)部,實(shí)體的方法被領(lǐng)域服務(wù)組合和封裝,領(lǐng)域服務(wù)又被應(yīng)用服務(wù)組合和封裝。在服務(wù)逐層組合和封裝的過(guò)程中,你會(huì)發(fā)現(xiàn)這樣一個(gè)有趣的現(xiàn)象。

圖片圖片

讓我們來(lái)看一下這張圖。在服務(wù)設(shè)計(jì)時(shí),你可能無(wú)法完全預(yù)測(cè)哪些下層服務(wù)會(huì)被多少個(gè)上層服務(wù)組合調(diào)用。因此,領(lǐng)域?qū)油ǔV惶峁┮恍?/span>原子服務(wù),例如領(lǐng)域服務(wù) a、b、c。

然而,隨著系統(tǒng)功能的增強(qiáng)和外部接入的增多,應(yīng)用服務(wù)會(huì)不斷豐富。某一天,你可能會(huì)發(fā)現(xiàn)領(lǐng)域服務(wù) b 和 c 被多個(gè)應(yīng)用服務(wù)頻繁調(diào)用,且它們的執(zhí)行順序基本一致。這時(shí),你可以考慮將 b 和 c 合并,并將應(yīng)用服務(wù)中 b 和 c 的功能下沉到領(lǐng)域?qū)樱葑優(yōu)橐粋€(gè)新的領(lǐng)域服務(wù)(b+c)。

這種演進(jìn)方式不僅減少了服務(wù)的數(shù)量,還降低了上層服務(wù)組合和編排的復(fù)雜度。

三層架構(gòu)如何演進(jìn)到 DDD 分層架構(gòu)?

通過(guò)前面的講解,相信你已經(jīng)對(duì) DDD 分層架構(gòu)的優(yōu)勢(shì)有了清晰的認(rèn)識(shí)。我們可以總結(jié)出以下兩個(gè)最重要的優(yōu)點(diǎn):

  1. 層間松耦合:DDD 分層架構(gòu)通過(guò)解耦各層之間的依賴關(guān)系,使得我們可以專注于本層的設(shè)計(jì),而無(wú)需過(guò)多關(guān)注其他層。這種設(shè)計(jì)不僅降低了層與層之間的耦合度,還避免了因某一層的改動(dòng)而影響其他層的情況。

  2. 結(jié)構(gòu)清晰,易于升級(jí)和維護(hù):分層架構(gòu)使程序結(jié)構(gòu)更加清晰,升級(jí)和維護(hù)變得更加容易。當(dāng)我們需要修改某一層的代碼時(shí),只要該層的接口參數(shù)保持不變,其他層通常無(wú)需進(jìn)行任何改動(dòng)。即使某一層的接口發(fā)生變化,也只會(huì)影響其直接相鄰的上層,修改工作量較小且風(fēng)險(xiǎn)可控,不會(huì)引發(fā)意外的系統(tǒng)問(wèn)題。

那我們?cè)撛鯓愚D(zhuǎn)向 DDD 分層架構(gòu)呢?不妨看看下面這個(gè)過(guò)程。

傳統(tǒng)企業(yè)應(yīng)用大多是單體架構(gòu),而單體架構(gòu)則大多是三層架構(gòu)。三層架構(gòu)解決了程序內(nèi)代碼間調(diào)用復(fù)雜、代碼職責(zé)不清的問(wèn)題,但這種分層是邏輯概念,在物理上它是中心化的集中式架構(gòu),并不適合分布式微服務(wù)架構(gòu)。

DDD 分層架構(gòu)中的要素其實(shí)和三層架構(gòu)類似,只是在 DDD 分層架構(gòu)中,這些要素被重新歸類,重新劃分了層,確定了層與層之間的交互規(guī)則和職責(zé)邊界。

圖片圖片

讓我們來(lái)看一下這張圖,分析從三層架構(gòu)向 DDD 分層架構(gòu)演進(jìn)的過(guò)程。

1. 演進(jìn)的核心區(qū)域

從三層架構(gòu)向 DDD 分層架構(gòu)的演進(jìn),主要集中在業(yè)務(wù)邏輯層數(shù)據(jù)訪問(wèn)層

2. 用戶接口層的變化

DDD 分層架構(gòu)在用戶接口層引入了 DTO(數(shù)據(jù)傳輸對(duì)象),為前端提供了更多的可用數(shù)據(jù),并提升了展示的靈活性。

3. 業(yè)務(wù)邏輯層的優(yōu)化

DDD 分層架構(gòu)對(duì)三層架構(gòu)的業(yè)務(wù)邏輯層進(jìn)行了更清晰的劃分,解決了三層架構(gòu)中核心業(yè)務(wù)邏輯混亂、代碼改動(dòng)相互影響大的問(wèn)題。具體來(lái)說(shuō):

  • 應(yīng)用層:快速響應(yīng)前端的變化,負(fù)責(zé)服務(wù)的組合、編排和轉(zhuǎn)發(fā)。
  • 領(lǐng)域?qū)?/span>:實(shí)現(xiàn)領(lǐng)域模型的能力,專注于核心業(yè)務(wù)邏輯的表達(dá)。

4. 數(shù)據(jù)訪問(wèn)層的改進(jìn)

在數(shù)據(jù)訪問(wèn)層和基礎(chǔ)層之間,DDD 分層架構(gòu)引入了倉(cāng)儲(chǔ)(Repository)設(shè)計(jì)模式,取代了三層架構(gòu)中的 DAO 方式。倉(cāng)儲(chǔ)模式通過(guò)依賴倒置原則,實(shí)現(xiàn)了各層對(duì)基礎(chǔ)資源的解耦。倉(cāng)儲(chǔ)分為兩部分:

  • 倉(cāng)儲(chǔ)接口:位于領(lǐng)域?qū)樱x數(shù)據(jù)訪問(wèn)的契約。
  • 倉(cāng)儲(chǔ)實(shí)現(xiàn):位于基礎(chǔ)層,負(fù)責(zé)具體的數(shù)據(jù)庫(kù)操作。

此外,三層架構(gòu)中通用的第三方工具包、驅(qū)動(dòng)、Common、Utility、Config 等公共資源類,在 DDD 分層架構(gòu)中被統(tǒng)一放到了基礎(chǔ)層

5. 演進(jìn)的意義

傳統(tǒng)三層架構(gòu)向 DDD 分層架構(gòu)的演進(jìn),體現(xiàn)了領(lǐng)域驅(qū)動(dòng)設(shè)計(jì)思想的逐步成熟和應(yīng)用。這種演進(jìn)不僅優(yōu)化了架構(gòu)的分層設(shè)計(jì),還提升了系統(tǒng)的靈活性、可維護(hù)性和可擴(kuò)展性。

責(zé)任編輯:武曉燕 來(lái)源: 二進(jìn)制跳動(dòng)
相關(guān)推薦

2024-05-31 12:59:03

2025-12-09 03:00:00

2017-11-08 13:31:34

分層架構(gòu)代碼DDD

2023-11-24 07:16:10

DDD微服務(wù)

2022-08-08 13:24:28

整潔架構(gòu)架構(gòu)前端

2023-07-31 08:00:19

2025-02-26 08:46:31

2013-10-28 09:24:34

SDN軟件定義網(wǎng)絡(luò)TCP

2024-05-21 09:26:54

微服務(wù)DDD建模架構(gòu)

2024-11-27 15:33:17

軟件架構(gòu)DDD

2025-01-16 10:38:31

2011-05-31 08:54:37

Android開發(fā) 架構(gòu)

2023-07-04 07:53:53

MVCDDD架構(gòu)

2009-03-24 08:44:40

GoogleAndroid移動(dòng)OS

2013-04-11 09:43:15

Android創(chuàng)建項(xiàng)目Android開發(fā)

2010-02-04 11:06:14

2023-08-02 08:51:46

服務(wù)架構(gòu)分層架構(gòu)

2010-03-10 12:13:06

IT運(yùn)維管理網(wǎng)絡(luò)拓?fù)?/a>摩卡軟件

2020-04-10 10:43:51

Mobvista云計(jì)算成本云原生

2010-03-15 13:53:20

3層交換機(jī)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

欧美精品尤物在线| 欧美激情五月| 成人网址在线观看| 国产高清一区日本| 成a人片在线观看www视频| 欧美另类极品videosbestfree| 亚洲一区二区三区高清| 中文字幕av网| 国内精久久久久久久久久人| 国产精品白丝av| 亚洲成人三级| 亚洲bt欧美bt日本bt| 伊人性伊人情综合网| 亚洲精品黑牛一区二区三区| 免费在线看黄色片| 亚洲电影免费观看高清| 一区二区三区午夜探花| 中文字幕在线第一页| 国产精品视频一| 一区二区三区在线视频观看 | 91视频免费在线| 天天影视色香欲综合网老头| 亚洲a级精品| 嘿咻视频在线看| 国产精品免费一区二区| 欧美一区二区三区成人| 一本久久a久久精品vr综合| 亚洲美女淫视频| 水蜜桃久久夜色精品一区| 日本a一级在线免费播放| 国产欧美韩日| 欧美不卡一区二区三区四区| 成人性视频免费网站| 四虎国产精品永久在线国在线| 日韩五码在线观看| 国内精品视频在线| 岛国av在线不卡| 亚洲精选在线| av在线不卡免费| 欧美日韩国产精品激情在线播放| 69av在线视频| 欧美影视一区二区三区| 国产专区欧美精品| 久久狠狠久久| av电影在线网| 久久综合九色综合88i| 国产精品欧美日韩| 精品88久久久久88久久久| 91麻豆蜜桃一区二区三区| 国产精品x453.com| 韩日精品一区| 91久久精品国产91久久性色| 日韩av在线电影网| 亚洲高清免费视频| 国产乱码精品一区二区三区忘忧草| 久久精品凹凸全集| 在线免费观看的av| 精品久久久久久久大神国产| 中文无码久久精品| 99精品视频在线免费播放 | 91在线中文字幕| 国产一区二区三区在线播放免费观看 | 午夜在线观看av| 欧美二区三区| 91精品久久久久久久久| 亚洲色图25p| 91成人在线免费观看| 国产精品蜜臀av| 成人性生交大片| 免费视频一区二区| 在线电影一区二区| 人人精品亚洲| 亚洲欧美日本国产| 免费日韩成人| 写真福利精品福利在线观看| 国产视频中文字幕在线观看| 香蕉视频在线观看网站| 午夜免费高清视频| 无码aⅴ精品一区二区三区浪潮 | 久久视频在线看| 国产亚洲精品久久久久久牛牛| 欧美日韩你懂的| 色噜噜久久综合| 午夜伦欧美伦电影理论片| av在线二区| 国产日韩欧美综合精品 | 在线观看日韩av先锋影音电影院| 成人免费在线视频观看| 国产精品区一区二区三| 国产精品久久久久久久久图文区| www久久精品| 国产精品免费aⅴ片在线观看| 亚洲视频精选在线| 亚洲国产精品久久人人爱蜜臀| 日韩理论在线观看| 亚洲午夜影视影院在线观看| 亚洲成人一区在线| 日韩欧美亚洲范冰冰与中字| 7777精品伊人久久久大香线蕉超级流畅 | 国产91丝袜在线播放九色| 国产成人精品影院| 国产婷婷色一区二区三区在线| 亚洲成在人线在线播放| 欧美一级xxx| 久久亚洲国产精品| 国产精品福利网| www.成人三级视频| 亚洲人成人77777线观看| 免费看日本黄色| 黄网免费入口| 成年在线电影| 亚洲一区av| 综合精品久久| 99re亚洲国产精品| 日韩欧美在线视频日韩欧美在线视频 | 九九视频精品免费| 亚洲视频一二三| 日韩电影大全免费观看2023年上| 欧美激情亚洲一区| 久久久久免费网| 欧美精品无码一区二区三区| 成人免费视频| 欧美91在线| 狠狠色丁香久久婷婷综合丁香| 亚洲精品欧美激情| 色小说视频一区| 国产精品久久精品国产| 成人禁在线观看网站| **在线精品| 老牛嫩草一区二区三区日本| 一区二区三区四区亚洲| 中文字幕在线亚洲| 欧美重口乱码一区二区| 中文乱码字幕高清在线观看| 麻豆久久一区| 国产69精品久久777的优势| 欧美性一区二区| 国产日韩精品视频| 日韩大片一区二区| 狠狠久久综合| 国产精品99久久久久久有的能看| 日韩三级中文字幕| 蜜桃成人在线| 麻豆视频在线| 欧美亚洲不卡| 91福利视频久久久久| 国产免费成人av| 高清日韩av| 亚洲精品蜜桃乱晃| 亚洲精品免费看| 日韩69视频在线观看| 日韩中文字幕组| 亚洲精品一区二区三区中文字幕| 久久久九九九九| 欧美日韩不卡合集视频| 草草久久久无码国产专区| 人人精品久久| 久久综合九色综合欧美亚洲| 欧美日韩成人精品| 国产一线二线三线在线观看| 国产suv精品一区| 夜夜嗨av一区二区三区网页| 成人网在线视频| 3d成人动漫在线| 老司机一区二区三区| 精品视频在线播放| 免费看黄色一级大片| 欧美禁忌电影| 欧美精选午夜久久久乱码6080| 亚洲高清在线观看一区| 国产精品白丝久久av网站| 亚洲免费看黄网站| 国产精品制服诱惑| 户外露出一区二区三区| 国产欧美一区二区在线| 国产日韩欧美日韩大片| www在线观看播放免费视频日本| 国产精品自拍三区| 欧美在线性爱视频| 国产原创视频在线观看| 久久色在线观看| 国产精品乱码| 国产福利亚洲| 一本大道综合伊人精品热热| 日韩欧美亚洲在线| 日韩av影院| 日韩欧美一区在线| 国产黄色av免费看| 日韩电影一区二区三区| 国产精品aaaa| 韩国女主播一区二区| 欧美日韩中国免费专区在线看| 成人午夜免费在线视频| 亚洲二区三区不卡| 欧美黑人性猛交| gay欧美网站| 91精品国产aⅴ一区二区| 波多野结衣在线中文| 99re免费视频精品全部| 亚洲欧洲日夜超级视频|