精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

被潑冷水后,誰能超越微服務(wù)?

譯文 精選
開發(fā) 架構(gòu)
作為從業(yè)近30年的資深技術(shù)大神,為何做此感嘆?本文通過一場(chǎng)“利用模塊降低架構(gòu)成本”的探討,幫助大家梳理現(xiàn)在的架構(gòu)設(shè)計(jì)難題,希望對(duì)諸君有所啟發(fā)。

?作者 | Shai Almog

策劃 | 云昭

歷史總會(huì)重演。一切剛過去的,又會(huì)被重新提起。開源項(xiàng)目Codename One的聯(lián)合創(chuàng)始人Shai,曾是Sun Microsystems開源LWUIT項(xiàng)目的共同作者,參與了無數(shù)開源項(xiàng)目。作為最早一批Java開發(fā)者,最近感慨道:?jiǎn)误w,又回來了!

Shai說道:我已經(jīng)在這個(gè)圈子里很久時(shí)間了,看到了一次次被拋棄、被重新發(fā)現(xiàn)的想法,超越“時(shí)髦詞匯”,并凱旋而歸。

他進(jìn)一步舉例,“近年來,SQL也掙扎過后,死而復(fù)生。我們?cè)俅螣釔坳P(guān)系數(shù)據(jù)庫(kù)。我認(rèn)為單體架構(gòu)將再次迎來奇幻之旅。微服務(wù)和無服務(wù)器是云供應(yīng)商推動(dòng)的趨勢(shì),目的當(dāng)然是在向我們兜售更多的云計(jì)算資源。然而對(duì)于大多數(shù)用例來說,微服務(wù)在財(cái)務(wù)上意義不大。是的,供應(yīng)商當(dāng)然也可以降低成本。但當(dāng)他們擴(kuò)大規(guī)模時(shí),他們會(huì)以股息來覆蓋掉成本。單是可觀測(cè)性成本的增加,就讓‘大型云’供應(yīng)商的腰包鼓起來了!”

作為從業(yè)近30年的資深技術(shù)大神,為何做此感嘆?本文通過一場(chǎng)“利用模塊降低架構(gòu)成本”的探討,幫助大家梳理現(xiàn)在的架構(gòu)設(shè)計(jì)難題,希望對(duì)諸君有所啟發(fā)。

1、問題背景

我最近領(lǐng)導(dǎo)了一個(gè)會(huì)議小組,討論了微服務(wù)與單體服務(wù)的主題。組內(nèi)認(rèn)為,單塊的規(guī)模不如微服務(wù)。這對(duì)于亞馬遜、eBay等所取代的那些龐然大物來說可能是正確的。這些確實(shí)是巨大的代碼庫(kù),其中的每一次修改都是痛苦的,而且它們的擴(kuò)展都是具有挑戰(zhàn)性的。但這不是一個(gè)公平的比較。較新的方法通常優(yōu)于舊的方法。但如果我們用更新的工具構(gòu)建一個(gè)整體,我們會(huì)得到更好的可擴(kuò)展性嗎?它的局限性是什么?現(xiàn)代的單體(也稱巨石)到底該是什么樣子?

2、單體回歸范例:Modulith

Spring Modulith是一個(gè)模塊化的單體結(jié)構(gòu),可以讓我們使用動(dòng)態(tài)隔離件構(gòu)建單體結(jié)構(gòu)。通過這種方法,我們可以分離測(cè)試、開發(fā)、文檔和依賴項(xiàng)。這有助于微服務(wù)開發(fā)的獨(dú)立方面,而所涉及的開銷很少。它消除了遠(yuǎn)程調(diào)用和功能復(fù)制(存儲(chǔ)、身份驗(yàn)證等)的開銷。

Spring Modulith不是基于Java平臺(tái)模塊化(Jigsaw)。他們?cè)跍y(cè)試期間和運(yùn)行時(shí)強(qiáng)制分離,這是一個(gè)常規(guī)的Spring Boot項(xiàng)目。它有一些額外的運(yùn)行時(shí)功能,可以實(shí)現(xiàn)模塊化的可觀測(cè)性,但它主要是“最佳實(shí)踐”的執(zhí)行者。這種分離的價(jià)值超出了我們通常使用微服務(wù)的價(jià)值,但也有一些權(quán)衡。

