日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當(dāng)前位置:首頁 > 科技  > 軟件

業(yè)務(wù)側(cè)最好的朋友:微服務(wù)中的 BFF 架構(gòu)

來源: 責(zé)編: 時(shí)間:2024-07-05 09:03:29 1160觀看
導(dǎo)讀在我們之前設(shè)計(jì)的一個(gè)供應(yīng)鏈系統(tǒng)中,它包含了商品、銷售訂單、加盟商、門店運(yùn)營、門店工單等服務(wù),涉及了各種用戶角色,比如總部商品管理、總部門店管理、加盟商員工、門店人員等,而且每個(gè)部門的角色還會進(jìn)行細(xì)分。而且這個(gè)

在我們之前設(shè)計(jì)的一個(gè)供應(yīng)鏈系統(tǒng)中,它包含了商品、銷售訂單、加盟商、門店運(yùn)營、門店工單等服務(wù),涉及了各種用戶角色,比如總部商品管理、總部門店管理、加盟商員工、門店人員等,而且每個(gè)部門的角色還會進(jìn)行細(xì)分。而且這個(gè)系統(tǒng)中還包含了兩個(gè)客戶端 App:一個(gè)面向客戶,另一個(gè)面向公司員工和加盟商。mBi28資訊網(wǎng)——每日最新資訊28at.com

此時(shí),整個(gè)供應(yīng)鏈系統(tǒng)的架構(gòu)如下圖所示:mBi28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片mBi28資訊網(wǎng)——每日最新資訊28at.com

上圖中的網(wǎng)關(guān)層主要負(fù)責(zé)路由、認(rèn)證、監(jiān)控、限流熔斷等工作。mBi28資訊網(wǎng)——每日最新資訊28at.com

  • 路由:所有的請求都需要通過網(wǎng)關(guān)層進(jìn)行處理,網(wǎng)關(guān)層再根據(jù) URI 將請求指向?qū)?yīng)的后臺服務(wù),如果同一個(gè)服務(wù)存在多個(gè)服務(wù)器節(jié)點(diǎn),網(wǎng)關(guān)層還將承擔(dān)負(fù)載均衡的工作。
  • 認(rèn)證:對所有的請求進(jìn)行集中認(rèn)證鑒權(quán)。
  • 監(jiān)控:記錄所有的 API 請求數(shù)據(jù),API 管理系統(tǒng)能對 API 調(diào)用實(shí)現(xiàn)管理和性能監(jiān)控。
  • 限流熔斷:流量過大時(shí),我們可以在網(wǎng)關(guān)層實(shí)現(xiàn)限流。如果后臺服務(wù)響應(yīng)延時(shí)或故障,我們可以主動(dòng)在調(diào)用端的上游服務(wù)做熔斷,以此保護(hù)后端服務(wù)資源,同時(shí)不影響用戶體驗(yàn)。

此時(shí),我們的架構(gòu)看起來是不是挺完美?且市面上標(biāo)準(zhǔn)的 Spring Cloud 架構(gòu)都是這樣做的。不過,這個(gè)架構(gòu)會出現(xiàn)一些問題,下面我們先通過幾個(gè)例子來看看。mBi28資訊網(wǎng)——每日最新資訊28at.com

案例一

在這個(gè)供應(yīng)鏈系統(tǒng)中,很多界面都需要顯示多個(gè)服務(wù)數(shù)據(jù),比如在一個(gè) App 首頁中,針對門店運(yùn)營人員,需要顯示工單數(shù)量、最近的工單、銷售訂單數(shù)據(jù)、最近待處理的訂單、低于庫存安全值的商品等信息。mBi28資訊網(wǎng)——每日最新資訊28at.com

此時(shí)第一個(gè)問題來了,在接口設(shè)計(jì)過程中,我們經(jīng)常糾結(jié)將兩個(gè)客戶端 App 調(diào)用的接口存放在哪個(gè)服務(wù)中?以至于決策效率低下,而且還會出現(xiàn)職責(zé)劃分不統(tǒng)一的情況。mBi28資訊網(wǎng)——每日最新資訊28at.com

最終我們決定將第一個(gè)接口存放在門店服務(wù)中,此時(shí)調(diào)用關(guān)系如下圖所示:mBi28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片mBi28資訊網(wǎng)——每日最新資訊28at.com

