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

扒一扒Nacos、OpenFeign、Ribbon、loadbalancer組件協(xié)調工作的原理

開發(fā) 前端
Nacos、OpenFeign、Ribbon源碼剖析的文章,可以從公眾號后臺菜單欄中的文章分類中查看。

大家好,我是三友~~

前幾天有個大兄弟問了我一個問題,注冊中心要集成SpringCloud,想實現(xiàn)SpringCloud的負載均衡,需要實現(xiàn)哪些接口和規(guī)范。

圖片

既然這個兄弟問到我了,而我又剛好知道,這不得好好寫一篇文章來回答這個問題,雖然在后面的聊天中我已經回答過了。

接下來本文就來探究一下Nacos、OpenFeign、Ribbon、loadbalancer等組件協(xié)調工作的原理,知道這些原理之后,就知道應該需要是實現(xiàn)哪些接口了。

再多說一句,本文并沒有詳細地深入剖析各個組件的源碼,如果有感興趣的兄弟可以從公眾號后臺菜單欄中的文章分類中查看我之前寫的關于Nacos、OpenFeign、Ribbon源碼剖析的文章。

Nacos

先從Nacos講起。

Nacos是什么,官網中有這么一段話

圖片

這一段話說的直白點就是Nacos是一個注冊中心和配置中心!

在Nacos中有客戶端和服務端的這個概念

圖片

  • 服務端需要單獨部署,用來保存服務實例數(shù)據(jù)的
  • 客戶端就是用來跟服務端通信的SDK,支持不同語言

當需要向Nacos服務端注冊或者獲取服務實例數(shù)據(jù)的時候,只需要通過Nacos提供的客戶端SDK就可以了,就像下面這樣:

引入依賴

<dependency>
<groupId>com.alibaba.nacos</groupId>
<artifactId>nacos-client</artifactId>
<version>1.4.4</version>
</dependency>

示例代碼

Properties properties = new Properties();
properties.setProperty("serverAddr", "localhost");
properties.setProperty("namespace", "8848");

NamingService naming = NamingFactory.createNamingService(properties);

//服務注冊,注冊一個order服務,order服務的ip是192.168.2.100,端口8080
naming.registerInstance("order", "192.168.2.100", 8080);

//服務發(fā)現(xiàn),獲取所有的order服務實例
List<Instance> instanceList = naming.selectInstances("order", true);

當服務注冊到Nacos服務端的時候,在服務端內部會有一個集合去存儲服務的信息

圖片

這個集合在注冊中心界中有個響亮的名字,服務注冊表。

如何進行服務自動注冊?

用過SpringCloud的小伙伴肯定知道,在項目啟動的時候服務能夠自動注冊到服務注冊中心,并不需要手動寫上面那段代碼,那么服務自動注冊是如何實現(xiàn)的呢?

服務自動注冊三板斧

SpringCloud本身提供了一套服務自動注冊的機制,或者說是約束,其實就是三個接口,只要注冊中心實現(xiàn)這些接口,就能夠在服務啟動時自動注冊到注冊中心,而這三個接口我稱為服務自動注冊三板斧。

服務實例數(shù)據(jù)封裝--Registration

Registration是SpringCloud提供的一個接口,繼承了ServiceInstance接口

圖片

Registration

圖片

ServiceInstance

從ServiceInstance的接口定義可以看出,這是一個服務實例數(shù)據(jù)的封裝,比如這個服務的ip是多少,端口號是多少。

所以Registration就是當前服務實例數(shù)據(jù)封裝,封裝了當前服務的所在的機器ip和端口號等信息。

Nacos既然要整合SpringCloud,自然而然也實現(xiàn)了這個接口

圖片

NacosRegistration

這樣當前服務需要被注冊到注冊中心的信息就封裝好了。

服務注冊--ServiceRegistry

ServiceRegistry也是個接口,泛型就是上面提到的服務實例數(shù)據(jù)封裝的接口

圖片

ServiceRegistry

這個接口的作用就是把上面封裝的當前服務的數(shù)據(jù)Registration注冊通過register方法注冊到注冊中心中。

Nacos也實現(xiàn)了這個接口。

NacosServiceRegistry

并且核心的注冊方法的實現(xiàn)代碼跟前面的demo幾乎一樣