舉個(gè)例子,傳統(tǒng)的Spring monolith將采用分層架構(gòu),其包如下:

com.debugagent.myapp
com.debugagent.myapp.services
com.debugagent.myapp.db
com.debugagent.myapp.rest

這很有價(jià)值,因?yàn)樗梢詭椭覀儽苊鈱又g的依賴關(guān)系;例如,DB層不應(yīng)依賴于服務(wù)層。我們可以使用這樣的模塊,并有效地將依賴關(guān)系圖推向一個(gè)方向:向下。但隨著我們的成長(zhǎng),這沒有多大意義。每一層都將充滿業(yè)務(wù)邏輯類和數(shù)據(jù)庫(kù)復(fù)雜性。

有了Modulith,我們的架構(gòu)看起來更像這樣:

com.debugagent.myapp.customers
com.debugagent.myapp.customers.services
com.debugagent.myapp.customers.db
com.debugagent.myapp.customers.rest

com.debugagent.myapp.invoicing
com.debugagent.myapp.invoicing.services
com.debugagent.myapp.invoicing.db
com.debugagent.myapp.invoicing.rest

com.debugagent.myapp.hr
com.debugagent.myapp.hr.services
com.debugagent.myapp.hr.db
com.debugagent.myapp.hr.rest

這看起來非常接近一個(gè)合適的微服務(wù)架構(gòu)。我們根據(jù)業(yè)務(wù)邏輯分離了所有部分。在這里,可以更好地控制交叉依賴關(guān)系,團(tuán)隊(duì)可以專注于自己的孤立區(qū)域,而不必互相踩腳。這是微服務(wù)的價(jià)值之一,且沒有開銷。

我們可以使用注釋進(jìn)一步深入地和聲明性地實(shí)現(xiàn)分離。我們可以定義哪個(gè)模塊使用哪個(gè)并強(qiáng)制單向依賴關(guān)系,因此人力資源模塊將與發(fā)票無關(guān)。客戶模塊也不會(huì)。我們可以在客戶和發(fā)票之間建立單向關(guān)系,并使用事件進(jìn)行反饋。Modulith中的事件是簡(jiǎn)單、快速和事務(wù)性的。它們消除了模塊之間的依賴關(guān)系,無需麻煩。這可以用微服務(wù)實(shí)現(xiàn),但很難實(shí)現(xiàn)。比如,開票需要向不同的模塊公開接口。如何防止客戶使用該界面?

有了模塊,我們就可以做到。對(duì)用戶可以更改代碼并提供訪問權(quán)限,但這需要經(jīng)過代碼審查,這會(huì)帶來自己的問題。請(qǐng)注意,對(duì)于模塊,我們?nèi)匀豢梢砸蕾嚦R姷奈⒎?wù),如功能標(biāo)志、消息傳遞系統(tǒng)等。您可以在文檔和Nicolas Fr?nkel的博客中閱讀有關(guān)Spring Modulith的更多信息。

模塊系統(tǒng)中的每個(gè)依賴項(xiàng)都被映射并記錄在代碼中。Spring實(shí)現(xiàn)包括使用方便的最新圖表自動(dòng)記錄所有內(nèi)容的能力。你可能會(huì)認(rèn)為,依賴性是Terraform的原因。對(duì)于這樣的“高級(jí)”設(shè)計(jì)來說,這是正確的地方嗎?

對(duì)于Modulith部署,像Terraform這樣的基礎(chǔ)設(shè)施即代碼(IaC)解決方案仍然存在,但它們會(huì)簡(jiǎn)單得多。問題是責(zé)任的劃分。正如下圖所展示,微服務(wù)并沒有消除整體結(jié)構(gòu)的復(fù)雜性。我們只把“難啃的骨頭”踢給了DevOps團(tuán)隊(duì)。更糟糕的是,我們沒有給他們正確的工具來理解這種復(fù)雜性,所以他們不得不從外部管理。

圖片

圖源:Twitter