并將第二個(gè)接口存放在工單服務(wù)中,此時(shí)調(diào)用關(guān)系如下圖所示:mBi28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片mBi28資訊網(wǎng)——每日最新資訊28at.com

案例二

一個(gè)用戶的提交操作常常需要修改多個(gè)服務(wù)數(shù)據(jù),比如一個(gè)提交工單的操作,我們需要修改庫存、銷售訂單狀態(tài)、工單等數(shù)據(jù)。關(guān)注公眾號:碼猿技術(shù)專欄,回復(fù)關(guān)鍵詞:1111 獲取阿里內(nèi)部Java性能調(diào)優(yōu)手冊!mBi28資訊網(wǎng)——每日最新資訊28at.com

此時(shí)第二個(gè)問題出現(xiàn)了,因?yàn)檫@樣的需求非常多,所以服務(wù)經(jīng)常被其他多個(gè)服務(wù)調(diào)來調(diào)去,導(dǎo)致服務(wù)之間的依賴非?;靵y,最終服務(wù)調(diào)用關(guān)系如下圖所示:mBi28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片mBi28資訊網(wǎng)——每日最新資訊28at.com

通過上圖,我們發(fā)現(xiàn)服務(wù)間的依賴問題給技術(shù)迭代帶來了地獄般的體驗(yàn),講解,這里就不過多贅述。mBi28資訊網(wǎng)——每日最新資訊28at.com

為了解決這 2 個(gè)問題,最終我們決定抽象一個(gè) API 層。mBi28資訊網(wǎng)——每日最新資訊28at.com

API 層

一般來說,客戶端的接口需要滿足聚合、分布式調(diào)用、裝飾這三種需求。mBi28資訊網(wǎng)——每日最新資訊28at.com

  • 聚合:一個(gè)接口需要聚合多個(gè)后臺服務(wù)返回的數(shù)據(jù),并將數(shù)據(jù)返回給客戶端。
  • 分布式調(diào)用:一個(gè)接口可能需要依次調(diào)用多個(gè)后臺服務(wù),才能實(shí)現(xiàn)多個(gè)后臺服務(wù)的數(shù)據(jù)修改。
  • 裝飾:一個(gè)接口需要重新裝飾后臺返回的數(shù)據(jù),比如刪除一些字段或者對某些字段進(jìn)行封裝,然后組成客戶端需要的數(shù)據(jù)。

因此,我們決定在客戶端與后臺服務(wù)之間增加一個(gè)新的 API 層,專門用來滿足上面的三點(diǎn)需求,此時(shí)整個(gè)架構(gòu)如下圖所示。mBi28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片mBi28資訊網(wǎng)——每日最新資訊28at.com

從圖中我們發(fā)現(xiàn),所有請求經(jīng)過網(wǎng)關(guān)后,全部交由一個(gè)共用的 API 層進(jìn)行處理,而該 API 層沒有自己的數(shù)據(jù)庫,它的主要職責(zé)是調(diào)用其他后臺服務(wù)。mBi28資訊網(wǎng)——每日最新資訊28at.com

通過這樣的設(shè)計(jì)方案后,以上兩個(gè)問題就得到了很多地解決。mBi28資訊網(wǎng)——每日最新資訊28at.com

  • 應(yīng)該將某個(gè)接口放在哪個(gè)服務(wù)的糾結(jié)次數(shù)減少了:如果是聚合、裝飾、分布式的調(diào)用邏輯,我們直接把它們放在 API 層。如果是要落庫或者查詢數(shù)據(jù)庫的邏輯,目標(biāo)數(shù)據(jù)在哪個(gè)服務(wù)中,我們就把數(shù)據(jù)和邏輯放在哪個(gè)服務(wù)中。
  • 后臺服務(wù)之間的依賴也大幅減少了:目前的依賴關(guān)系只有 API 層調(diào)用各個(gè)后臺服務(wù)。

此時(shí),我們的設(shè)計(jì)方案完美了吧?別高興得太早,還會出現(xiàn)新的問題。mBi28資訊網(wǎng)——每日最新資訊28at.com

客戶端適配問題