服務自動注冊--AutoServiceRegistration

AutoServiceRegistration

AutoServiceRegistration是一個標記接口,所以本身沒有實際的意義,僅僅代表了自動注冊的意思。

AutoServiceRegistration有個抽象實現(xiàn)AbstractAutoServiceRegistration

AbstractAutoServiceRegistration是個抽象類

AbstractAutoServiceRegistration實現(xiàn)了ApplicationListener,監(jiān)聽了WebServerInitializedEvent事件。

WebServerInitializedEvent這個事件是SpringBoot在項目啟動時,當諸如tomcat這類Web服務啟動之后就會發(fā)布,注意,只有在Web環(huán)境才會發(fā)布這個事件。

ServletWebServerInitializedEvent繼承自WebServerInitializedEvent。

所以一旦當SpringBoot項目啟動,tomcat等web服務器啟動成功之后,就會觸發(fā)AbstractAutoServiceRegistration監(jiān)聽器的執(zhí)行。

最終就會調用ServiceRegistry注冊Registration,實現(xiàn)服務自動注冊

Nacos自然而然也繼承了AbstractAutoServiceRegistration

NacosAutoServiceRegistration

對于Nacos而言,就將當前的服務注冊的ip和端口等信息,就注冊到了Nacos服務注冊中心。

所以整個注冊流程就可以用這么一張圖概括

當然,不僅僅是Nacos是這么實現(xiàn)的,常見的比如Eureka、Zookeeper等注冊中心在整合SpringCloud都是實現(xiàn)上面的三板斧。

Ribbon

講完了SpringCloud環(huán)境底下是如何自動注冊服務到注冊中心的,下面來講一講Ribbon。

我們都知道,Ribbon是負載均衡組件,他的作用就是從眾多的服務實例中根據(jù)一定的算法選擇一個服務實例。

但是有個疑問,服務實例的數(shù)據(jù)都在注冊中心,Ribbon是怎么知道的呢???

答案其實很簡單,那就是需要注冊中心去主動適配Ribbon,只要注冊中心去適配了Ribbon,那么Ribbon自然而然就知道服務實例的數(shù)據(jù)了。

Ribbon提供了一個獲取服務實例的接口,叫ServerList

ServerList

接口中提供了兩個方法,這兩個方法在眾多的實現(xiàn)中實際是一樣的,并沒有區(qū)別。

當Ribbon通過ServerList獲取到服務實例數(shù)據(jù)之后,會基于這些數(shù)據(jù)來做負載均衡的。

Nacos自然而然也實現(xiàn)了ServerList接口,為Ribbon提供Nacos注冊中心中的服務數(shù)據(jù)。

NacosServerList

這樣,Ribbon就能獲取到了Nacos服務注冊中心的數(shù)據(jù)。

同樣地,除了Nacos之外,Eureka、Zookeeper等注冊中心也都實現(xiàn)了這個接口。

到這,其實就明白了Ribbon是如何知道注冊中心的數(shù)據(jù)了,需要注冊中心來適配。

在這里插個個人的看法,其實我覺得Ribbon在適配SpringCloud時對獲取服務實例這塊支持封裝的不太好。

因為SpringCloud本身就是一套約束、規(guī)范,只要遵守這套規(guī)范,那么就可以實現(xiàn)各個組件的替換,這就是為什么換個注冊中心只需要換個依賴,改個配置文件就行。

而Ribbon本身是一個具體的負載均衡組件,注冊中心要想整合SpringCloud,還得需要單獨去適配Ribbon,有點違背了SpringCloud約束的意義。

就類似mybatis一樣,mybatis依靠jdbc,但是mybatis根本不關心哪個數(shù)據(jù)庫實現(xiàn)的jdbc。

真正好的做法是Ribbon去適配SpringCloud時,用SpringCloud提供的api去獲取服務實例,這樣不同的注冊中心只需要適配這個api,無需單獨適配Ribbon了。

而SpringCloud實際上是提供了這么一個獲取服務實例的api,DiscoveryClient

DiscoveryClient

通過DiscoveryClient就能夠獲取到服務實例,當然也是需要不同注冊中心的適配。

隨著Ribbon等組件停止維護之后,SpringCloud官方自己也搞了一個負載均衡組件loadbalancer,用來平替Ribbon。