這就是為什么我們行業(yè)的基礎(chǔ)設(shè)施成本在上升,而傳統(tǒng)行業(yè)的基礎(chǔ)設(shè)施價(jià)格卻在下降。當(dāng)DevOps團(tuán)隊(duì)遇到問題時(shí),他們會(huì)投入資源。這顯然不是正確的做法。

3、其他模塊

我們可以使用標(biāo)準(zhǔn)Java平臺(tái)模塊(Jigsaw)來構(gòu)建Spring Boot應(yīng)用程序。這樣做的好處是可以分解應(yīng)用程序和標(biāo)準(zhǔn)Java語(yǔ)法,但有時(shí)可能會(huì)很尷尬。當(dāng)使用外部庫(kù)或?qū)⒁恍┕ぷ鞑鸱譃橥ㄓ霉ぞ邥r(shí),可能會(huì)更有效。

另一個(gè)選項(xiàng)是Maven中的模塊系統(tǒng)。這個(gè)系統(tǒng)允許我們將構(gòu)建分解為多個(gè)單獨(dú)的項(xiàng)目。這是一個(gè)非常方便的過程,可以讓我們省去大量項(xiàng)目的麻煩。每個(gè)項(xiàng)目都是獨(dú)立的,易于使用。它可以使用自己的構(gòu)建過程。然后,當(dāng)我們構(gòu)建主項(xiàng)目時(shí),這些全部都變成了一個(gè)單體。在某種程度上,這才是我們真正想要的。

4、單體架構(gòu):擴(kuò)展,有解嗎

可以使用大多數(shù)微服務(wù)擴(kuò)展工具來擴(kuò)展我們的單體們。許多與擴(kuò)展和集群相關(guān)的開發(fā)都是在單體架構(gòu)的情況下進(jìn)行的。這是一個(gè)更簡(jiǎn)單的過程,因?yàn)橹挥幸粋€(gè)移動(dòng)部分:應(yīng)用程序。我們復(fù)制其他實(shí)例并觀察它們。沒有哪項(xiàng)服務(wù)是失敗的。我們有細(xì)粒度的性能工具,所有的功能都可以作為一個(gè)統(tǒng)一的版本。

我認(rèn)為擴(kuò)展單體為微服務(wù)比直接構(gòu)建微服務(wù)更簡(jiǎn)單——

  • 我們可以使用分析工具,并獲得瓶頸的合理近似值。
  • 我們的團(tuán)隊(duì)可以輕松地(并且經(jīng)濟(jì)實(shí)惠地)設(shè)置運(yùn)行測(cè)試的登臺(tái)環(huán)境。
  • 我們擁有整個(gè)系統(tǒng)及其依賴關(guān)系的單一視圖。
  • 我們可以單獨(dú)測(cè)試單個(gè)模塊并驗(yàn)證性能假設(shè)。

跟蹤和可觀測(cè)性工具非常棒。但它們也會(huì)影響生產(chǎn),有時(shí)還會(huì)產(chǎn)生噪音。當(dāng)我們?cè)噲D解決伸縮瓶頸或性能問題時(shí),這些工具可能會(huì)讓設(shè)計(jì)者踩一些坑。

我們可以將Kubernetes與monolits一起使用,就像將其與微服務(wù)一起使用一樣有效。鏡像尺寸會(huì)更大(如果我們使用GraalVM這樣的工具,則可能不會(huì)太大)。有了這一點(diǎn),我們可以跨區(qū)域復(fù)制monolith ,并提供與微服務(wù)相同的故障轉(zhuǎn)移行為。相當(dāng)多的開發(fā)人員將monolics部署到Lambdas。筆者不太喜歡這種方法,因?yàn)榉浅0嘿F。

5、單體的瓶頸問題:有解

但仍有一點(diǎn)是巨大的障礙:數(shù)據(jù)庫(kù)。由于微服務(wù)固有地具有多個(gè)獨(dú)立的數(shù)據(jù)庫(kù),因此它們實(shí)現(xiàn)了巨大的規(guī)模。單體架構(gòu)通常與單個(gè)數(shù)據(jù)存儲(chǔ)一起工作。這通常是應(yīng)用程序的真正瓶頸。有多種方法可以擴(kuò)展現(xiàn)代數(shù)據(jù)庫(kù)。集群和分布式緩存是強(qiáng)大的工具,可以讓我們達(dá)到在微服務(wù)架構(gòu)中很難達(dá)到的性能水平。