在這個(gè)供應(yīng)鏈系統(tǒng)中,一系列的接口主要供各種客戶端(比如 App、H5、PC 網(wǎng)頁、小程序等)進(jìn)行調(diào)用,此時(shí)的調(diào)用關(guān)系如下圖所示:mBi28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片mBi28資訊網(wǎng)——每日最新資訊28at.com

不過,這種設(shè)計(jì)方案會存在 3 個(gè)問題:mBi28資訊網(wǎng)——每日最新資訊28at.com

不同客戶端的頁面細(xì)節(jié)的需求可能不一樣,比如 App 的功能比重大,就會要求頁面中多放一些信息,而小程序的功能比重小,同樣的頁面就會要求少放一些信息,以至于后臺服務(wù)中同一個(gè) API 需要針對不同客戶端實(shí)現(xiàn)不同適配;mBi28資訊網(wǎng)——每日最新資訊28at.com

客戶端經(jīng)常需要進(jìn)行一些輕微的改動(dòng),比如增加一個(gè)字段/刪除一個(gè)字段,此時(shí)我們必須采取數(shù)據(jù)最小化原則來縮減客戶端接口的響應(yīng)速度。而且,為了客戶端這種細(xì)微而頻繁的改動(dòng),后臺服務(wù)經(jīng)常需要同步發(fā)版;mBi28資訊網(wǎng)——每日最新資訊28at.com

結(jié)合 #1 和 #2 我們發(fā)現(xiàn),在后臺服務(wù)的發(fā)版過程中,常常需要綜合考慮不同客戶端的兼容問題,這無形中增加了 API 層為不同客戶端做兼容的復(fù)雜度。mBi28資訊網(wǎng)——每日最新資訊28at.com

這時(shí)該如何解決呢?我們就可以考慮使用 BFF 了。mBi28資訊網(wǎng)——每日最新資訊28at.com

BFF(Backend for Front)

BFF 不是一個(gè)架構(gòu),而是一個(gè)設(shè)計(jì)模式,它的主要職責(zé)是為前端設(shè)計(jì)出優(yōu)雅的后臺服務(wù),即一個(gè) API。一般而言,每個(gè)客戶端都有自己的 API 服務(wù),此時(shí)整個(gè)架構(gòu)如下圖所示:mBi28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片mBi28資訊網(wǎng)——每日最新資訊28at.com

從上圖可以看到:不同的客戶端請求經(jīng)過同一個(gè)網(wǎng)關(guān)后,它們都將分別重定向到為對應(yīng)客戶端設(shè)計(jì)的 API 服務(wù)中。因?yàn)槊總€(gè) API 服務(wù)只能針對一種客戶端,所以它們可以對特定的客戶端進(jìn)行專門優(yōu)化。而去除了兼容邏輯的 API 顯得更輕便,響應(yīng)速度還比通用的 API 服務(wù)更快(因?yàn)樗恍枰袛嗖煌蛻舳说倪壿嫞?span style="display:none">mBi28資訊網(wǎng)——每日最新資訊28at.com

除此之外,每種客戶端還可以實(shí)現(xiàn)自己發(fā)布,不需要再跟著其他客戶端一起排期。mBi28資訊網(wǎng)——每日最新資訊28at.com

此時(shí)的方案挺完美了吧?還不完美,因?yàn)樯厦娴姆桨笇儆谝粋€(gè)通用架構(gòu)。在實(shí)際業(yè)務(wù)中,我們還需要結(jié)合實(shí)際業(yè)務(wù)來定,下面我們深入說明一下實(shí)際業(yè)務(wù)需求。mBi28資訊網(wǎng)——每日最新資訊28at.com

前面我們列出了 5 種服務(wù),實(shí)際上,整個(gè)供應(yīng)鏈系統(tǒng)將近有 100 種服務(wù)。因?yàn)樗且粋€(gè)非常龐大的系統(tǒng),且整個(gè)業(yè)務(wù)鏈條的所有工作都包含在這個(gè)系統(tǒng)中,比如新零售、供應(yīng)鏈、財(cái)務(wù)、加盟商、售后、客服等,,這就需要幾百號研發(fā)人員同時(shí)進(jìn)行維護(hù)。mBi28資訊網(wǎng)——每日最新資訊28at.com