<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-loadbalancer</artifactId>
<version>2.2.5.RELEASE</version>
</dependency>

這個組件底層在獲取服務實例的時候,就是使用的DiscoveryClient。

所以對于loadbalancer?這個負載均衡組價來說,注冊中心只需要實現(xiàn)DiscoveryClient之后就自然而然適配了loadbalancer。

OpenFeign

OpenFeign是一個rpc框架,當我們需要調用遠程服務的時候,只需要聲明個接口就可以遠程調用了,就像下面這樣

聽上去很神奇,其實本質上就是后面會為接口創(chuàng)建一個動態(tài)代理對象,解析類上,方法上的注解。

當調用方法的時候,會根據(jù)方法上面的參數(shù)拼接一個http請求地址,這個地址的格式是這樣的http://服務名/接口路徑。

比如,上面的例子,當調用saveOrder?方法的時候,按照這種規(guī)律拼出的地址就是這樣的 http://order/order,第一個order是服務名,第二個order是PostMapping注解上面的。

但是由于只知道需要調用服務的服務名,不知道服務的ip和端口,還是無法調用遠程服務,這咋辦呢?

這時就輪到Ribbon登場了,因為Ribbon這個大兄弟知道服務實例的數(shù)據(jù)。

于是乎,OpenFeign就對Ribbon說,兄弟,你不是可以從注冊中心獲取到order服務所有服務實例數(shù)據(jù)么,幫我從這些服務實例數(shù)據(jù)中找一個給我。

圖片

于是Ribbon就會從注冊中心獲取到的服務實例中根據(jù)負載均衡策略選擇一個服務實例返回給OpenFeign。

OpenFeign拿到了服務實例,此時就獲取到了服務所在的ip和端口,接下來就會重新構建請求路徑,將路徑中的服務名替換成ip和端口,代碼如下:

圖片

reconstructURIWithServer

  • Server就是服務實例信息的封裝
  • orignal就是原始的url,就是上面提到的,http://order/order

假設獲取到的orde服務所在的ip和端口分別是192.168.2.100和8080?,最終重構后的路徑就是http://192.168.2.100:8080/order,之后OpenFeign就可以發(fā)送http請求了。

至于前面提到的loadbalancer,其實也是一樣的,他也會根據(jù)負載均衡算法,從DiscoveryClient獲取到的服務實例中選擇一個服務實例給OpenFeign,后面也會根據(jù)服務實例重構url,再發(fā)送http請求。

圖片

loadbalancer組件重構url代碼

總結

到這,就把Nacos、OpenFeign、Ribbon、loadbalancer等組件協(xié)調工作的原理講完了,其實就是各個組件會預留一些擴展接口,這也是很多開源框架都會干的事,當?shù)谌娇蚣苋ミm配的,只要實現(xiàn)這些接口就可以了。

最后畫一張圖來總結一下上述組價的工作的原理。

圖片

最后再小小地說一句,Nacos、OpenFeign、Ribbon源碼剖析的文章,可以從公眾號后臺菜單欄中的文章分類中查看。

責任編輯:武曉燕 來源: 三友的java日記
相關推薦

2022-07-11 20:46:39

AQSJava

2025-06-04 01:20:00

2019-10-21 10:59:52

編程語言JavaC

2019-09-10 07:29:44

2023-01-30 22:10:12

BeanSpring容器

2018-04-03 15:42:40

2019-02-25 22:46:39

2020-01-15 15:29:52

InnoDB數(shù)據(jù)硬盤

2015-10-15 13:38:39

2015-08-18 09:12:54

app推廣渠道

2015-09-16 14:04:06

大數(shù)據(jù)巨頭

2015-09-21 10:07:31

2019-01-03 11:09:19

2015-09-16 14:11:47

2024-12-04 13:54:19

pnpm存儲項目

2022-09-30 09:40:39

智能汽車

2017-09-07 18:45:51

C#

2025-04-30 07:26:04

2015-12-15 09:51:42

大公司技術知乎

2021-05-13 05:25:16

數(shù)據(jù)分析數(shù)分培訓大數(shù)據(jù)
點贊
收藏

51CTO技術棧公眾號