在一個(gè)單體結(jié)構(gòu)中,也并不需要單個(gè)數(shù)據(jù)庫(kù)。例如:在使用Redis進(jìn)行緩存時(shí),選擇使用SQL數(shù)據(jù)庫(kù)也是很常見的事情。但我們也可以為時(shí)間序列或空間數(shù)據(jù)使用單獨(dú)的數(shù)據(jù)庫(kù)。我們也可以使用單獨(dú)的數(shù)據(jù)庫(kù)來提高性能,盡管根據(jù)筆者經(jīng)驗(yàn),這種情況從未發(fā)生過。將數(shù)據(jù)保存在同一數(shù)據(jù)庫(kù)中的好處是巨大的。

6、回歸單體的好處

事實(shí)上,這樣做有一個(gè)驚人的好處,我們可以在不依賴“最終一致性”的情況下完成交易。當(dāng)我們嘗試調(diào)試和復(fù)制分布式系統(tǒng)時(shí),可能會(huì)遇到一個(gè)很難在本地復(fù)制的過渡狀態(tài),甚至很難通過查看可觀測(cè)性數(shù)據(jù)來完全理解。

原始性能消除了大量網(wǎng)絡(luò)開銷。通過適當(dāng)調(diào)整的二級(jí)緩存,我們可以進(jìn)一步刪除80-90%的讀IO。在微服務(wù)中,要實(shí)現(xiàn)這一點(diǎn)要困難得多,而且可能不會(huì)刪除網(wǎng)絡(luò)調(diào)用的開銷。

正如我之前提到的,應(yīng)用程序的復(fù)雜性在微服務(wù)架構(gòu)中不會(huì)消失。我們只是把它搬到了另一個(gè)地方。所以從這個(gè)層面講,微服務(wù)并不算真正的進(jìn)步,因?yàn)樵诖诉^程中平白添加了許多移動(dòng)部件,增加了整體復(fù)雜性。因此,回歸更智能、更簡(jiǎn)單的統(tǒng)一架構(gòu)更有意義。

7、再看微服務(wù)的賣點(diǎn)

編程語(yǔ)言的選擇是微服務(wù)親和力的首要指標(biāo)之一。微服務(wù)的興起與Python和JavaScript的興起相關(guān)。這兩種語(yǔ)言非常適合小型應(yīng)用程序,對(duì)于較大型的應(yīng)用就不太適用了。

Kubernetes使得擴(kuò)展此類部署相對(duì)容易,因此為已經(jīng)增長(zhǎng)的趨勢(shì)增添了動(dòng)力。微服務(wù)也有一些相對(duì)快速的升降能力。這可以以更細(xì)粒度的方式控制成本。在這方面,微服務(wù)被出售給組織,作為降低成本的一種方式。

這并非完全沒有優(yōu)點(diǎn)。如果以前的服務(wù)器部署需要強(qiáng)大(昂貴)的服務(wù)器,那么這一論點(diǎn)可能有一定道理。這可能適用于極端使用的情況,比如:突然面臨非常高的負(fù)載,但隨后沒有堵塞。在這些情況下,可以從托管的Kubernetes提供商動(dòng)態(tài)(廉價(jià))獲取資源。

微服務(wù)的主要賣點(diǎn)之一是組織調(diào)度方面。這使得各個(gè)敏捷團(tuán)隊(duì)能夠在不完全了解“大局”的情況下解決小問題。問題也在于此,這就會(huì)創(chuàng)造一種“單干”文化,讓每個(gè)團(tuán)隊(duì)都“自己做自己的事情”。在縮減規(guī)模的過程中,尤其是在代碼“腐爛”的情況下,問題更甚。系統(tǒng)可能仍能工作數(shù)年,但實(shí)際上無法維護(hù)。

8、互聯(lián)網(wǎng)建立在單體之上

為什么要離開呢

筆者組內(nèi)中的一個(gè)共識(shí)是,我們應(yīng)該始終從單體開始。它更容易構(gòu)建,如果我們選擇使用微服務(wù),我們可以稍后將單體分解。