因?yàn)槲覀児餐S護(hù)一個(gè) App、PC 界面、新零售、售后、加盟商,還有各自的小程序和 H5,所以為了實(shí)現(xiàn)業(yè)務(wù)解耦和分開排期,每個(gè)部門需要各自維護(hù)自己的 API 服務(wù),而且 App 與 PC 前端也需要根據(jù)部門實(shí)現(xiàn)組件化,此時(shí)的架構(gòu)如下圖所示。mBi28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片mBi28資訊網(wǎng)——每日最新資訊28at.com

針對以上需求,我們?nèi)绾卧诩夹g(shù)架構(gòu)上進(jìn)行實(shí)現(xiàn)呢?下面具體來看看。mBi28資訊網(wǎng)——每日最新資訊28at.com

技術(shù)架構(gòu)上如何實(shí)現(xiàn)?

我們的整套架構(gòu)還是基于 Spring Cloud 設(shè)計(jì)的,如下圖所示:mBi28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片mBi28資訊網(wǎng)——每日最新資訊28at.com

下面我們簡單介紹下圖中網(wǎng)關(guān)、API服務(wù)、后臺服務(wù)的作用。mBi28資訊網(wǎng)——每日最新資訊28at.com

  • 網(wǎng)關(guān):網(wǎng)關(guān)使用的是 Spring Cloud Zuul,Zuul 將拉取的注冊存放在 ZooKeeper 的 API 服務(wù)中,然后通過 Feign 調(diào)用 API 服務(wù)。
  • API 服務(wù):API 服務(wù)其實(shí)就是一個(gè) Spring Web 服務(wù),它沒有自己的數(shù)據(jù)庫,主要職責(zé)是聚合、分布式調(diào)用及裝飾數(shù)據(jù),并通過 Feign 調(diào)用后臺服務(wù)。
  • 后臺服務(wù):后臺服務(wù)其實(shí)也是一個(gè) Spring Web 服務(wù),它有自己的數(shù)據(jù)庫和緩存。

此時(shí)的方案看著很完美了,不過它會出現(xiàn) API 之間代碼重復(fù)問題。此時(shí)我們該如何解決?且往下看mBi28資訊網(wǎng)——每日最新資訊28at.com

如何解決 API 之間代碼重復(fù)問題?

雖然 H5 與小程序的布局不同,但是頁面中很多功能一致,也就是說重復(fù)的代碼邏輯主要存在 PC API 和 App API 中。mBi28資訊網(wǎng)——每日最新資訊28at.com

然而,針對重復(fù)代碼的問題,不同部門在設(shè)計(jì)時(shí)會呈現(xiàn) 3 種不同的邏輯:mBi28資訊網(wǎng)——每日最新資訊28at.com

  • 某些部門將這些重復(fù)的代碼存放在一個(gè) JAR 中,讓幾個(gè) API 服務(wù)實(shí)現(xiàn)共用;
  • 某些部門將這些重復(fù)的代碼抽取出來,然后存放在一個(gè)叫 CommonAPI 的獨(dú)立 API 服務(wù)中,其他 API 服務(wù)直接調(diào)用這個(gè) Common API 就行;
  • 某些部門因?yàn)橹貜?fù)邏輯少,通過評估后,他們發(fā)現(xiàn)維護(hù)這些重復(fù)代碼的成本小于維護(hù) #1 中的 JAR 或者 #2 中的 CommonAPI 服務(wù),所以會繼續(xù)讓這些重復(fù)代碼存在。

假如某些 API 服務(wù)提供接口的出入?yún)⑴c后臺服務(wù)的一致,此時(shí)該怎么辦? 此時(shí) API 服務(wù)的接口無須做任何事情,因?yàn)樗皇且粋€(gè)簡單的代理層。mBi28資訊網(wǎng)——每日最新資訊28at.com

于是,有同事提出:“每次一看到這些純代理的 API 接口就不爽,我們能不能想辦法把它們?nèi)サ簟!鞭k法倒是有幾個(gè),我們一起來看看。mBi28資訊網(wǎng)——每日最新資訊28at.com

  • 網(wǎng)關(guān)直接繞過 API 服務(wù)調(diào)用后臺服務(wù),不過這樣就會破壞分層,所以很快被否掉了。
  • 在 API 服務(wù)層做一個(gè)攔截器,如果 URI 找不到對應(yīng) API 服務(wù)中的 controller mapping,就會直接通過 URI 找后臺服務(wù)并進(jìn)行調(diào)用。不過這種方式將大大增加系統(tǒng)的復(fù)雜度,出問題時(shí)調(diào)查起來更麻煩且收益不大。而寫這些無腦代碼不僅成本低,整體的接口列表還更可控。