中文字幕日韩三级| 激情五月俺来也| 亚洲精品一级片| 中文亚洲字幕| 国产亚洲精品激情久久| 人人干人人视频| 欧美成人hd| 丰满亚洲少妇av| 欧洲美女7788成人免费视频| xxxx日本黄色| 另类视频一区二区三区| 亚洲va韩国va欧美va精品| 欧美mv日韩mv国产网站app| 国产女教师bbwbbwbbw| 天天操天天干天天干| 免费日本视频一区| 欧美日韩成人在线观看| 成人午夜福利一区二区| 国产亚洲亚洲国产一二区| 天天综合天天做天天综合| 天天综合色天天综合色hd| www.日本在线观看| 日本不卡123| 欧美高清第一页| 黄色片网站免费| 国产精品网址| 日韩一卡二卡三卡| 天堂在线资源视频| xxx性欧美| 1区2区3区精品视频| 精品国产中文字幕| 国产黄色av网站| 男男成人高潮片免费网站| 韩国三级日本三级少妇99| 成人涩涩小片视频日本| 精品国产一区二区三区小蝌蚪 | 不卡的看片网站| 国产精品一区二区久久久| 国产又大又黄视频| 合欧美一区二区三区| 色婷婷综合久久久久| 中文字幕一区二区久久人妻网站| 日韩精品一区国产| 欧美欧美欧美欧美首页| 免费激情视频在线观看| 天天综合av| 亚洲不卡av一区二区三区| 亚洲av综合色区| 免费在线午夜视频| 国产视频视频一区| 国产一区二区不卡视频| 国产特级aaaaaa大片| 日韩精品午夜视频| 4k岛国日韩精品**专区| 性欧美丰满熟妇xxxx性仙踪林| 中文字幕日韩亚洲| 欧美中文字幕一区二区三区 | 欧美成人日本| 最新日韩中文字幕| 88av在线播放| 国产激情在线观看| 欧美激情一区三区| 欧洲亚洲一区| 日本福利片高清在线观看| 国产不卡一区视频| 91在线观看免费高清| 久久久久久久久久一级| 免费日韩视频| 45www国产精品网站| 久久精品国产亚洲av麻豆色欲| 91精品一区国产高清在线gif | 欧美日韩一区在线观看| 日韩一级在线免费观看| 亚洲电影观看| 黄网站色欧美视频| 加勒比成人在线| 不卡的av影片| 午夜精品久久久久久久99水蜜桃| 黄色一级片在线看| 欧美亚洲日本精品| 一本色道久久综合亚洲aⅴ蜜桃| 国产精品无码av在线播放| 女厕盗摄一区二区三区| 日韩欧美在线看| 毛片av免费在线观看| 麻豆精品蜜桃| 欧美久久久一区| 手机在线观看日韩av| 一区二区在线免费播放| 在线播放日韩导航| 99国产精品免费视频| 波多野结衣欧美| 亚洲黄页网在线观看| 国产精品边吃奶边做爽| 亚洲色图丝袜| 中文字幕日韩在线观看| 四虎影院中文字幕| 欧美日韩免费观看一区=区三区| 欧美国产日本高清在线 | 国产免费人做人爱午夜视频| 日本欧美韩国| 91精品国产综合久久精品| 最新中文字幕日本| 动漫av一区| 亚洲国产91色在线| 免费黄色片网站| 欧美成人精品| 欧美在线一级视频| 在线观看免费观看在线| 国产精品一品二品| 久久国产精品亚洲va麻豆| 国产精品久久一区二区三区不卡| 中文字幕一区在线观看视频| 成人一级生活片| 国产精品高清乱码在线观看| 5566中文字幕一区二区电影| 中国免费黄色片| 亚洲区小说区| 久久久精品2019中文字幕神马| 日韩久久久久久久久| 美女www一区二区| 国产精品国产亚洲精品看不卡15| 欧美成人免费| 亚洲综合一区二区| 日本激情视频在线| 国产精品午夜av| 精品国产网站地址| 成人免费看片98欧美| 国产尤物一区二区| 日本在线免费观看一区| 美足av综合网| 欧美精品 国产精品| 四虎精品一区二区| 先锋资源久久| 国产成人综合亚洲| 五月婷婷在线观看视频| 自拍偷在线精品自拍偷无码专区| 日韩少妇内射免费播放18禁裸乳| 精品国产伦一区二区三区观看说明| 亚洲国产精品大全| 亚洲国产美女视频| 天堂va蜜桃一区二区三区| 国产伦精品一区二区三区照片| 免费观看久久久久| 日本道在线观看一区二区| 香港三日本8a三级少妇三级99| 97色伦图片97综合影院| 国产精品99导航| 香港一级纯黄大片| 亚洲国产精品欧美一二99| 亚洲午夜激情影院| 日韩综合一区| 国产成人拍精品视频午夜网站| 亚洲xxx在线| 一区二区在线观看视频| 亚洲一区日韩精品| 日本大胆欧美| 国产精品91免费在线| 午夜一区在线观看| 欧美日韩国产中文字幕| 污污免费在线观看| 亚洲性感美女99在线| av一区和二区| 中文字幕资源网在线观看| 欧美日韩国产精品成人| 天堂а√在线中文在线鲁大师| 日韩精品免费专区| 欧美视频小说| 奇米777日韩| 亚洲欧美在线一区二区| 亚洲天堂av片| 久久久久9999亚洲精品| 午夜精品久久久久久久无码| 国产在线播放精品| 欧美疯狂性受xxxxx另类| 国产人妻精品一区二区三| 亚洲女爱视频在线| 少妇熟女视频一区二区三区 | 风间由美中文字幕在线看视频国产欧美| 久久精品一区中文字幕| 国产精品一品二区三区的使用体验| 国产精品久久久久三级| 中文字幕在线视频一区二区三区| 久久久久久久久久久9不雅视频 | 亚洲一二三区视频| 午夜精品久久久99热福利| 亚洲欧美丝袜中文综合| 色婷婷精品久久二区二区蜜臀av| 亚欧洲乱码视频| 免费成人你懂的| 欧美精品一区二区性色a+v| 精品国产亚洲一区二区三区大结局| 美女av一区二区| 少妇人妻精品一区二区三区| 欧美日韩亚洲视频| 国产免费嫩草影院| 国产不卡免费视频| 国产极品尤物在线| 日韩成人激情| 91久久嫩草影院一区二区| 秋霞在线午夜| 亚洲欧美成人一区二区在线电影| 亚洲欧美一二三区| 亚洲欧美另类小说视频| 影音先锋黄色资源| 亚洲作爱视频| 一本久道久久综合| 都市激情久久| 国产精品日本精品| 丁香高清在线观看完整电影视频| 亚洲精品一区二区三区精华液| 日本一级淫片色费放| 国产精品久久久久久久久免费樱桃 | 欧美日韩国产精品一区二区三区四区 | 久久无码精品丰满人妻| 国产亚洲女人久久久久毛片| 午夜免费视频网站| 久久综合九色综合欧美狠狠| 影音先锋成人资源网站| 在线成人动漫av| 亚洲综合成人婷婷小说| 男人皇宫亚洲男人2020| 久久精品视频亚洲| 欧美zzoo| 亚洲爱爱爱爱爱| 一级特黄特色的免费大片视频| 亚洲福利视频一区| 91大神福利视频| 99久久综合国产精品| 国产又大又黄又粗又爽| 99精品久久| 日韩欧美视频免费在线观看| 精品国产乱码久久久久久果冻传媒 | 91精品视频观看| 欧美极品免费| 97精品视频在线播放| caopo在线| 色哟哟入口国产精品| 色视频在线看| 日韩欧美自拍偷拍| 波多野结衣电车| 福利微拍一区二区| 久久久久人妻一区精品色欧美| 国产精品欧美一区喷水| 新91视频在线观看| 99久久精品国产精品久久| 亚洲精品国产久| 理论电影国产精品| 四季av一区二区| 久久综合亚州| 国产裸体免费无遮挡| 欧美亚洲视频| 日韩在线一级片| 影音先锋亚洲精品| 久久精品无码中文字幕| 午夜久久福利| 看一级黄色录像| 国产精品x453.com| 在线精品日韩| 欧美日韩一二| 日韩午夜视频在线观看| 少妇一区二区视频| 日本a级片久久久| 一区二区三区日本久久久| 国产精品一区二区三区四区五区| 蜜桃精品视频| 91一区二区三区| 久久久久亚洲精品中文字幕| 国产日韩欧美视频| 电影中文字幕一区二区| 亚洲一区二区免费| 日韩精品一区二区三区免费视频| 国产成人小视频在线观看| 午夜不卡一区| 91丨九色丨国产在线| 久久一级大片| 99re6在线| 国产精品久av福利在线观看| 国精产品一区二区| 亚洲小说图片视频| 深夜福利成人| 亚洲国产精品久久久天堂| 欧美做受777cos| 国产精品大片| 成人在线免费在线观看| 美女精品网站| mm131国产精品| 国产精品原创巨作av| 国产一精品一aⅴ一免费| a级高清视频欧美日韩| 韩国无码一区二区三区精品| 亚洲欧美综合在线精品| 精品国产乱码久久久久久鸭王1| 亚洲图片欧美一区| 中文字幕在线欧美| 欧美日韩国产综合视频在线观看 | 欧美日韩午夜剧场| 亚洲欧美另类在线视频| 91精品国产综合久久福利| 日本xxxxwww| 国产午夜精品视频| av在线影院| 欧美亚洲另类激情另类| 成人在线不卡| 国产伦精品一区二区三区免费视频| 亚洲精品456| 亚洲一区二区在| 亚洲高清资源| 热久久精品国产| 国产伦精品一区二区三区免费迷| 亚洲av成人精品一区二区三区| 久久色成人在线| 久久久久久久久久网站| 欧美午夜无遮挡| 中文字幕在线观看你懂的| 精品乱人伦小说| av在线资源站| 97国产一区二区精品久久呦| 福利一区视频| 久久精品国产精品国产精品污| 日韩av有码| 国产精品丝袜久久久久久消防器材| 日韩电影在线免费看| 超碰人人cao| 国产无人区一区二区三区| 激情综合五月网| 91福利国产精品| 亚洲第一色网站| 最近2019中文字幕第三页视频 | 欧美综合一区第一页| 爱情电影网av一区二区| 欧美精品在线一区| 欧美+日本+国产+在线a∨观看| 国产精品免费成人| www..com久久爱| 欧美成人免费看| 欧美精品一二三| 黄色在线免费观看大全| 91国产精品电影| 噜噜噜天天躁狠狠躁夜夜精品| 制服丝袜综合日韩欧美| 日韩精品高清不卡| theav精尽人亡av| 亚洲国产一区二区a毛片| 国产精品无码专区av免费播放| 在线亚洲国产精品网| av在线最新| 国产主播一区二区三区四区| 欧美精品二区| 天天操精品视频| 亚洲欧美日韩国产综合| 亚洲无码精品在线播放| 在线看日韩欧美| 亚洲精品永久免费视频| 精品国产福利| 亚洲精选在线| 少妇一级淫片免费放播放| 亚洲狠狠爱一区二区三区| 黄色片一区二区三区| 欧美国产第一页| 成人av色网站| 亚洲精品偷拍视频| 国产精品一区二区三区99| 日韩a级片在线观看 | 亚洲国产精品一| 欧美久久精品午夜青青大伊人| 你懂得影院夜精品a| 久久精品第九区免费观看 | 欧美性猛交bbbbb精品| 精品无人区太爽高潮在线播放| 日韩脚交footjobhd| 久久久久久久久四区三区| 亚洲免费大片| 精品无码一区二区三区| 日本久久一区二区| 一区二区三区视频在线观看视频| 国产精品色悠悠| 亚洲人成免费网站| 女同性αv亚洲女同志| 亚洲一区二区三区四区中文字幕| 成人午夜免费在线观看| 97视频人免费观看| 啪啪亚洲精品| www.污污视频| 亚洲一区二区三区四区五区黄| 日韩一区二区三区在线观看视频| 538国产精品视频一区二区| 欧美理论电影大全| 亚洲三级在线观看视频| 亚洲精品美腿丝袜| 天天色综合av| 国产精品吹潮在线观看| 91综合在线| 交换做爰国语对白| 欧美日韩在线影院| 91精品国产91久久久久游泳池| 成人精品视频在线| 99视频在线精品国自产拍免费观看| 国产精品无码午夜福利| 色婷婷av一区|