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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Dubbo 一篇文章就够了:从入门到实战

發布時間:2024/2/28 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Dubbo 一篇文章就够了:从入门到实战 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一 為什么需要 dubbo

很多時候,其實我們使用這個技術的時候,可能都是因為項目需要,所以,我們就用了,但是,至于為什么我們需要用到這個技術,可能自身并不是很了解的,但是,其實了解技術的來由及背景知識,對于理解一項技術還是有幫助的,那么,dubbo是怎么被提上日程的呢?

在互聯網的發展過程中,在以前,我們只需要一個服務器,將程序全部打包好就可以,但是,隨著流量的增大,常規的垂直應用架構已無法應對,所以,架構就發生了演變。

1 單一應用架構

2 應用和數據庫單獨部署

3 應用和數據庫集群部署

4 數據庫壓力變大,讀寫分離

5 使用緩存技術加快速度

6 數據庫分庫分表

7 應用分為不同的類型拆分

發展到這個階段的時候,我們發現,應用與應用之間的關系已經十分的復雜了,就會出現以下幾個問題(以下摘錄于官網):

① 當服務越來越多時,服務 URL 配置管理變得非常困難,F5 硬件負載均衡器的單點壓力也越來越大。
② 當進一步發展,服務間依賴關系變得錯蹤復雜,甚至分不清哪個應用要在哪個應用之前啟動,架構師都不能完整的描述應用的架構關系。
③ 接著,服務的調用量越來越大,服務的容量問題就暴露出來,這個服務需要多少機器支撐?什么時候該加機器?

為了解決這由于架構的演變所產生的問題幾個問題,于是,dubbo 產生了。當然,解決這個問題的技術不止 dubbo 。

從上面 Dubbo 的服務治理圖我們就可以看到,Duboo 很好了解決了上面所出現的一些問題。

所以,當你的系統架構發展到了這種階段的時候,就需要考慮使用 Dubbo 了。

二 Dubbo 技術架構

我們已經非常清楚的知道為什么在我們的系統中需要 Dubbo 這項技術了,下面,我們接著嘮叨嘮叨 Dubbo 的架構。

首先,上一張圖(摘自官網)。

看到圖之后,可能你對上面的幾個概念還是一臉懵逼,無從下手,下面,帶你看看這幾個角色到底是什么意思?

節點角色說明

節點角色說明
Provider暴露服務的服務提供方
Consumer調用遠程服務的服務消費方
Registry服務注冊與發現的注冊中心
Monitor統計服務的調用次數和調用時間的監控中心
Container服務運行容器

看了這幾個概念后似乎發現,其實 Dubbo 的架構也是很簡單的(其實現細節是復雜的),為什么這么說呢,有沒有發現,其實很像生產者-消費者模型。只是在這種模型上,加上了注冊中心和監控中心,用于管理提供方提供的url,以及管理整個過程。

那么,整個發布-訂閱的過程就非常的簡單了。

  • 啟動容器,加載,運行服務提供者。
  • 服務提供者在啟動時,在注冊中心發布注冊自己提供的服務。
  • 服務消費者在啟動時,在注冊中心訂閱自己所需的服務。

如果考慮失敗或變更的情況,就需要考慮下面的過程。

  • 注冊中心返回服務提供者地址列表給消費者,如果有變更,注冊中心將基于長連接推送變更數據給消費者。
  • 服務消費者,從提供者地址列表中,基于軟負載均衡算法,選一臺提供者進行調用,如果調用失敗,再選另一臺調用。
  • 服務消費者和提供者,在內存中累計調用次數和調用時間,定時每分鐘發送一次統計數據到監控中心。

通過這番講解,我相信 Dubbo 的架構我們也輕車熟路了,那就直接入手,開車吧。

三 Dubbo 開始入門

終于走到這一步了,寫到這里停了大概一周的時間,主要原因還是最近項目太忙,趕著交差呢,今天希望能一鼓作氣,完完整整的寫完 dubbo 的基礎篇!

3.1 服務端

首先,我們先把服務端的接口寫好,因為其實 dubbo 的作用簡單來說就是給消費端提供接口。

接口定義

/*** xml方式服務提供者接口*/ public interface ProviderService {String SayHello(String word); }

這個接口非常簡單,只是包含一個 SayHello 的方法。

接著,定義它的實現類。

/*** xml方式服務提供者實現類*/ public class ProviderServiceImpl implements ProviderService{public String SayHello(String word) {return word;} }

這樣我們就把我們的接口寫好了,那么我們應該怎么將我們的服務暴露出去呢?

導入 maven 依賴

<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.ouyangsihai</groupId><artifactId>dubbo-provider</artifactId><version>1.0-SNAPSHOT</version><dependencies><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>3.8.1</version><scope>test</scope></dependency><!-- https://mvnrepository.com/artifact/com.alibaba/dubbo --><dependency><groupId>com.alibaba</groupId><artifactId>dubbo</artifactId><version>2.6.6</version></dependency><dependency><groupId>org.apache.zookeeper</groupId><artifactId>zookeeper</artifactId><version>3.4.10</version></dependency><dependency><groupId>com.101tec</groupId><artifactId>zkclient</artifactId><version>0.5</version></dependency><dependency><groupId>io.netty</groupId><artifactId>netty-all</artifactId><version>4.1.32.Final</version></dependency><dependency><groupId>org.apache.curator</groupId><artifactId>curator-framework</artifactId><version>2.8.0</version></dependency><dependency><groupId>org.apache.curator</groupId><artifactId>curator-recipes</artifactId><version>2.8.0</version></dependency></dependencies> </project>

這里使用的 dubbo 的版本是?2.6.6?,需要注意的是,如果你只導入 dubbo 的包的時候是會報錯的,找不到 netty 和 curator 的依賴,所以,在這里我們需要把這兩個的依賴加上,就不會報錯了。

另外,這里我們使用 zookeeper 作為注冊中心。

到目前為止,dubbo 需要的環境就已經可以了,下面,我們就把上面剛剛定義的接口暴露出去。

暴露接口(xml 配置方法)

首先,我們在我們項目的 resource 目錄下創建 META-INF.spring 包,然后再創建?provider.xml?文件,名字可以任取哦,如下圖。

<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd"><!--當前項目在整個分布式架構里面的唯一名稱,計算依賴關系的標簽--><dubbo:application name="provider" owner="sihai"><dubbo:parameter key="qos.enable" value="true"/><dubbo:parameter key="qos.accept.foreign.ip" value="false"/><dubbo:parameter key="qos.port" value="55555"/></dubbo:application><dubbo:monitor protocol="registry"/><!--dubbo這個服務所要暴露的服務地址所對應的注冊中心--><!--<dubbo:registry address="N/A"/>--><dubbo:registry address="N/A" /><!--當前服務發布所依賴的協議;webserovice、Thrift、Hessain、http--><dubbo:protocol name="dubbo" port="20880"/><!--服務發布的配置,需要暴露的服務接口--><dubbo:serviceinterface="com.sihai.dubbo.provider.service.ProviderService"ref="providerService"/><!--Bean bean定義--><bean id="providerService" class="com.sihai.dubbo.provider.service.ProviderServiceImpl"/></beans>

① 上面的文件其實就是類似 spring 的配置文件,而且,dubbo 底層就是 spring。
②?節點:dubbo:application
就是整個項目在分布式架構中的唯一名稱,可以在?name?屬性中配置,另外還可以配置?owner?字段,表示屬于誰。
下面的參數是可以不配置的,這里配置是因為出現了端口的沖突,所以配置。
③?節點:dubbo:monitor
監控中心配置, 用于配置連接監控中心相關信息,可以不配置,不是必須的參數。
④?節點:dubbo:registry
配置注冊中心的信息,比如,這里我們可以配置 zookeeper 作為我們的注冊中心。address?是注冊中心的地址,這里我們配置的是?N/A?表示由 dubbo 自動分配地址。或者說是一種直連的方式,不通過注冊中心。
⑤?節點:dubbo:protocol
服務發布的時候 dubbo 依賴什么協議,可以配置 dubbo、webserovice、Thrift、Hessain、http等協議。
⑥?節點:dubbo:service
這個節點就是我們的重點了,當我們服務發布的時候,我們就是通過這個配置將我們的服務發布出去的。interface?是接口的包路徑,ref?是第 ⑦ 點配置的接口的 bean。
⑦ 最后,我們需要像配置 spring 的接口一樣,配置接口的 bean。

到這一步,關于服務端的配置就完成了,下面我們通過?main 方法將接口發布出去。

發布接口