提及具體某個(gè)軟件相關(guān)的復(fù)雜性,我們討論單個(gè)模塊而不是單個(gè)應(yīng)用程序要更有意義些。二者在資源使用和財(cái)務(wù)浪費(fèi)上的差異是巨大的。在這個(gè)追求“降本”的時(shí)代,為什么人們還要不知變通地默認(rèn)構(gòu)建微服務(wù),而不是動(dòng)態(tài)的模塊化單體架構(gòu)呢?

我們可以從這兩大“架構(gòu)陣營(yíng)”學(xué)到很多東西。誠(chéng)然,微服務(wù)為亞馬遜創(chuàng)造了奇跡。但公平地說,他們的云成本已包含在這個(gè)奇跡之中。所以,一位的搞微服務(wù)教條肯定是有問題的。

另一方面,互聯(lián)網(wǎng)是建立在單體之上的。它們中的大多數(shù)都不是模塊化的。兩者都有普遍適用的技術(shù)。因此,筆者看來,正確的選擇是構(gòu)建一個(gè)模塊化的單體結(jié)構(gòu),先搭建好合適的身份驗(yàn)證基礎(chǔ)設(shè)施,如果我們想在未來轉(zhuǎn)向微服務(wù),我們可以利用這些基礎(chǔ)設(shè)施來進(jìn)行解構(gòu)拆分。

9、后記

在設(shè)計(jì)應(yīng)用時(shí),我們目前更多是面臨“二選一”的架構(gòu)選擇:?jiǎn)误w和微服務(wù)。它們二者通常被視為相反的方法。

在小型系統(tǒng)演進(jìn)過程中,有這樣一個(gè)不爭(zhēng)的事實(shí):?jiǎn)误w應(yīng)用程序往往會(huì)隨著時(shí)間的推移而在架構(gòu)上降級(jí),即使在其生命周期開始階段就定義其為架構(gòu)。隨著時(shí)間的推移,各種架構(gòu)的禁止事項(xiàng)會(huì)不知不覺地進(jìn)入項(xiàng)目,久而久之,系統(tǒng)變得更難改變,進(jìn)化性受到影響。

另一方面,微服務(wù)提供了更強(qiáng)的分離手段,但同時(shí)也帶來了許多復(fù)雜性,因?yàn)榧词箤?duì)于小型應(yīng)用程序,團(tuán)隊(duì)也必須應(yīng)對(duì)分布式系統(tǒng)的挑戰(zhàn)。

單體回歸,也是具體的有條件的回歸。我們看到,趨勢(shì)的改變,代表著某段時(shí)期具體任務(wù)或者目標(biāo)正在變化。出于目標(biāo)的變化,我們對(duì)于微服務(wù)和單體架構(gòu)的二選一的選擇問題,也不能再教條式的看待。

事物往往都在螺旋式的演進(jìn),對(duì)于架構(gòu)而言,亦如是。

原文鏈接:https://dzone.com/articles/is-it-time-to-go-back-to-the-monolith

責(zé)任編輯:武曉燕 來源: 51CTO技術(shù)棧
相關(guān)推薦

2023-01-09 07:32:27

架構(gòu)微服務(wù)轉(zhuǎn)型

2011-05-31 10:41:13

ARM服務(wù)器

2015-06-09 11:15:01

開源OpenStack

2011-11-28 09:05:01

JavaScriptDart微軟

2019-03-27 10:54:00

5G運(yùn)營(yíng)商設(shè)備制造商

2018-09-26 14:00:09

人工智能區(qū)塊鏈投資

2009-07-14 14:43:01

2025-07-10 08:40:59

2016-01-06 09:32:46

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

2017-07-25 16:44:37

5G技術(shù)4G

2009-03-21 10:12:10

微軟瀏覽器IE8

2020-09-03 14:09:43

量子芯片計(jì)算

2011-10-09 10:35:35

喬布斯蘋果Kindle fire

2018-01-04 13:21:10

深度學(xué)習(xí)人工智能數(shù)據(jù)

2024-01-05 08:44:52

2018-03-16 10:27:49

人工智能霍金

2022-02-16 17:14:20

WebWeb3.0去中心化