綜合考慮后,最終我們決定保留無腦的代碼。mBi28資訊網(wǎng)——每日最新資訊28at.com

后臺服務(wù)與 API 服務(wù)的開發(fā)團(tuán)隊(duì)如何進(jìn)行分工?

最后我們是這樣分工的:專門的 API 開發(fā)團(tuán)隊(duì)負(fù)責(zé) API 服務(wù),而后臺服務(wù)需要根據(jù)領(lǐng)域再劃分小組的職責(zé)。mBi28資訊網(wǎng)——每日最新資訊28at.com

這種劃分方式的好處在于 API 團(tuán)隊(duì)能對所有服務(wù)有個(gè)整體認(rèn)識,且不會出現(xiàn)后臺服務(wù)劃分不清晰、工作重復(fù)的情況。而壞處在于 API 團(tuán)隊(duì)整體業(yè)務(wù)邏輯偏簡單,長久留不住人。mBi28資訊網(wǎng)——每日最新資訊28at.com

本文鏈接:http://m.www897cc.com/showinfo-26-98861-0.html業(yè)務(wù)側(cè)最好的朋友:微服務(wù)中的 BFF 架構(gòu)

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。郵件:2376512515@qq.com

上一篇: 你有多久沒在 JS 中使用 class 了?

下一篇: 使用Spring Boot和流量控制算法解決視頻會議系統(tǒng)網(wǎng)絡(luò)波動(dòng)問題

標(biāo)簽:
  • 熱門焦點(diǎn)