package com.sihai.dubbo.provider;import com.alibaba.dubbo.config.ApplicationConfig; import com.alibaba.dubbo.config.ProtocolConfig; import com.alibaba.dubbo.config.RegistryConfig; import com.alibaba.dubbo.config.ServiceConfig; import com.alibaba.dubbo.container.Main; import com.sihai.dubbo.provider.service.ProviderService; import com.sihai.dubbo.provider.service.ProviderServiceImpl; import org.springframework.context.support.ClassPathXmlApplicationContext;import java.io.IOException;/*** xml方式啟動**/ public class App {public static void main( String[] args ) throws IOException {//加載xml配置文件啟動ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("META-INF/spring/provider.xml");context.start();System.in.read(); // 按任意鍵退出} }

發布接口非常簡單,因為 dubbo 底層就是依賴 spring 的,所以,我們只需要通過?ClassPathXmlApplicationContext?拿到我們剛剛配置好的 xml ,然后調用?context.start()?方法就啟動了。

看到下面的截圖,就算是啟動成功了,接口也就發布出去了。

你以為到這里就結束了了,并不是的,我們拿到?dubbo 暴露出去的 url分析分析。

dubbo 暴露的 url

dubbo://192.168.234.1:20880/com.sihai.dubbo.provider.service.ProviderService?anyhost=true&application=provider&bean.name=com.sihai.dubbo.provider.service.ProviderService&bind.ip=192.168.234.1&bind.port=20880&dubbo=2.0.2&generic=false&interface=com.sihai.dubbo.provider.service.ProviderService&methods=SayHello&owner=sihai&pid=8412&qos.accept.foreign.ip=false&qos.enable=true&qos.port=55555&side=provider&timestamp=1562077289380

分析

① 首先,在形式上我們發現,其實這么牛逼的 dubbo 也是用類似于 http 的協議發布自己的服務的,只是這里我們用的是?dubbo 協議。
②?dubbo://192.168.234.1:20880/com.sihai.dubbo.provider.service.ProviderService
上面這段鏈接就是???之前的鏈接,構成:協議://ip:端口/接口。發現是不是也沒有什么神秘的。
③?anyhost=true&application=provider&bean.name=com.sihai.dubbo.provider.service.ProviderService&bind.ip=192.168.234.1&bind.port=20880&dubbo=2.0.2&generic=false&interface=com.sihai.dubbo.provider.service.ProviderService&methods=SayHello&owner=sihai&pid=8412&qos.accept.foreign.ip=false&qos.enable=true&qos.port=55555&side=provider&timestamp=1562077289380
??之后的字符串,分析后你發現,這些都是剛剛在?provider.xml?中配置的字段,然后通過?&?拼接而成的,聞到了?http的香味了嗎?

終于,dubbo 服務端入門了。下面我們看看拿到了 url 后,怎么消費呢?

3.2 消費端

上面提到,我們在服務端提供的只是點對點的方式提供服務,并沒有使用注冊中心,所以,下面的配置也是會有一些不一樣的。

消費端環境配置

首先,我們在消費端的 resource 下建立配置文件?consumer.xml。

<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd"><!--當前項目在整個分布式架構里面的唯一名稱,計算依賴關系的標簽--><dubbo:application name="consumer" owner="sihai"/><!--dubbo這個服務所要暴露的服務地址所對應的注冊中心--><!--點對點的方式--><dubbo:registry address="N/A" /><!--<dubbo:registry address="zookeeper://localhost:2181" check="false"/>--><!--生成一個遠程服務的調用代理--><!--點對點方式--><dubbo:reference id="providerService"interface="com.sihai.dubbo.provider.service.ProviderService"url="dubbo://192.168.234.1:20880/com.sihai.dubbo.provider.service.ProviderService"/><!--<dubbo:reference id="providerService"interface="com.sihai.dubbo.provider.service.ProviderService"/>--></beans>

分析

① 發現這里的?dubbo:application?和?dubbo:registry?是一致的。
②?dubbo:reference?:我們這里采用點對點的方式,所以,需要配置在服務端暴露的 url 。

maven 依賴

和服務端一樣

<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.ouyangsihai</groupId><artifactId>dubbo-consumer</artifactId><version>1.0-SNAPSHOT</version><dependencies><dependency><groupId>com.ouyangsihai</groupId><artifactId>dubbo-provider</artifactId><version>1.0-SNAPSHOT</version></dependency><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>3.8.1</version><scope>test</scope></dependency><!-- https://mvnrepository.com/artifact/com.alibaba/dubbo --><dependency><groupId>com.alibaba</groupId><artifactId>dubbo</artifactId><version>2.6.6</version></dependency><dependency><groupId>org.apache.zookeeper</groupId><artifactId>zookeeper</artifactId><version>3.4.10</version></dependency><dependency><groupId>com.101tec</groupId><artifactId>zkclient</artifactId><version>0.5</version></dependency><dependency><groupId>io.netty</groupId><artifactId>netty-all</artifactId><version>4.1.32.Final</version></dependency><dependency><groupId>org.apache.curator</groupId><artifactId>curator-framework</artifactId><version>2.8.0</version></dependency><dependency><groupId>org.apache.curator</groupId><artifactId>curator-recipes</artifactId><version>2.8.0</version></dependency></dependencies> </project>

調用服務

package com.sihai.dubbo.consumer;import com.alibaba.dubbo.config.ApplicationConfig; import com.alibaba.dubbo.config.ReferenceConfig; import com.alibaba.dubbo.config.RegistryConfig; import com.sihai.dubbo.provider.service.ProviderService; import org.springframework.context.support.ClassPathXmlApplicationContext;import java.io.IOException;/*** xml的方式調用**/ public class App {public static void main( String[] args ) throws IOException {ClassPathXmlApplicationContext context=new ClassPathXmlApplicationContext("consumer.xml");context.start();ProviderService providerService = (ProviderService) context.getBean("providerService");String str = providerService.SayHello("hello");System.out.println(str);System.in.read();} }

這里和服務端的發布如出一轍。


如此,我們就成功調用接口了。

四 加入 zookeeper 作為注冊中心

在前面的案例中,我們沒有使用任何的注冊中心,而是用一種直連的方式進行的。但是,實際上很多時候,我們都是使用 dubbo + zookeeper 的方式,使用 zookeeper 作為注冊中心,這里,我們就介紹一下 zookeeper 作為注冊中心的使用方法。

這里,我們在前面的入門實例中進行改造。

4.1 服務端

在服務端中,我們只需要修改 provider.xml 即可。

<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd"><!--當前項目在整個分布式架構里面的唯一名稱,計算依賴關系的標簽--><dubbo:application name="provider" owner="sihai"><dubbo:parameter key="qos.enable" value="true"/><dubbo:parameter key="qos.accept.foreign.ip" value="false"/><dubbo:parameter key="qos.port" value="55555"/></dubbo:application><dubbo:monitor protocol="registry"/><!--dubbo這個服務所要暴露的服務地址所對應的注冊中心--><!--<dubbo:registry address="N/A"/>--><dubbo:registry address="zookeeper://localhost:2181" check="false"/><!--當前服務發布所依賴的協議;webserovice、Thrift、Hessain、http--><dubbo:protocol name="dubbo" port="20880"/><!--服務發布的配置,需要暴露的服務接口--><dubbo:serviceinterface="com.sihai.dubbo.provider.service.ProviderService"ref="providerService"/><!--Bean bean定義--><bean id="providerService" class="com.sihai.dubbo.provider.service.ProviderServiceImpl"/></beans>

重點關注這句話

<dubbo:registry address="zookeeper://localhost:2181"?/>

在 address 中,使用我們的 zookeeper 的地址。

如果是?zookeeper 集群的話,使用下面的方式。

<dubbo:registry protocol="zookeeper"address="192.168.11.129:2181,192.168.11.137:2181,192.168.11.138:2181"/>

服務端的配置就好了,其他的跟?入門案例?一樣。

4.2 消費端

跟服務端一樣,在消費端,我們也只需要修改?consumer.xml?即可。

<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd"><!--當前項目在整個分布式架構里面的唯一名稱,計算依賴關系的標簽--><dubbo:application name="consumer" owner="sihai"/><!--dubbo這個服務所要暴露的服務地址所對應的注冊中心--><!--點對點的方式--><!--<dubbo:registry address="N/A" />--><dubbo:registry address="zookeeper://localhost:2181" check="false"/><!--生成一個遠程服務的調用代理--><!--點對點方式--><!--<dubbo:reference id="providerService"interface="com.sihai.dubbo.provider.service.ProviderService"url="dubbo://192.168.234.1:20880/com.sihai.dubbo.provider.service.ProviderService"/>--><dubbo:reference id="providerService"interface="com.sihai.dubbo.provider.service.ProviderService"/></beans>

① 注冊中心配置跟服務端一樣。

<dubbo:registry address="zookeeper://localhost:2181"/>

② dubbo:reference
由于我們這里使用 zookeeper 作為注冊中心,所以,跟點對點的方式是不一樣的,這里不再需要 dubbo 服務端提供的 url 了,只需要直接引用服務端提供的接口即可。

<dubbo:reference id="providerService"interface="com.sihai.dubbo.provider.service.ProviderService"/>

好了,消費端也配置好了,這樣就可以使用修改的入門案例,重新啟動運行了。

同樣成功了。

這時候的區別在于,將 dubbo 發布的 url 注冊到了 zookeeper,消費端從 zookeeper 消費,zookeeper 相當于一個中介,給消費者提供服務。

你以為這就完了?不,好戲才剛剛開始呢。

五 多種配置方式

入門實例的時候,我們使用的是?xml 配置的方式,對 dubbo 的環境進行了配置,但是,官方還提供了其他的配置方式,這里我們也一一分解。

5.1 API配置方式

這種方式其實官方是不太推薦的,官方推薦使用 xml 配置的方式,但是,在有的時候測試的時候,還是可以用的到的,另外,為了保證完整性,這些內容還是有必要講講的。

首先還是回到服務端工程。

服務端

這里我們使用?api 的方式配置,所以,provider.xml?這個配置文件就暫時不需要了,我們只需要在上面的?AppApi?這個類中的?main?方法中用 api配置及啟動即可。

package com.sihai.dubbo.provider;import com.alibaba.dubbo.config.ApplicationConfig; import com.alibaba.dubbo.config.ProtocolConfig; import com.alibaba.dubbo.config.RegistryConfig; import com.alibaba.dubbo.config.ServiceConfig; import com.sihai.dubbo.provider.service.ProviderService; import com.sihai.dubbo.provider.service.ProviderServiceImpl;import java.io.IOException;/*** Api方式啟動* api的方式調用不需要其他的配置,只需要下面的代碼即可。* 但是需要注意,官方建議:* Api方式用于測試用例使用,推薦xml的方式*/ public class AppApi {public static void main( String[] args ) throws IOException {// 服務實現ProviderService providerService = new ProviderServiceImpl();// 當前應用配置ApplicationConfig application = new ApplicationConfig();application.setName("provider");application.setOwner("sihai");// 連接注冊中心配置RegistryConfig registry = new RegistryConfig();registry.setAddress("zookeeper://localhost:2181"); // registry.setUsername("aaa"); // registry.setPassword("bbb");// 服務提供者協議配置ProtocolConfig protocol = new ProtocolConfig();protocol.setName("dubbo");protocol.setPort(20880);//protocol.setThreads(200);// 注意:ServiceConfig為重對象,內部封裝了與注冊中心的連接,以及開啟服務端口// 服務提供者暴露服務配置ServiceConfig<ProviderService> service = new ServiceConfig<ProviderService>(); // 此實例很重,封裝了與注冊中心的連接,請自行緩存,否則可能造成內存和連接泄漏service.setApplication(application);service.setRegistry(registry); // 多個注冊中心可以用setRegistries()service.setProtocol(protocol); // 多個協議可以用setProtocols()service.setInterface(ProviderService.class);service.setRef(providerService);service.setVersion("1.0.0");// 暴露及注冊服務service.export();} }

分析

看到上面的代碼是不是云里霧里,不要慌,我們通過對照 xml 的方式分析一下。

registry 的 xml 方式 <dubbo:registry protocol="zookeeper"?address="localhost:2181"/> API 的方式 RegistryConfig registry = new RegistryConfig(); registry.setAddress("zookeeper://localhost:2181");

dubbo:registry節點對應RegistryConfig?,xml 的屬性對應 API 方式用?set?方法就可以了。對比之下,你就會發現,如果 API 的方式不熟悉,可以對照 xml 配置方式就可以。

其他 API

org.apache.dubbo.config.ServiceConfig org.apache.dubbo.config.ReferenceConfig org.apache.dubbo.config.ProtocolConfig org.apache.dubbo.config.RegistryConfig org.apache.dubbo.config.MonitorConfig org.apache.dubbo.config.ApplicationConfig org.apache.dubbo.config.ModuleConfig org.apache.dubbo.config.ProviderConfig org.apache.dubbo.config.ConsumerConfig org.apache.dubbo.config.MethodConfig org.apache.dubbo.config.ArgumentConfig

更詳細的可以查看官方文檔:
http://dubbo.apache.org/zh-cn...

我們再看看我配置的消費端的 Api 方式。

消費端

同樣,我們不需要 consumer.xml 配置文件了,只需要在?main?方法中啟動即可。

package com.sihai.dubbo.consumer;import com.alibaba.dubbo.config.ApplicationConfig; import com.alibaba.dubbo.config.ReferenceConfig; import com.alibaba.dubbo.config.RegistryConfig; import com.sihai.dubbo.provider.service.ProviderService;/*** api的方式調用* api的方式調用不需要其他的配置,只需要下面的代碼即可。* 但是需要注意,官方建議:* Api方式用于測試用例使用,推薦xml的方式*/ public class AppApi {public static void main(String[] args) {// 當前應用配置ApplicationConfig application = new ApplicationConfig();application.setName("consumer");application.setOwner("sihai");// 連接注冊中心配置RegistryConfig registry = new RegistryConfig();registry.setAddress("zookeeper://localhost:2181");// 注意:ReferenceConfig為重對象,內部封裝了與注冊中心的連接,以及與服務提供方的連接// 引用遠程服務ReferenceConfig<ProviderService> reference = new ReferenceConfig<ProviderService>(); // 此實例很重,封裝了與注冊中心的連接以及與提供者的連接,請自行緩存,否則可能造成內存和連接泄漏reference.setApplication(application);reference.setRegistry(registry); // 多個注冊中心可以用setRegistries()reference.setInterface(ProviderService.class);// 和本地bean一樣使用xxxServiceProviderService providerService = reference.get(); // 注意:此代理對象內部封裝了所有通訊細節,對象較重,請緩存復用providerService.SayHello("hello dubbo! I am sihai!");} }

這部分的 API 配置的方式就到這了,注意:官方推薦 xml 的配置方法

5.2 注解配置方式

注解配置方式還是需要了解一下的,現在微服務都傾向于這種方式,這也是以后發展的趨勢,0 配置應該是這幾年的趨勢。

那么如何對 dubbo 使用注解的方式呢?我們先看服務端。

服務端

第一步:定義接口及實現類,在上面的截圖中的 annotation 包下

package com.sihai.dubbo.provider.service.annotation;/*** 注解方式接口*/ public interface ProviderServiceAnnotation {String SayHelloAnnotation(String word); } package com.sihai.dubbo.provider.service.annotation;import com.alibaba.dubbo.config.annotation.Service;/*** 注解方式實現類*/ @Service(timeout = 5000) public class ProviderServiceImplAnnotation implements ProviderServiceAnnotation{public String SayHelloAnnotation(String word) {return word;} }

@Service

@Service?用來配置 Dubbo 的服務提供方。

第二步:組裝服務提供方。通過 Spring 中?Java Config?的技術(@Configuration)和 annotation 掃描(@EnableDubbo)來發現、組裝、并向外提供 Dubbo 的服務。

package com.sihai.dubbo.provider.configuration;import com.alibaba.dubbo.config.ApplicationConfig; import com.alibaba.dubbo.config.ProtocolConfig; import com.alibaba.dubbo.config.ProviderConfig; import com.alibaba.dubbo.config.RegistryConfig; import com.alibaba.dubbo.config.spring.context.annotation.EnableDubbo; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration;/*** 注解方式配置*/ @Configuration @EnableDubbo(scanBasePackages = "com.sihai.dubbo.provider.service.annotation") public class DubboConfiguration {@Bean // #1 服務提供者信息配置public ProviderConfig providerConfig() {ProviderConfig providerConfig = new ProviderConfig();providerConfig.setTimeout(1000);return providerConfig;}@Bean // #2 分布式應用信息配置public ApplicationConfig applicationConfig() {ApplicationConfig applicationConfig = new ApplicationConfig();applicationConfig.setName("dubbo-annotation-provider");return applicationConfig;}@Bean // #3 注冊中心信息配置public RegistryConfig registryConfig() {RegistryConfig registryConfig = new RegistryConfig();registryConfig.setProtocol("zookeeper");registryConfig.setAddress("localhost");registryConfig.setPort(2181);return registryConfig;}@Bean // #4 使用協議配置,這里使用 dubbopublic ProtocolConfig protocolConfig() {ProtocolConfig protocolConfig = new ProtocolConfig();protocolConfig.setName("dubbo");protocolConfig.setPort(20880);return protocolConfig;} }

分析

  • 通過 @EnableDubbo 指定在com.sihai.dubbo.provider.service.annotation?下掃描所有標注有?@Service?的類
  • 通過?@Configuration?將?DubboConfiguration?中所有的?@Bean?通過?Java Config?的方式組裝出來并注入給 Dubbo 服務,也就是標注有?@Service?的類。這其中就包括了:

    • ProviderConfig:服務提供方配置
    • ApplicationConfig:應用配置
    • RegistryConfig:注冊中心配置
    • ProtocolConfig:協議配置

看起來很復雜,其實。。。

第三步:啟動服務

package com.sihai.dubbo.provider;import com.alibaba.dubbo.config.spring.context.annotation.DubboComponentScan; import com.sihai.dubbo.provider.configuration.DubboConfiguration; import org.springframework.context.annotation.AnnotationConfigApplicationContext; import sun.applet.Main;import java.io.IOException;/*** 注解啟動方式*/ public class AppAnnotation {public static void main(String[] args) throws IOException {AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(DubboConfiguration.class); context.start();System.in.read(); } }

發現輸出下面信息就表示 success 了。

消費端

同樣我們下看看消費端的工程,有一個感性認識。

第一步:引用服務

package com.sihai.dubbo.consumer.Annotation;import com.alibaba.dubbo.config.annotation.Reference; import com.sihai.dubbo.provider.service.annotation.ProviderServiceAnnotation; import org.springframework.stereotype.Component;/*** 注解方式的service*/ @Component("annotatedConsumer") public class ConsumerAnnotationService {@Referenceprivate ProviderServiceAnnotation providerServiceAnnotation;public String doSayHello(String name) {return providerServiceAnnotation.SayHelloAnnotation(name);} }

在?ConsumerAnnotationService?類中,通過?@Reference?引用服務端提供的類,然后通過方法調用這個類的方式,給消費端提供接口。
注意:如果這里找不到?ProviderServiceAnnotation?類,請在服務端先把服務端工程用?Maven intall?一下,然后將服務端的依賴放到消費端的?pom?中。如下:

<dependency><groupId>com.ouyangsihai</groupId><artifactId>dubbo-provider</artifactId><version>1.0-SNAPSHOT</version></dependency>

第二步:組裝服務消費者
這一步和服務端是類似的,這里就不在重復了。

package com.sihai.dubbo.consumer.configuration;import com.alibaba.dubbo.config.ApplicationConfig; import com.alibaba.dubbo.config.ConsumerConfig; import com.alibaba.dubbo.config.RegistryConfig; import com.alibaba.dubbo.config.spring.context.annotation.EnableDubbo; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.ComponentScan; import org.springframework.context.annotation.Configuration;import java.util.HashMap; import java.util.Map;/*** 注解配置類*/ @Configuration @EnableDubbo(scanBasePackages = "com.sihai.dubbo.consumer.Annotation") @ComponentScan(value = {"com.sihai.dubbo.consumer.Annotation"}) public class ConsumerConfiguration {@Bean // 應用配置public ApplicationConfig applicationConfig() {ApplicationConfig applicationConfig = new ApplicationConfig();applicationConfig.setName("dubbo-annotation-consumer");Map<String, String> stringStringMap = new HashMap<String, String>();stringStringMap.put("qos.enable","true");stringStringMap.put("qos.accept.foreign.ip","false");stringStringMap.put("qos.port","33333");applicationConfig.setParameters(stringStringMap);return applicationConfig;}@Bean // 服務消費者配置public ConsumerConfig consumerConfig() {ConsumerConfig consumerConfig = new ConsumerConfig();consumerConfig.setTimeout(3000);return consumerConfig;}@Bean // 配置注冊中心public RegistryConfig registryConfig() {RegistryConfig registryConfig = new RegistryConfig();registryConfig.setProtocol("zookeeper");registryConfig.setAddress("localhost");registryConfig.setPort(2181);return registryConfig;} }

第三步:發起遠程調用

在?main?方法中通過啟動一個?Spring Context,從其中查找到組裝好的 Dubbo 的服務消費者,并發起一次遠程調用。

package com.sihai.dubbo.consumer;import com.sihai.dubbo.consumer.Annotation.ConsumerAnnotationService; import com.sihai.dubbo.consumer.configuration.ConsumerConfiguration; import com.sihai.dubbo.provider.service.ProviderService; import org.springframework.context.annotation.AnnotationConfigApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext;import java.io.IOException;/*** 注解方式啟動**/ public class AppAnnotation {public static void main( String[] args ) throws IOException {AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(ConsumerConfiguration.class); context.start(); // 啟動ConsumerAnnotationService consumerAnnotationService = context.getBean(ConsumerAnnotationService.class); String hello = consumerAnnotationService.doSayHello("annotation"); // 調用方法System.out.println("result: " + hello); // 輸出結果} }

結果

六 常用場景

在下面的講解中,都會是以?xml?配置的方式來講解的,這也是 dubbo 官方比較推薦的方式。以下的操作都是在服務端的?xml?配置文件和消費端的配置文件來講解的。

6.1 啟動時檢查

Dubbo 缺省會在啟動時檢查依賴的服務是否可用,不可用時會拋出異常,阻止 Spring 初始化完成,以便上線時,能及早發現問題,默認 `check="true"。

但是,有的時候,我們并不是都需要啟動時就檢查的,比如測試的時候,我們是需要更快速的啟動,所以,這種場景的時候,我們是需要關閉這個功能的。

下面,我們看看如何使用這個功能。

在服務端注冊的時候(客戶端注冊時同樣適用);

<dubbo:registry protocol="zookeeper"?address="localhost:2181,localhost:2182,localhost:2183"check="false"/>

在客戶端引用服務端服務的時候;

<dubbo:reference check="false" id="providerService"interface="com.sihai.dubbo.provider.service.ProviderService"/>

就是這么簡單,就是這么強!

6.2 集群容錯

dubbo 也是支持集群容錯的,同時也有很多可選的方案,其中,默認的方案是?failover,也就是重試機制。

首先,我們先把所有的容錯機制都整理一遍,然后再看看使用。

集群模式說明使用方法
Failover Cluster失敗自動切換,當出現失敗,重試其它服務器。通常用于讀操作,但重試會帶來更長延遲??赏ㄟ^ retries="2" 來設置重試次數(不含第一次)。cluster="xxx" xxx:集群模式名稱 ,例如cluster="failover"
Failfast Cluster快速失敗,只發起一次調用,失敗立即報錯。通常用于非冪等性的寫操作,比如新增記錄。?
Failsafe Cluster失敗安全,出現異常時,直接忽略。?
Failback Cluster失敗自動恢復,后臺記錄失敗請求,定時重發。通常用于消息通知操作。?
Forking Cluster并行調用多個服務器,只要一個成功即返回。通常用于實時性要求較高的讀操作,但需要浪費更多服務資源??赏ㄟ^ forks="2" 來設置最大并行數。?
Broadcast Cluster廣播調用所有提供者,逐個調用,任意一臺報錯則報錯。通常用于通知所有提供者更新緩存或日志等本地資源信息。?

使用實例
在發布服務或者引用服務的時候設置

<!--服務發布的配置,需要暴露的服務接口--><dubbo:service cluster="failover" retries="2"interface="com.sihai.dubbo.provider.service.ProviderService"ref="providerService"/> <dubbo:reference cluster="failover" retries="2" check="false" id="providerService"interface="com.sihai.dubbo.provider.service.ProviderService"/>

6.3 負載均衡

負載均衡想必是一個再熟悉不過的概念了,所以,dubbo 支持也是再正常不過了,這里也總結一下 dubbo 支持的負載均衡的一些方案及使用方法。

負載均衡模式說明使用方法
Random LoadBalance隨機 按權重設置隨機概率<dubbo:service loadbalance="xxx"/> xxx:負載均衡方法
RoundRobin LoadBalance輪詢 按公約后的權重設置輪詢比率。?
LeastActive LoadBalance最少活躍調用數 相同活躍數的隨機,活躍數指調用前后計數差。?
ConsistentHash LoadBalance一致性 Hash 相同參數的請求總是發到同一提供者。 當某一臺提供者掛時,原本發往該提供者的請求,基于虛擬節點,平攤到其它提供者,不會引起劇烈變動。?

6.4 直連提供者

在開發及測試環境下,經常需要繞過注冊中心,只測試指定服務提供者,所以,這種情況下,我們只需要直接連接服務端的地即可,其實,這種方法在前面的講解已經使用到了,第一種講解的方式就是這種方式,因為這種方式簡單。

使用

<dubbo:reference id="providerService"interface="com.sihai.dubbo.provider.service.ProviderService"url="dubbo://192.168.234.1:20880/com.sihai.dubbo.provider.service.ProviderService"/>

說明:可以看到,只要在消費端在?dubbo:reference?節點使用?url?給出服務端的方法即可。

6.5 只訂閱

只訂閱就是只能夠訂閱服務端的服務,而不能夠注冊。

引用官方的使用場景如下:

為方便開發測試,經常會在線下共用一個所有服務可用的注冊中心,這時,如果一個正在開發中的服務提供者注冊,可能會影響消費者不能正常運行。
可以讓服務提供者開發方,只訂閱服務(開發的服務可能依賴其它服務),而不注冊正在開發的服務,通過直連測試正在開發的服務。 <dubbo:registry?register="false"?protocol="zookeeper"address="localhost:2181,localhost:2182,localhost:2183"?check="false"/>

① 使用只訂閱方式

當在服務提供端使用?register="false"?的時候,我們使用下面的方式獲取服務端的服務;

<dubbo:reference cluster="failover" retries="2" check="false" id="providerService"interface="com.sihai.dubbo.provider.service.ProviderService"/>

啟動信息

發現,這時候并不是向注冊中心 zookeeper?注冊,而只是做了發布服務和啟動netty。

② 不使用只訂閱方式

<dubbo:registry protocol="zookeeper"?address="localhost:2181,localhost:2182,localhost:2183"check="false"/>

啟動信息

可以發現,這里就向注冊中心 zookeeper 注冊了。

6.6 只注冊

只注冊正好跟前面的只訂閱相反,這個時候可以向注冊中心注冊,但是,消費端卻不能夠讀到服務。

應用場景

如果有兩個鏡像環境,兩個注冊中心,有一個服務只在其中一個注冊中心有部署,另一個注冊中心還沒來得及部署,而兩個注冊中心的其它應用都需要依賴此服務。這個時候,可以讓服務提供者方只注冊服務到另一注冊中心,而不從另一注冊中心訂閱服務。

使用說明

<dubbo:registry?subscribe="false"?address="localhost:2181"></dubbo:registry>

在服務端的?dubbo:registry?節點下使用?subscribe="false"?來聲明這個服務是只注冊的服務。

這個時候消費端調用的時候是不能調用的。

6.7 多協議機制

在前面我們使用的協議都是 dubbo 協議,但是 dubbo 除了支持這種協議外還支持其他的協議,比如,rmi、hessian等,另外,而且還可以用多種協議同時暴露一種服務。

使用方法

① 一種接口使用一種協議

先聲明多種協議

<!--當前服務發布所依賴的協議;webserovice、Thrift、Hessain、http--><dubbo:protocol name="dubbo" port="20880"/><dubbo:protocol name="rmi" port="1099" />

然后在發布接口的時候使用具體協議

<!--服務發布的配置,需要暴露的服務接口--><dubbo:service cluster="failover" retries="2"interface="com.sihai.dubbo.provider.service.ProviderService"ref="providerService"/><dubbo:service cluster="failover" retries="2"interface="com.sihai.dubbo.provider.service.ProviderService"ref="providerService" protocol="rmi"/>

在輸出日志中,就可以找到rmi發布的接口。

rmi://192.168.234.1:1099/com.sihai.dubbo.provider.service.ProviderService?anyhost=true&application=provider&bean.name=com.sihai.dubbo.provider.service.ProviderService&cluster=failover&dubbo=2.0.2&generic=false&interface=com.sihai.dubbo.provider.service.ProviderService&methods=SayHello&owner=sihai&pid=796&retries=2&side=provider&timestamp=1564281053185, dubbo version:?2.6.6, current host:?192.168.234.1

② 一種接口使用多種協議
聲明協議和上面的方式一樣,在發布接口的時候有一點不一樣。

<dubbo:service cluster="failover" retries="2"interface="com.sihai.dubbo.provider.service.ProviderService"ref="providerService" protocol="rmi,dubbo"/>

說明:protocol屬性,可以用,隔開,使用多種協議。

6.8 多注冊中心

Dubbo 支持同一服務向多注冊中心同時注冊,或者不同服務分別注冊到不同的注冊中心上去,甚至可以同時引用注冊在不同注冊中心上的同名服務。

服務端多注冊中心發布服務

一個服務可以在不同的注冊中心注冊,當一個注冊中心出現問題時,可以用其他的注冊中心。

注冊

<!--多注冊中心--><dubbo:registry protocol="zookeeper" id="reg1" timeout="10000" address="localhost:2181"/><dubbo:registry protocol="zookeeper" id="reg2" timeout="10000" address="localhost:2182"/><dubbo:registry protocol="zookeeper" id="reg3" timeout="10000" address="localhost:2183"/>

發布服務

<!--服務發布的配置,需要暴露的服務接口--><dubbo:service cluster="failover" retries="2"interface="com.sihai.dubbo.provider.service.ProviderService"ref="providerService" registry="reg1"/><dubbo:service cluster="failover" retries="2"interface="com.sihai.dubbo.provider.service.ProviderService"ref="providerService" protocol="rmi" registry="reg2"/>

說明:使用registry="reg2"指定該接口使用的注冊中心,同時也可以使用多個,用,隔開,例如,registry="reg1,,reg2"。

消費端多注冊中心引用服務

首先,先向不同注冊中心注冊;

<!--多注冊中心--><dubbo:registry protocol="zookeeper" id="reg1" timeout="10000" address="localhost:2181"/><dubbo:registry protocol="zookeeper" id="reg2" timeout="10000" address="localhost:2182"/><dubbo:registry protocol="zookeeper" id="reg3" timeout="10000" address="localhost:2183"/>

其次,不同的消費端服務引用使用不同的注冊中心;

!--不同的服務使用不同的注冊中心--><dubbo:reference cluster="failover" retries="2" check="false" id="providerService"interface="com.sihai.dubbo.provider.service.ProviderService" registry="reg1"/><dubbo:reference cluster="failover" retries="2" check="false" id="providerService2"interface="com.sihai.dubbo.provider.service.ProviderService" registry="reg2"/>

說明:上面分別使用注冊中心1和注冊中心2。

6.9 多版本

不同的服務是有版本不同的,版本可以更新并且升級,同時,不同的版本之間是不可以調用的。

<!--服務發布的配置,需要暴露的服務接口--><dubbo:service cluster="failover" retries="2"interface="com.sihai.dubbo.provider.service.ProviderService"ref="providerService" registry="reg1" version="1.0.0"/><dubbo:service cluster="failover" retries="2"interface="com.sihai.dubbo.provider.service.ProviderService"ref="providerService" protocol="rmi" registry="reg2" version="1.0.0"/>

加入了版本控制。

6.10 日志管理

dubbo 也可以將日志信息記錄或者保存到文件中的。

① 使用accesslog輸出到log4j

<dubbo:protocol accesslog="true" name="dubbo" port="20880"/><dubbo:protocol accesslog="true" name="rmi" port="1099" />

② 輸出到文件

<dubbo:protocol accesslog="http://localhost/log.txt" name="dubbo" port="20880"/><dubbo:protocol accesslog="http://localhost/log2.txt" name="rmi" port="1099" />

七 總結

這篇文章就到這里了,主要講了一下幾個內容
1、為什么需要dubbo
2、dubbo架構簡析
3、dubbo入門
4、zookeeper注冊中心加入dubbo
5、dubbo多種配置方式(xml、api、注解)
6、常用場景介紹

總結

以上是生活随笔為你收集整理的Dubbo 一篇文章就够了:从入门到实战的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

av免费电影在线观看 | 成人精品影视 | 麻豆果冻剧传媒在线播放 | 免费观看午夜视频 | 狠狠88综合久久久久综合网 | 国产成人精品一区二区三区福利 | 久久久国产精华液 | 久久99热久久99精品 | 999男人的天堂 | 成人网页在线免费观看 | 国产亚洲久一区二区 | 免费精品视频在线观看 | 伊人五月天婷婷 | 91精品久久久久久久91蜜桃 | 人人草网站 | 国产在线观看不卡 | 9在线观看免费高清完整 | 在线电影 一区 | 日韩欧美国产精品 | 天天干天天干天天干天天干天天干天天干 | 精品久久久久国产 | 日韩| 色在线视频 | 日本视频高清 | 91在线国内视频 | 18女毛片 | 四虎在线免费观看 | av大片网站 | 色婷婷综合成人av | 亚洲欧美怡红院 | 国内成人精品视频 | 成人一级在线观看 | 久久久久久国产精品 | 六月天综合网 | 欧美日韩精品在线一区二区 | av中文电影 | 色狠狠一区二区 | 国产一级精品在线观看 | 最新av在线免费观看 | 久久99视频精品 | 亚洲激情五月 | 亚洲精品在线一区二区 | 97国产大学生情侣酒店的特点 | 国产精品免费在线视频 | 99视频在线观看一区三区 | 久久久久久久久久久久国产精品 | 性色va | 久久国产精品久久精品国产演员表 | 日韩高清在线一区 | 超级av在线 | 国产精品美女999 | 99在线热播精品免费99热 | 日本黄色一级电影 | 天天干夜夜夜 | 久久久黄色免费网站 | 成人片在线播放 | 精品久久免费看 | 超碰在线98 | 毛片888| 久久久www成人免费毛片 | 国产精品一二三 | 国产1区在线 | 日韩av免费大片 | 蜜桃av人人夜夜澡人人爽 | 日韩特黄一级欧美毛片特黄 | 美女视频永久黄网站免费观看国产 | 日日爽夜夜操 | 超碰人在线 | 999国内精品永久免费视频 | 91尤物国产尤物福利在线播放 | 国产亚洲视频在线观看 | 精品久久久久免费极品大片 | 亚洲黄色片在线 | 久久久久亚洲精品国产 | 国产精品美女 | 精品视频久久久久久 | 亚洲精品国产麻豆 | 久久国产精品色av免费看 | 国产h在线播放 | 国产一二三区av | 开心激情五月婷婷 | 亚洲精品国偷拍自产在线观看 | 亚洲精品国产精品国自产 | 超碰在线cao | 99爱在线观看 | 99国产在线视频 | 久久久免费视频播放 | 久久开心激情 | 亚洲午夜电影网 | 手机在线黄色网址 | 日批网站免费观看 | 色中色资源站 | 99在线精品视频 | 国产精品一区二区av | 日韩免费网站 | 亚洲欧洲一区二区在线观看 | 96超碰在线 | 午夜婷婷在线观看 | 久久精品视频免费 | 91久久偷偷做嫩草影院 | 手机看片国产 | 午夜在线免费观看视频 | 午夜影院先 | 久草电影免费在线观看 | 天天操夜夜做 | 免费一级日韩欧美性大片 | 亚洲 精品在线视频 | 91色九色 | 国产黄色大全 | 黄网站色欧美视频 | 久久国产成人午夜av影院宅 | 亚洲婷婷伊人 | 最新中文在线视频 | 久草在在线 | 亚洲国产精品影院 | 国产午夜视频在线观看 | 国产成人精品在线播放 | 免费看毛片网站 | 国产精品日韩精品 | 中文字幕在线观看免费高清完整版 | 99热精品国产一区二区在线观看 | 成人啪啪18免费游戏链接 | 亚洲国产影院 | www.天天操.com | 91视频麻豆视频 | 狠狠狠色狠狠色综合 | 久久国产成人午夜av影院潦草 | ,午夜性刺激免费看视频 | 午夜久久久久久久久久久 | 波多野结衣在线观看一区二区三区 | 久久天天躁狠狠躁亚洲综合公司 | 日韩大片在线免费观看 | 国产精品久久久久久久久久99 | 久久网页 | 综合网在线视频 | 亚洲视频在线看 | 欧美精品免费在线 | 丁香婷婷激情国产高清秒播 | 国产免费久久精品 | 免费三级骚| 亚洲天堂精品视频在线观看 | 国产欧美综合视频 | 久久99久久99精品免视看婷婷 | 亚洲精品456在线播放 | 中文字幕av免费在线观看 | 99热这里是精品 | 在线中文字幕观看 | 97超碰超碰 | 日韩理论片中文字幕 | 成人日批视频 | 久久中国精品 | 综合激情久久 | 免费在线一区二区三区 | 久久96| av黄免费看 | 久久国产精品免费看 | 精品国产99国产精品 | 亚洲最新精品 | a黄色影院 | 国产探花 | 天天干夜夜爽 | 伊人久久影视 | av在线最新 | 亚洲精品美女久久久 | 欧美成人久久 | 在线观看视频在线 | 黄色一区三区 | 91黄在线看| 成人黄色视 | 搡bbbb搡bbb视频 | 91精品在线播放 | 亚洲黄色在线观看 | 精品国产一区二区三区久久影院 | 久久视频在线看 | 亚洲人成影院在线 | 免费大片黄在线 | 欧美少妇的秘密 | 日韩免费在线看 | 欧美一级片在线 | 久草精品视频在线播放 | 精品久久久久久久久久 | 成人一区二区在线 | 在线观看免费av网 | 久久精品永久免费 | 日韩精品中文字幕在线不卡尤物 | 六月色丁香 | 去干成人网 | 怡红院av | 中文字幕日韩伦理 | 三级av免费 | 亚洲伦理中文字幕 | 精品国产免费av | 在线观看你懂的网址 | www.色婷婷| 午夜在线免费观看 | 欧美另类v | 亚洲精品美女在线观看播放 | 中文字幕乱在线伦视频中文字幕乱码在线 | 久久亚洲国产精品 | 久久久久国产一区二区三区四区 | 99热 精品在线 | 中文字幕在线观看第一区 | 九月婷婷色 | 久久综合亚洲鲁鲁五月久久 | 精品一区三区 | 永久免费精品视频 | 国产高清一级 | 亚洲国产高清在线观看视频 | 久久久久久久久久久网 | 激情中文在线 | av资源网在线播放 | 一区 二区 精品 | 亚洲日日射 | 成人免费色 | 91在线九色 | 亚洲国产成人在线观看 | 免费视频一区 | 国产精品视频在线观看 | 在线观看av免费观看 | 天天摸天天操天天舔 | 五月天电影免费在线观看一区 | 五月香视频在线观看 | 黄色免费观看视频 | 免费99精品国产自在在线 | 91九色在线 | 国产高清免费视频 | 日日夜夜精品网站 | 国产96在线| www天天干| 国产精品久久久久久模特 | 18久久久 | 国产v欧美 | 五月综合在线观看 | 狠狠色丁香婷婷综合最新地址 | 欧美精品在线视频观看 | 久久免费看a级毛毛片 | 九九九视频精品 | 96av在线| 在线免费视频一区 | 亚洲精品欧美精品 | 天天天天天操 | 97操操操| 六月丁香综合网 | 免费黄色特级片 | 亚洲撸撸 | 国产va精品免费观看 | 亚洲精品成人av在线 | 午夜色婷婷 | 天天干天天做天天操 | 在线观看91精品国产网站 | 国产黄色一级片在线 | 一区二区国产精品 | 久久露脸国产精品 | 亚洲免费一级 | 国产精品久久久久永久免费观看 | 最新日韩在线观看 | 在线免费黄色片 | 国产99爱 | 一级黄色a视频 | 国产日韩精品一区二区三区 | 99热这里只有精品8 久久综合毛片 | 日本公妇在线观看高清 | 久久99精品国产麻豆宅宅 | 久久久久在线视频 | 免费一级日韩欧美性大片 | 亚洲网站在线看 | 午夜影院在线观看18 | 日本午夜在线观看 | 日本成人免费在线观看 | 成人精品一区二区三区电影免费 | 亚洲国产日本 | 国产黄在线 | 中文字幕网站视频在线 | 91入口在线观看 | 亚洲伦理中文字幕 | 日韩va欧美va亚洲va久久 | 激情一区二区三区欧美 | 婷婷中文字幕 | 99精品在线观看 | 国产精品久久久久9999 | 中文字幕高清在线播放 | 久久视频网 | av福利网址导航 | 欧美视频国产视频 | 亚洲欧洲久久久 | 欧美日韩精品在线免费观看 | 亚洲aaa级 | 欧美精选一区二区三区 | 射久久久| 欧美亚洲成人xxx | 欧美有色 | 亚洲aⅴ免费在线观看 | 国产一区二区久久久 | 久久视奸 | 四虎影视4hu4虎成人 | 一区二区精品国产 | 国产日韩欧美在线观看视频 | 日韩在线视频线视频免费网站 | 最近更新好看的中文字幕 | 午夜视频日本 | 九草视频在线观看 | 97超碰人人澡人人爱学生 | 九九久久精品 | 久久涩视频 | 久艹在线播放 | 国产999精品久久久影片官网 | 久久爱资源网 | 成人动漫精品一区二区 | 久草在线精品观看 | 国产高清视频免费在线观看 | 国产一级免费在线 | 欧美另类交人妖 | 69久久久久久久 | 在线观看网站你懂的 | 欧美日韩一区二区免费在线观看 | 亚洲麻豆精品 | 黄色免费国产 | 日日操网 | 精品视频久久 | 亚洲理论在线观看 | av超碰在线 | 波多野结衣在线视频一区 | 日韩理论视频 | 五月婷色 | 四虎在线观看精品视频 | 一区中文字幕在线观看 | 丝袜美腿在线播放 | 国产精品九色 | 一级片免费观看视频 | 毛片二区 | 婷婷丁香av | 91xav | 国产乱码精品一区二区三区介绍 | 精品久久久久久久久久久久久久久久久久 | 国产大片黄色 | 国产一级不卡毛片 | 亚洲精品自拍视频在线观看 | 另类五月激情 | 成片免费观看视频大全 | 亚洲精品在线免费观看视频 | 美女视频黄,久久 | 中文字幕在线观看完整版电影 | 久久中文字幕在线视频 | 少妇性色午夜淫片aaaze | 在线观看国产区 | 国产精品久久久av | 五月婷婷丁香综合 | 香蕉色综合 | av直接看 | 66av99精品福利视频在线 | 久久人人爽人人爽人人片av免费 | 国产精品成人aaaaa网站 | av丁香 | 亚洲在线精品 | 人人草网站 | 成年人毛片在线观看 | 91麻豆精品一区二区三区 | 久久精品欧美一区 | 久草在线免费色站 | 国产精品久久久久免费观看 | 欧美久久久久久久久中文字幕 | www.色爱| 91丨精品丨蝌蚪丨白丝jk | 久草在线观| 在线视频日韩一区 | 国产一区自拍视频 | 国产第一页福利影院 | 人交video另类hd | 亚洲国产精品va在线看黑人动漫 | 香蕉在线播放 | 欧美一二三四在线 | 午夜免费电影院 | 超碰97免费| 亚洲精品五月天 | 久久亚洲专区 | av短片在线观看 | 日韩精品高清视频 | 91久久精 | 国产综合激情 | 操综合| 91秒拍国产福利一区 | 国产精品女 | 天天操天天爽天天干 | 国产精品久久久久久久av大片 | 久久精品99 | 亚洲欧洲成人 | 九九九九精品九九九九 | 超碰人在线 | 亚洲精品视频免费在线观看 | 日韩久久精品 | 亚洲狠狠婷婷综合久久久 | 国产欧美精品一区二区三区四区 | 亚洲永久国产精品 | а中文在线天堂 | 欧美日韩另类在线观看 | 免费av观看 | 国产成人精品一区二区在线观看 | 99热在线国产精品 | 日本99干网| 999免费视频 | 色99视频 | 黄色精品在线看 | 国产小视频免费在线网址 | 国产精品久久久久久久妇 | 婷婷丁香自拍 | 人人艹视频 | 久久久受www免费人成 | 欧美日韩伦理在线 | 在线观看中文字幕第一页 | 综合精品久久久 | 又污又黄的网站 | 一区二区在线电影 | 成全在线视频免费观看 | 日本精品久久久久影院 | 久久精品亚洲一区二区三区观看模式 | 国产精品igao视频网网址 | 91精品国产高清 | 九九免费在线视频 | 在线免费国产视频 | 久久久久五月 | 亚洲久草网 | 国产黄色片久久久 | 中文在线a∨在线 | 999久久久久久| 人人插人人费 | 最近字幕在线观看第一季 | 精品国产乱码久久久久久三级人 | 91中文视频 | 日韩欧美精品一区二区 | 一性一交视频 | 伊人天天狠天天添日日拍 | 国产黄色精品在线 | 国产91勾搭技师精品 | 97福利在线 | 激情五月六月婷婷 | 久久久av电影 | 成人av网站在线观看 | 日韩欧美精品在线观看视频 | 久久精品美女视频网站 | 蜜臀av麻豆| 久久69精品久久久久久久电影好 | 天天狠狠| 国产一区二区高清视频 | 成人9ⅰ免费影视网站 | 国产天天综合 | 一区二区中文字幕在线观看 | 西西www4444大胆在线 | 麻豆国产精品视频 | av在线播放观看 | 一区二区三区av在线 | 中文字幕免费在线 | 日韩一级黄色av | 在线观看免费一级片 | 久久少妇免费视频 | 美女视频a美女大全免费下载蜜臀 | 亚洲国产精品激情在线观看 | 欧美日韩视频在线播放 | 久久永久免费视频 | 一本一道久久a久久精品 | 一区三区在线欧 | 国产午夜三级一区二区三桃花影视 | 久久久久国产精品免费免费搜索 | 色婷婷视频在线 | 人人澡超碰碰 | 草久在线观看 | 一区二区三区国产欧美 | 91精品免费在线观看 | 天天曰天天干 | 国产黄在线播放 | 91精品国产91久久久久福利 | 亚洲婷婷综合色高清在线 | 91精品婷婷国产综合久久蝌蚪 | 国产码电影 | 亚洲视频免费在线观看 | 精品久久久久久亚洲综合网 | 国内精品久久久久久久97牛牛 | 久久精品网站视频 | 成人观看| av综合av| 久久99精品国产 | 91精品视频观看 | 日韩不卡高清视频 | 亚洲高清资源 | 久久久久久久久久电影 | 日韩欧美视频免费在线观看 | 婷婷激情在线观看 | 久久一区二 | 天天操天天草 | 色五月色开心色婷婷色丁香 | 九九一级片| 国产中文欧美日韩在线 | 又爽又黄又无遮挡网站动态图 | 精品1区2区 | 久久视频这里有久久精品视频11 | 日韩欧美在线播放 | 五月婷婷中文网 | 蜜臀av性久久久久蜜臀aⅴ涩爱 | 久久天天躁狠狠躁亚洲综合公司 | 久久国产精品一区二区 | 亚洲精品午夜久久久久久久久久久 | wwwwww黄 | 久久综合精品国产一区二区三区 | 99热最新在线 | 一级一级一片免费 | 综合五月 | 日韩区在线观看 | 久久av免费观看 | 波多野结衣电影久久 | 国产美女搞久久 | 天天操天天舔天天爽 | 久久精品日产第一区二区三区乱码 | 97精品免费视频 | 久久午夜免费观看 | 美女精品国产 | 久草在线视频免费资源观看 | 久久天天躁夜夜躁狠狠85麻豆 | 国产美女精品人人做人人爽 | 日韩av影视 | 久人人| 日韩在线播放av | 亚洲成人黄色在线观看 | 欧美精品久久久久久久免费 | 中文字幕高清av | 久久视频这里有久久精品视频11 | 欧美日韩国产精品久久 | 五月婷婷丁香激情 | 国产一区二区在线播放 | 久久无码av一区二区三区电影网 | 精品国产伦一区二区三区观看体验 | 亚洲午夜精品福利 | 国产精品资源 | av大全在线免费观看 | 91麻豆精品国产午夜天堂 | 美女av在线免费 | 成人在线观看资源 | www.com黄 | 综合激情网... | 国产亚洲在线 | 高清一区二区 | 最近日本中文字幕 | 在线 成人 | 又污又黄的网站 | 久久久久欧美精品 | 国产一区二区三区视频在线 | 综合婷婷| 99爱视频 | 黄色tv视频| www成人精品 | 在线蜜桃视频 | 九九九视频精品 | 日韩在线 | wwwwww黄| 午夜av大片 | 亚洲天堂免费视频 | 日韩精品免费一区二区 | 日日爽天天操 | 美女精品国产 | 国产精品美女久久久久久 | 亚洲精品毛片一级91精品 | 9999国产精品| 日韩av高清在线观看 | 超碰免费久久 | 在线观看免费91 | 久久乱码卡一卡2卡三卡四 五月婷婷久 | 一级欧美日韩 | 激情av资源 | www操操操 | 91禁在线看 | 欧美日韩一区二区三区不卡 | 超碰在线94| 久久99视频免费观看 | 久久超级碰 | 99热国产在线观看 | www操操操 | 丁香六月五月婷婷 | 九九热精品在线 | 国产精品手机在线 | 在线亚洲观看 | 国产亚洲成av人片在线观看桃 | 美女网站在线看 | 91久久国产露脸精品国产闺蜜 | 色五月色开心色婷婷色丁香 | 欧美日韩高清一区二区 国产亚洲免费看 | 亚洲91av| 成人黄色电影在线 | 亚洲乱码精品 | 欧美性猛片 | 天天综合亚洲 | 五月花丁香婷婷 | 国产香蕉97碰碰久久人人 | 91九色最新 | 国产精品99久久久久久大便 | 亚洲色图激情文学 | 国产精品久久久久久模特 | 一区二区三区 亚洲 | 波多野结依在线观看 | 久久夜色精品亚洲噜噜国4 午夜视频在线观看欧美 | 成人av高清| 91在线文字幕| 久久99网 | 日韩网 | 国产不卡片 | 最新一区二区三区 | av大全在线 | 婷婷亚洲激情 | 午夜精品久久久久久久久久久久久久 | 国产91成人在在线播放 | 欧美一级电影在线观看 | 一区二区 精品 | 亚洲精品中文在线 | 国产日本在线观看 | 99视频在线免费观看 | 国产精品9区 | 99精品视频在线观看播放 | 97涩涩视频 | 五月婷婷亚洲 | 新版资源中文在线观看 | 久久国语 | 欧美在线free | 国产99中文字幕 | 一区二区精品 | 99热国产在线 | 亚洲精品动漫成人3d无尽在线 | 五月天婷婷在线观看视频 | 久久久男人的天堂 | 欧美人牲 | 国产资源在线播放 | 国产伦理剧 | 亚洲精品高清一区二区三区四区 | 国产成人av一区二区三区在线观看 | 青春草免费在线视频 | 亚洲精品在线国产 | 制服丝袜欧美 | 在线免费黄色片 | 久久黄页 | 久久精品综合网 | 天堂v中文 | 91探花在线视频 | 色天天综合网 | 国产精品久久久久久久久久久久 | 亚洲专区中文字幕 | 国产精品美女久久久久久久 | 成人性生交大片免费看中文网站 | 天天操天天干天天综合网 | 国产一区 在线播放 | 韩国精品在线 | 欧美精品在线视频 | 欧美极品少妇xxxx | 日韩和的一区二在线 | 久久精品国产精品亚洲 | 国产成人av网址 | av免费播放| 在线看国产 | 久久天天躁夜夜躁狠狠85麻豆 | 黄色的视频网站 | 伊人手机在线 | 一区二区久久久久 | 91夜夜夜| 日本天天操 | 91在线精品一区二区 | 在线观看 国产 | 福利片视频区 | 久久亚洲婷婷 | av在线免费播放网站 | 亚洲毛片一区二区三区 | 手机看片99 | 国产成人av | 人人干人人搞 | 国产老太婆免费交性大片 | 国产在线精品视频 | 国产精品一区二区在线观看 | 麻豆手机在线 | 欧美性生活大片 | 亚洲国产经典视频 | 中文字幕在线视频免费播放 | 久久99国产一区二区三区 | 亚洲美女免费精品视频在线观看 | 三级黄免费看 | 一区二区三区四区在线免费观看 | 婷婷久久亚洲 | 黄色aaa毛片 | 在线精品视频在线观看高清 | 亚洲精品一区二区18漫画 | 六月丁香在线观看 | 一级淫片在线观看 | 97电影在线 | 国产青青青 | 天天爱天天操天天干 | 天天操天天干天天爽 | 国产91精品在线观看 | 色妞久久福利网 | 国产在线一卡 | 国产99爱 | 免费视频三区 | 天天色图 | 国产精品涩涩屋www在线观看 | 97av精品 | 国产免费中文字幕 | 亚洲九九九在线观看 | 日韩午夜精品福利 | 黄色福利网站 | 中文字幕在线日亚洲9 | 天堂在线v | 激情久久一区二区三区 | www.精选视频.com | 国产99久久精品一区二区300 | 成人av网站在线观看 | 国产成人精品一区一区一区 | 欧美男同网站 | 婷婷丁香七月 | 国产精品一区二区在线观看免费 | 精品国产成人av | 精品一区 精品二区 | 日批网站在线观看 | 美女黄濒 | 亚洲精品成人网 | 在线视频第一页 | 天天五月天色 | 国产最顶级的黄色片在线免费观看 | 伊人婷婷在线 | 国产视频久久久久 | 69精品视频在线观看 | 波多野结衣在线视频一区 | 日韩欧美在线观看一区二区三区 | 久久伊人国产精品 | 深爱五月激情五月 | 免费婷婷| 成人动图 | 玖玖在线视频观看 | 精品国产成人av | 亚洲精品小视频在线观看 | 成人久久精品 | 国产一区成人 | 亚洲无吗天堂 | 欧美日韩免费一区 | 69久久99精品久久久久婷婷 | 最新色视频 | 亚洲欧洲精品一区二区 | 欧美天天射 | 青春草视频 | 亚洲高清视频在线观看 | 日本婷婷色 | av一级片在线观看 | 国产精品第三页 | 日韩伦理片一区二区三区 | 亚洲 成人 一区 | 在线观看aa| 中文字幕av最新更新 | 亚洲国产成人精品电影在线观看 | 婷婷网在线 | www.五月天激情 | 国产一区二区免费在线观看 | av电影亚洲 | 日韩一区二区免费视频 | 日韩视频a| 国产免费av一区二区三区 | 欧美激情精品 | aaa毛片视频 | 日日夜夜91 | 最近中文字幕在线播放 | 91视频久久久久 | 久久视频精品 | 国产九九精品视频 | 欧美精品一区二区在线观看 | 在线观看中文字幕av | 九色视频自拍 | av在线激情 | 天天干天天操人体 | 国产91学生粉嫩喷水 | 国产精品一区二区三区在线看 | 青青草国产精品 | 97av在线| 亚洲男男gaygay无套同网址 | 久久久久久国产精品免费 | 成人av片免费看 | 中文在线√天堂 | 中文字幕资源在线 | 超碰97人| 日韩欧美国产视频 | 亚洲在线网址 | 五月综合网站 | 中文字幕资源网 国产 | 久久尤物电影视频在线观看 | 国产精品一区二区久久国产 | 欧美日韩一区二区三区在线观看视频 | 久久在线观看视频 | 天天射日 | 麻豆网站免费观看 | 久久黄色精品视频 | 婷婷色中文字幕 | 99精品国产99久久久久久福利 | 色丁香婷婷 | 视频在线观看入口黄最新永久免费国产 | 亚洲黄色免费 | 2019中文在线观看 | 国产伦精品一区二区三区四区视频 | 麻豆国产在线视频 | 黄色国产成人 | 国产精品手机在线 | 91av视频在线观看免费 | 天天天天天天天天操 | 这里有精品在线视频 | 521色香蕉网站在线观看 | 天天爱天天干天天爽 | 在线一级片 | 97视频在线免费观看 | 亚洲色影爱久久精品 | 国产在线观看地址 | 亚洲精品国产精品国自产观看浪潮 | 国产亚洲精品精品精品 | 精品福利网站 | 亚州成人av在线 | 免费视频网 | 亚洲伊人色 | 99免费在线观看 | 亚洲精品乱码久久久久久蜜桃动漫 | 日本中文字幕在线免费观看 | 色播六月天| 五月天中文在线 | 久久久久久久久久久福利 | 亚洲香蕉视频 | 九九在线国产视频 | 久99久视频 | 免费在线国产精品 | 国产午夜精品一区二区三区嫩草 | 久久99精品久久只有精品 | 久久免费试看 | 天堂av一区二区 | 国产又粗又猛又黄又爽视频 | 天堂视频一区 | 九色视频网址 | 在线免费观看视频一区 | 欧美精品久久久久久 | 亚洲理论在线观看电影 | 久久久久伦理电影 | 国产精品久久久久久高潮 | 97电影在线看视频 | 日韩高清免费观看 | 91日本在线播放 | 成人在线网站观看 | 69夜色精品国产69乱 | 九九免费精品 | 女人18毛片a级毛片一区二区 | 三级av在线免费观看 | 国产精品高潮久久av | 激情久久五月天 | 精品在线观看一区二区三区 | 久久99亚洲精品久久 | 大荫蒂欧美视频另类xxxx | 久久理论影院 | 久久久综合九色合综国产精品 | 91视频久久 | 日韩精品一区在线播放 | 日韩欧美在线第一页 | av电影在线不卡 | 国产色一区 | 亚洲精品国精品久久99热一 | 992tv又爽又黄的免费视频 | 99免在线观看免费视频高清 | 久久激情视频免费观看 | 精品视频97| 美女免费黄视频网站 | 日韩电影在线观看一区二区 | 99情趣网视频 | 久久国产香蕉视频 | 亚洲精品一区二区三区新线路 | 日韩丝袜视频 | 一区二区三区高清不卡 | 精品久久久久久亚洲综合网 | 国产精品嫩草影院99网站 | 中文字幕 国产视频 | 91视频啪| 国产一区二区久久久 | 欧美日韩一区二区视频在线观看 | 国产一级免费观看视频 | 丰满少妇高潮在线观看 | 香蕉网在线播放 | 中文字幕一区二区三区视频 | 日韩精品视频免费专区在线播放 | 国产精品破处视频 | 国产精品va最新国产精品视频 | 四虎国产免费 | 色婷婷激情五月 | 天堂视频一区 | 夜夜躁日日躁狠狠久久88av | 国产一级免费观看视频 | 日本超碰在线 | 欧美一级久久久久 | 4438全国亚洲精品观看视频 | 国产欧美日韩视频 | 国产原创av在线 | 激情婷婷综合网 | 51精品国自产在线 | 婷婷视频 | 国产一级免费播放 | 狠狠干免费 | 成人污视频在线观看 | 国内精品久久久久影院日本资源 | 高清不卡一区二区在线 | 精品福利国产 | 免费av在线网 | 亚洲国产日本 | 亚洲精品在线资源 | 国产精品嫩草影院99网站 | 国产黄色大片 | 精品电影一区 | 日本三级人妇 | 国产精品久久久久9999 | 亚洲精品毛片一级91精品 | 欧美性生爱| 色婷婷导航 | 久久精品免费播放 | 69av网| 国产黄色精品视频 | 91麻豆网站 | 国产精品免费大片视频 | 免费男女羞羞的视频网站中文字幕 | 久久视频这里只有精品 | 欧美伦理电影一区二区 | 在线а√天堂中文官网 | 日韩精品一区二区三区在线播放 | 中文字幕一区二 | 亚洲日本激情 | 丁香五月网久久综合 | 免费成人黄色片 | www.国产视频 | 久久久久久久久免费视频 | 97精品伊人 | 国产男女免费完整视频 | 一本一本久久a久久精品综合妖精 | 国产午夜精品在线 | 日韩 精品 一区 国产 麻豆 | 久热香蕉视频 | 九九热在线免费观看 | 伊人色播 | 91av久久| 在线免费黄色毛片 | 看国产黄色片 | 狠狠色噜噜狠狠狠合久 | 日韩av不卡在线 | 在线观看日韩国产 | 中文字幕日本电影 | 99视频在线观看一区三区 | 人人揉人人揉人人揉人人揉97 | 日韩欧美国产免费播放 | 国产精品视频免费在线观看 | 91亚洲欧美激情 | 五月婷婷开心中文字幕 | 97在线观看视频国产 | 欧美成人精品欧美一级乱 | 精品成人网 | 91av视频免费观看 | 久久毛片网站 | 在线观看中文字幕网站 | 欧美日韩国产成人 | 一二区精品 | 欧美福利久久 | 成人在线观看网址 | 中文欧美字幕免费 | 区一区二区三区中文字幕 | 97超碰伊人 | 国产最顶级的黄色片在线免费观看 | a级成人毛片 | 91黄色免费网站 | 成人在线观看av | 人人干在线 | 亚洲a资源 | a电影在线观看 | 伊人精品在线 | 五月婷激情 | 亚洲视频 在线观看 | 亚洲一区二区精品3399 | 国产精品一区二区三区免费视频 | 亚洲视频综合在线 | 中文字幕在线观看资源 | 国产欧美在线一区二区三区 | 日韩av不卡在线播放 | 日日躁天天躁 | 婷婷激情5月天 | av在线免费网站 | 91最新视频在线观看 | av片免费播放 | 国产精品爽爽爽 | 国产一区不卡在线 | 国产一区二区三区免费视频 | 色播五月激情综合网 | 免费看高清毛片 | 日本99精品| 97精品国产97久久久久久春色 | 天天干天天干天天色 | 黄色大片av | 天天爽夜夜爽人人爽一区二区 | 黄色avwww| 久久免费视频国产 | 最近中文字幕第一页 | www视频在线播放 | 国产综合激情 | 亚洲一级免费观看 |