2018-08-06 11:47:07

云計(jì)算挑戰(zhàn)混合云

2009-02-26 10:42:55

云計(jì)算富士通

2023-09-01 09:42:37

模型學(xué)習(xí)
點(diǎn)贊
收藏

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

亚洲深夜影院| 成人久久精品| 91女神在线视频| 欧美一区在线直播| 亚洲欧洲久久久| 澳门av一区二区三区| 国产精品―色哟哟| 91香蕉电影院| 日韩免费av片| 奇米亚洲欧美| 欧美日本在线看| 亚洲爆乳无码精品aaa片蜜桃| 日韩一级片免费| 久久在线精品| 久久精品国产99国产精品澳门| 久久久久久久穴| 午夜欧美激情| 国产精品久久夜| www.成人av.com| 中文字幕日韩免费| 亚洲理论电影网| 日韩精品高清在线| 日韩av.com| 成人av免费电影网站| 亚洲欧美在线观看| 久久久久久久久久久一区| 一区二区三区在线免费观看视频| 欧美午夜在线视频| 中文字幕国产日韩| 性囗交免费视频观看| 高清在线一区| 天天综合天天做天天综合| 亚洲午夜高清视频| 天天操天天射天天| 国产一区二区在线免费观看| 57pao成人国产永久免费| 天天色天天综合| 亚洲a级精品| 欧美电影精品一区二区| 天天插天天操天天射| 高清在线视频不卡| 亚洲久本草在线中文字幕| 日韩精品国内| 少妇av一区二区| 韩国视频一区二区| 国产精品九九九| 国产一级特黄毛片| 在线免费观看日本欧美爱情大片| 一区二区三区在线播放欧美| 久久久午夜精品福利内容| 日韩黄色av| 欧美男人的天堂一二区| 久草热视频在线观看| av在线影院| 国产精品黄色在线观看| 日韩精品一区二区三区丰满| 天天综合天天综合| 成人精品一区二区三区四区| 91亚洲精品在线| 中文字幕在线观看高清| 日本欧洲一区二区| 国产成人中文字幕| 无码人妻丰满熟妇区bbbbxxxx| 亚洲日本久久| 久久久久久有精品国产| 欧美精品入口蜜桃| 欧美不卡在线| 久久69精品久久久久久国产越南| 日本成人精品视频| 欧美第十八页| 久久精品国产一区| 91免费公开视频| 亚洲精品99| 欧美精品免费在线观看| 丰满少妇高潮久久三区| 欧美激情五月| 欧美精品aaa| 国产无码精品在线播放| 99热免费精品| 日韩av电影在线播放| av手机天堂网| 美美哒免费高清在线观看视频一区二区| 国产成人综合精品在线| 最近中文字幕在线观看视频| 免费看精品久久片| 91亚洲国产成人久久精品网站| 99在线观看免费| 大尺度一区二区| 国产伦一区二区三区色一情| 国产精品国产高清国产| 久久精品视频一区| 中文字幕中文字幕在线中心一区| 二区在线播放| 亚洲成人tv网| 久久久久久久少妇| 日韩综合久久| 亚洲第一精品自拍| 亚洲精品一区二区三区影院忠贞| 国产精品成久久久久| 九九热最新视频//这里只有精品| 日本熟妇毛耸耸xxxxxx| 欧美综合在线观看视频| 亚洲高清一区二区三区| 成人免费网站在线| va视频在线观看| 风间由美一区二区三区在线观看| 国产精品香蕉视屏| 日韩porn| 国产精品国产三级国产| 99er在线视频| 国精产品一区二区三区有限公司 | 欧美日韩中文精品| 苍井空张开腿实干12次| 国产精品探花在线观看| 久久精品国产欧美亚洲人人爽| 久久网免费视频| 日日欢夜夜爽一区| 国产在线精品自拍| 亚洲 精品 综合 精品 自拍| 国产精品美女久久久久av爽李琼| 黄色a级片免费看| 精品亚洲美女网站| 精品欧美久久久| 东京热无码av男人的天堂| 欧美区日韩区| 国产精品十八以下禁看| 日本黄色免费视频| 国产精品久久久一本精品| 中国丰满熟妇xxxx性| 精品美女一区| 亚洲人成网在线播放| 久久高清无码视频| 麻豆精品国产传媒mv男同| 精品一区二区视频| 在线中文字幕电影| 欧美性大战xxxxx久久久| 精品少妇人妻av一区二区三区| 日本不卡二三区| 97成人超碰免| 国产1区在线观看| 最新国产の精品合集bt伙计| 国产成人av影视| 国产ts一区| 久久影视电视剧免费网站| 欧美a视频在线观看| 国产xxx精品视频大全| 中文字幕精品一区日韩| 精品免费av一区二区三区| 亚洲精品成人免费| www.av视频在线观看| 狠狠色狠狠色综合| 日日噜噜噜夜夜爽爽| 黄色综合网址| 日韩成人av网| 成年人午夜视频| 成人免费毛片a| 妞干网这里只有精品| 欧美伊人亚洲伊人色综合动图| 亚洲偷熟乱区亚洲香蕉av| 国产成人在线观看网站| 国产91在线|亚洲| 中文字幕一区二区三区最新| 亚洲精品无播放器在线播放| 日韩少妇与小伙激情| 中文字幕91爱爱| 国产精品全国免费观看高清| 日本美女高潮视频| 色999国产精品| 国产精品揄拍500视频| 不卡在线视频| 欧美日韩国产在线播放网站| 麻豆一区在线观看| 久久国产精品第一页| 黄频视频在线观看| 国产 日韩 欧美| 免费99精品国产自在在线| 国产av一区二区三区精品| 一区二区三区免费观看| 99久久久无码国产精品性波多 | 国产精品免费看一区二区三区| a黄色片在线观看| 日韩欧美电影一二三| 日本视频www| 久久久久久久国产精品影院| www.99av.com| 亚洲精品成人无限看| 成人国产一区二区| 亚洲黄色中文字幕| 日韩av网站在线| 中文字幕在线天堂| 亚洲视频在线一区观看| 色悠悠在线视频| 亚洲在线一区| 视频一区视频二区视频三区视频四区国产 | 影音国产精品| 国模精品娜娜一二三区| 高清成人在线| 久久精品国产2020观看福利| 亚洲AV午夜精品| 欧美日韩中文字幕| 久久国产高清视频| 99天天综合性| 中文字幕有码av| 黄色精品一区| 欧洲一区二区日韩在线视频观看免费| 男人天堂久久| 国模吧一区二区三区| 91在线直播| 亚洲第一男人av| 亚洲图片欧美在线| 亚洲大片一区二区三区| 摸摸摸bbb毛毛毛片| 国产成人自拍在线| 国产免费999| 在线观看视频日韩| 一本色道久久综合亚洲精品婷婷| 91精品国产自产精品男人的天堂| 日本一区二区在线播放| 中文字幕在线三区| 亚洲欧洲国产一区| 高清毛片aaaaaaaaa片| 欧美午夜电影在线播放| 日本一区二区欧美| 1000部国产精品成人观看| 91精品国产自产| 国产精品一区二区无线| av在线无限看| 亚洲精品偷拍| 久久国产精品免费观看| 欧美丝袜激情| 久久一区免费| 精品在线网站观看| 亚洲直播在线一区| 成人18视频在线观看| 91大神福利视频在线| 欧美xxxxhdvideosex| 日韩在线视频观看| 国产综合在线观看| 国产午夜精品久久久| 亚洲黄色a级片| 91精品一区二区三区久久久久久| 黄色污污网站在线观看| 黑人精品xxx一区| 日本少妇激情舌吻| 亚洲综合av网| 日本在线一级片| 国产精品久久久久久久岛一牛影视| 成人影视免费观看| 99热在这里有精品免费| www.黄色网| 国产精品99久久久久久久女警 | 深爱五月综合网| 日本不卡的三区四区五区| 国产超级av在线| 亚洲精品激情| 9色porny| 欧美日韩精品免费观看视频完整| 久久久成人精品一区二区三区| 日韩成人精品一区二区| 日韩久久不卡| 精品理论电影| 午夜精品区一区二区三| 六月丁香久久丫| 国产伦精品一区二区三区照片91 | 精品一二三区视频| 亚洲欧美日韩在线一区| 国产视频二区在线观看| 国产小视频91| 草碰在线视频| 久久久国产精彩视频美女艺术照福利| 幼a在线观看| 日韩视频免费在线| av在线影院| 久久久伊人日本| 性感女国产在线| 国产97在线亚洲| 久久福利在线| 亚洲一区二区三区在线免费观看| 久久久精品区| 国产欧美精品一区二区三区| 欧美日韩一本| 日本精品一区| 久久久久久久久久久9不雅视频| 精品国产无码在线| 在线精品一区| 国产福利一区视频| 狠狠色狠狠色综合系列| 精品影片一区二区入口| 久久久精品免费观看| 国产又色又爽又高潮免费 | 欧美国产日韩综合| 精品国产成人av| 精品一区二区无码| 91精品在线观看入口| 污视频软件在线观看| 一本一道久久a久久精品逆3p| 欧美性videos| 97国产精品视频人人做人人爱| 亚洲综合在线电影| av一本久道久久波多野结衣| 香蕉视频一区| 亚洲第一精品区| 国产日韩欧美高清免费| 中文字幕第38页| 成人av综合在线| 久久久久99精品成人| 亚洲3atv精品一区二区三区| 中文字幕 人妻熟女| 日韩精品在线一区二区| 国产日韩精品在线看| 欧美激情精品久久久| 欧美韩国亚洲| 国产成人免费观看| 成人亚洲一区二区| 2018国产在线| 久久91精品久久久久久秒播| 黄色片视频免费观看| 亚洲欧洲www| 特黄视频免费看| 欧美一级片免费看| 国产粉嫩一区二区三区在线观看| 久久91精品国产91久久跳| 吞精囗交69激情欧美| 国产伦理久久久| 亚洲影视一区二区三区| 虎白女粉嫩尤物福利视频| 国产精品一区二区你懂的| 国产91丝袜美女在线播放| 午夜欧美在线一二页| av免费在线不卡| 一区二区日韩精品| 美女av在线免费看| 成人av片网址| 天堂美国久久| 欧美一级裸体视频| 久久亚洲精精品中文字幕早川悠里 | 亚洲国产日韩综合久久精品| 精品乱码一区内射人妻无码| 日韩av一卡二卡| 激情图片在线观看高清国产| 91久久中文字幕| 99视频精品视频高清免费| 中文字幕在线观看第三页| 久久久久国产精品人| 久久夜色精品亚洲| 欧美成人bangbros| 国产成人无吗| 国产精品网址在线| 尤物tv在线精品| 青青草成人免费在线视频| 国产精品主播直播| 日韩av手机在线免费观看| 欧美老肥妇做.爰bbww| 69久久夜色| 国产精品日日做人人爱| 精品国产一级毛片| 久久综合久久色| 日本一区二区三区国色天香 | 极品粉嫩国产18尤物| 国产成人精品亚洲午夜麻豆| 裸体武打性艳史| 这里只有精品99re| 国产精品久久麻豆| 亚洲jizzjizz日本少妇| 欧美黄免费看| 国产调教打屁股xxxx网站| 亚洲一区精品在线| 人妻妺妺窝人体色www聚色窝 | 在线看一区二区| 川上优的av在线一区二区| 国产精品爽爽爽| 天天揉久久久久亚洲精品| 污污视频网站在线| 亚洲精品视频在线观看网站| www.久久久久久| 久久男人的天堂| 欧美亚视频在线中文字幕免费| 69堂免费视频| 国产亚洲一区二区三区四区| 少妇高潮av久久久久久| 中文字幕亚洲欧美一区二区三区 | 无码人妻精品一区二区三区9厂| 亚洲少妇中文在线| 成人亚洲免费| 超碰10000| 成人福利在线看| 99超碰在线观看| 日韩中文在线视频| 天堂va在线高清一区| 国产精品一区二区免费在线观看| 久久久久久久性| 国产精品久久久久久久成人午夜| 欧美日本高清视频| 日韩高清成人在线| 三上悠亚在线一区二区| 亚洲黄色片在线观看| 三级视频网站在线| 成人激情视频小说免费下载| 伊人久久综合| 成年人在线免费看片|