Top 日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不
欧美国产视频在线| 一区二区三区视频免费在线观看| 欧美午夜一区二区三区免费大片 | 久久久夜精品| 欧美承认网站| 欧美视频中文字幕在线| 国产日韩欧美高清| 亚洲高清免费| 亚洲一区视频在线| 老牛国产精品一区的观看方式| 欧美精品在线网站| 国产一区二区丝袜高跟鞋图片| 最新日韩av| 午夜免费在线观看精品视频| 美日韩精品视频免费看| 欧美亚男人的天堂| 黄色成人在线免费| 在线一区二区三区做爰视频网站| 久久久久国内| 欧美日韩国产精品| 国外成人在线视频网站| 一区二区高清在线观看| 久久久99精品免费观看不卡| 欧美日韩不卡一区| 国产综合亚洲精品一区二| 一本色道久久99精品综合| 久久精品一区二区三区中文字幕| 欧美连裤袜在线视频| 国产亚洲欧美激情| 一区二区日韩精品| 裸体丰满少妇做受久久99精品| 国产精品h在线观看| 亚洲精品1区| 久久精品亚洲| 国产精品家庭影院| 亚洲精品视频啊美女在线直播| 久久精品国产一区二区三| 欧美午夜在线一二页| 亚洲国产欧美日韩| 久久精品久久综合| 国产精品你懂的在线| 亚洲精品系列| 麻豆成人在线| 国产一区二区三区网站| 亚洲欧美高清| 欧美日韩精品一本二本三本| 亚洲二区在线观看| 久久精品三级| 国产欧美一区二区三区另类精品| 一区二区欧美日韩视频| 蜜桃av一区二区| 国产一区二区三区在线观看免费视频 | 国产欧美日韩一区二区三区| 99亚洲精品| 欧美不卡在线| 伊人色综合久久天天| 欧美一区二区精品久久911| 国产精品av久久久久久麻豆网| 亚洲麻豆国产自偷在线| 免费日韩一区二区| 极品裸体白嫩激情啪啪国产精品| 午夜日韩激情| 国产精品裸体一区二区三区| 一本色道久久综合亚洲二区三区 | 国产精品久久久久久久7电影| 9色国产精品| 欧美日韩国产精品自在自线| 最新热久久免费视频| 久久躁日日躁aaaaxxxx| 国产视频在线观看一区| 午夜视频精品| 国产欧美日韩综合一区在线播放| 亚洲一区二区精品视频| 国产精品久久久久高潮| 亚洲一级高清| 国产精品裸体一区二区三区| 亚洲视频在线二区| 国产精品久久久久91| 一区二区不卡在线视频 午夜欧美不卡'| 欧美激情区在线播放| 亚洲欧洲一级| 欧美激情在线免费观看| 亚洲黄一区二区三区| 欧美暴力喷水在线| 亚洲伦理精品| 欧美日韩极品在线观看一区| 一区二区日韩欧美| 国产精品高清在线观看| 亚洲欧美在线看| 国产日韩综合| 久久久一区二区三区| 亚洲大胆av| 欧美激情一区二区在线 | 欧美高潮视频| 亚洲美女色禁图| 欧美色图一区二区三区| 亚洲免费视频一区二区| 国产日韩欧美精品综合| 久久久亚洲精品一区二区三区| 精东粉嫩av免费一区二区三区| 裸体丰满少妇做受久久99精品| 亚洲精品一区在线| 欧美日韩视频不卡| 午夜精品久久久| 韩国视频理论视频久久| 欧美成人精品h版在线观看| 最新国产精品拍自在线播放| 欧美三级不卡| 欧美亚洲视频在线看网址| 精品成人国产在线观看男人呻吟| 欧美www视频| 在线一区二区三区做爰视频网站| 国产伦理精品不卡| 久久综合五月| 一本色道久久综合狠狠躁的推荐| 国产精品欧美日韩| 久久亚洲精品欧美| 一本色道久久| 韩国成人精品a∨在线观看| 欧美成人亚洲成人| 亚洲一线二线三线久久久| 国产一区香蕉久久| 欧美激情综合亚洲一二区| 亚洲午夜久久久久久久久电影网| 国产日韩欧美在线看| 美女啪啪无遮挡免费久久网站| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 99热免费精品| 国产一区二区三区观看| 欧美激情亚洲综合一区| 性做久久久久久久免费看| 亚洲国产精品成人久久综合一区| 欧美视频成人| 久久在线免费观看| 亚洲性感美女99在线| 在线精品国精品国产尤物884a| 欧美日韩亚洲91| 久久嫩草精品久久久久| 一区二区三区四区五区精品视频| 国产一区在线看| 欧美色另类天堂2015| 久久人人精品| 亚洲视频一区二区免费在线观看| 尤物yw午夜国产精品视频明星| 国产精品vvv| 欧美成人中文| 久久精品99| 亚洲性感激情| 亚洲毛片播放| 一区精品在线| 国产欧美日韩视频在线观看| 欧美日韩国产综合久久| 久久综合九色九九| 性欧美办公室18xxxxhd| 一二三区精品| 亚洲国产精品久久精品怡红院| 国产精品一区二区a| 欧美日本国产一区| 久久亚洲综合色| 欧美一级大片在线观看| 夜色激情一区二区| 亚洲国产99精品国自产| 国产一区二区久久精品| 国产精品久久久久aaaa| 欧美国产91| 久久男人资源视频| 欧美一区三区三区高中清蜜桃| 亚洲最新在线视频| 亚洲经典一区| 在线观看视频一区二区| 国产亚洲福利| 国产美女一区二区| 国产精品成人一区| 欧美日韩一区二区三区| 欧美va天堂在线| 另类亚洲自拍| 久久久久中文| 欧美在线啊v一区| 午夜精品久久久久久久99热浪潮 | 欧美视频在线一区二区三区| 欧美精品激情在线| 欧美大片免费观看| 可以免费看不卡的av网站| 久久狠狠婷婷| 欧美尤物巨大精品爽| 午夜免费日韩视频| 亚洲欧美国产精品va在线观看 | 久久亚洲欧美| 久久久水蜜桃| 久久久蜜桃精品| 久久久久久久国产| 欧美一级在线视频| 欧美一区2区三区4区公司二百| 亚洲女人天堂av| 亚洲欧美美女| 午夜一级在线看亚洲| 午夜久久久久久| 午夜天堂精品久久久久| 亚洲欧美日韩一区在线观看| 亚洲尤物影院| 午夜一区不卡| 欧美专区日韩视频| 久久精品网址| 久久综合久久88|