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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

给女朋友讲ActiveMQ是啥?

發布時間:2025/3/20 编程问答 53 豆豆
生活随笔 收集整理的這篇文章主要介紹了 给女朋友讲ActiveMQ是啥? 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1 ActiveMQ是啥

ActiveMQ 就是一個消息中間件,市面上現在有很多的消息中間件開源產品,比如,RocketMQ、RabbitMQ、Kafka等。

拿一個簡單的比喻來說,消息中間件就是一個中轉站,在程序中加的一個中轉站,有了這樣一個類似快遞的存儲站點,可以大大的減輕物流的壓力,而對應到程序中,也就是減輕了程序的壓力。

另外不得不說的是,ActiveMQ是遵從 JMS 規范的消息中間件,那么什么是 JMS 規范呢?

JMS 規范

JMS是java的消息服務,JMS的客戶端之間可以通過JMS服務進行異步的消息傳輸。

消息模型

  • Point-to-Point(P2P),點對點
  • P2P模式圖

如上圖,有幾個需要了解的概念,發送者、接收者、消息隊列

在點對點模型中,一般消息由發送者將消息發送到消息隊列中,然后,接收者從消息隊列中消費消息,消息被消費者消費之后,消息就不存在了。

  • Publish/Subscribe(Pub/Sub),發布訂閱模型
  • Pub/Sub模式圖

如上圖,有下面幾個概念,主題、發布者、訂閱者

發布訂閱模型中,發布者通常將消息發布到主題(topic)中,然后,訂閱者通過訂閱主題來消費消息,與 P2P 模型不同的是,發布訂閱模型的消息是可以被多次消費的!

兩種模式的區別

1、P2P在發送者和接收者之間沒有時間上的依賴性,也就是說發送者發送了消息之后,不管接收者有沒有運行,不會影響消息發送到隊列,而Pub/Sub模式有時間上的依賴性,消費者必須先訂閱主題,才能夠消費消息。2、P2P模式的每個消息只能有一個消費者,消費完了消息就不存在了,Pub/Sub模式可以有多個消費者。

2 為什么需要使用消息中間件

到這里我就不得不講一個小故事了!

小明、小李和小白都是在一個項目組的 Java 開發人員,但是呢,他們的團隊比較小,只有幾個開發人員,而他們正在開發一個項目,這個項目比較龐大,所以,項目負責人就考慮到項目進度,給他們每個人都分一個模塊單獨開發,這樣就能夠加快項目的進度了。

然而,萬萬沒有想到的是,當項目開發到一定階段的時候,小明、小李和小白各自負責的模塊都需要項目調用數據了,但是呢,現在問題來了,每次小白小明需要數據的時候,小明總是要改接口來滿足小白的需求,而且還會擔心小明的系統會不會出問題,如果出了問題就調用不了怎么辦?這樣就總是耽誤項目的進度,小李那邊也是出現了這種問題!

于是,小明就想了個辦法,如果在各個模塊之間再加一個模塊,用來處理數據,比如一個隊列來存數據,每次就把數據丟到那個模塊中去,這樣就不用擔心那個問題啦。小明是不是很聰明!

其實,小明沒有做足夠的調查,他說的這個模塊,就是 ActiveMQ 的作用所在啦。

也就是降低模塊與模塊之間的耦合度,達到解耦的目的!

然后,他們又遇到了一個問題,他們在開發一個用戶注冊模塊的時候,是先注冊,然后寫入數據庫,然后再發送郵件或者短信通知用戶,但是,他們發現這樣的系統速度很慢!

后來,他們發現了消息中間件后,改造了一下,變成了下面的模式。

他們也發現了,這就是消息中間件帶來的異步執行的優勢!系統速度杠杠的!

后來,小明、小李和小白開發的系統呢上線了,但是,公司業快速發展,當流量大的時候,系統的數據調用總是負荷不了,出現宕機的問題,沒辦法,只能再改代碼了!

他們靈機一動,前面都用了消息中間件了,但是沒有發現另外一個功能,我們可以加入消息中間件,控制每次消費消息的數量,保證系統不會宕機,剩下的消息在系統流量小的時候再定時執行不就可以了。簡直不要太好!

小明、小李和小白經過這個系統的開發,終于明白了消息中間件的優勢了!

3 安裝使用

3.1 下載

到下面的官網地址下載,包括linux和Windows的不同版本。

  • https://activemq.apache.org/components/classic/download/

3.2 解壓使用

windows使用方法

首先,解壓到一個自己的目錄,ActiveMQ目錄如下;

進入到對應的 bin 目錄;

里面有一個 activemq 的可執行文件,打開 cmd,執行:activemq start

成功啟動了!

關閉;

activemq stop

linux 使用方法

解壓到指定目錄;

sudo tar zxvf activemq-x.x.x-bin.tar.gz

進入到 bin 目錄,執行下面命令;

./activemq start

關閉;

./activemq stop

后臺管理界面

啟動成功之后,可以輸出http://localhost:8161/admin/查看 ActiveMQ 的后臺管理界面,用戶名和密碼都為 admin。

ok,到這里,ActiveMQ的安裝和基本使用應該沒有問題了,接下來,我們使用 ActiveMQ 的 Java API 從一個入門實例開始講起!

4 ActiveMQ入門程序

4.1 前提條件

在開始之前,先申明一下需要的 Java 環境的配置,相關配置自行解決哦!

  • Java JDK1.7 以上
  • Maven 3.0 以上
  • 開發工具 IDEA

4.2 帶你入門

step1:導入 Maven 相關依賴;

<build><plugins><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-compiler-plugin</artifactId><configuration><source>8</source><target>8</target></configuration></plugin></plugins></build><properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><spring.version>4.3.10.RELEASE</spring.version></properties><dependencies><dependency><groupId>org.apache.activemq</groupId><artifactId>activemq-all</artifactId><version>5.15.0</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-jms</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.apache.commons</groupId><artifactId>commons-pool2</artifactId><version>2.6.2</version></dependency><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-test</artifactId><version>4.2.5.RELEASE</version></dependency></dependencies>

step2:創建發送端類;

/*** @ClassName JmsSender* @Description* @Author 歐陽思海* @Date 2019/8/13 16:39* @Version 1.0**/ public class JmsSender {public static void main(String[] args) {ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://localhost:61616");Connection connection = null;try {connection = connectionFactory.createConnection();connection.start();Session session = connection.createSession(Boolean.FALSE, Session.CLIENT_ACKNOWLEDGE);Destination destination = session.createQueue("queue");MessageProducer producer = session.createProducer(destination);TextMessage textMessage = session.createTextMessage("hello activemq");producer.send(textMessage);//session.commit();session.close();} catch (JMSException e) {e.printStackTrace();} finally {if (connection != null) {try {connection.close();} catch (JMSException e) {e.printStackTrace();}}}} }

上面的代碼創建了一個消息發送者,步驟如下:1、創建ActiveMQ實現的JMS規范的實現類ActiveMQConnectionFactory的對象connectionFactory ,并且給定參數ActiveMQ的服務地址;2、由connectionFactory調用方法createConnection創建連接connection對象;3、由connection對象調用createSession方法創建session會話對象;4、有了session對象之后,就可以發送者、隊列或者主題了,這里創建隊列,session.createQueue("queue"),并給定了隊列名稱為queue。5、session對象通過方法createProducer創建生產者,并且創建消息session.createTextMessage("hello activemq");6、生產者調用send的方法發送消息,producer.send(textMessage);

通過上面的步驟就可以將消息發送到隊列中了,接著只要等待消費者消費消息即可,消息消費后,消息就消失了。

通過上面的講解,也將JMS的主要的接口都概括了,包括:ConnectionFactory(連接工廠)、Session(會話)、Connection(連接)

step3:創建消費端類;

/*** @ClassName JmsReceiver* @Description* @Author 歐陽思海* @Date 2019/8/13 16:47* @Version 1.0**/ public class JmsReceiver {public static void main(String[] args) {ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://localhost:61616");Connection connection = null;try {//創建連接connection = connectionFactory.createConnection();connection.start();Session session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);//創建隊列(如果隊列已經存在則不會創建,queue是隊列名稱)//destination表示目的地Destination destination = session.createQueue("queue");//創建消息接收者MessageConsumer consumer = session.createConsumer(destination);TextMessage textMessage = (TextMessage) consumer.receive();System.out.println(textMessage.getText());session.commit();session.close();} catch (JMSException e) {e.printStackTrace();} finally {if (connection != null) {try {connection.close();} catch (JMSException e) {e.printStackTrace();}}}} }

消費者和生產者的差別不大,前面的創建工廠、創建連接、創建會話對象和生產者一樣,區別在于,session.createConsumer(destination)通過session創建消費者,然后,調用receive方法接受消息。

運行發送端,查看后臺管理界面,點擊 Queues 選項,發現有一個入隊的消息,并且沒有出隊列

運行接收端

再查看后臺管理界面,消息被消費了;

5 ActiveMQ整合Spring

這一部分花了挺多時間琢磨的,首先是應為在實際的開發中,我們整合Spring來開發項目是最多的一種方式,這一塊如果可以學透的話,對于項目開發是非常有好處的,出于這個出發點,盡可能的把相關的知識講解的全面一些。

首先,這一部分分為以下三個部分來講解。

  • 不使用 Spring 配置文件方式
  • 使用 Spring 配置文件方式
  • 注解方式(0配置)

5.1 前提條件

  • JDK 1.7 以上
  • Maven 3.0 以上
  • Spring 4.3.1 ,或者以上版本
  • ActiveMQ 5.15.9 目前最新穩定版本
  • 項目結構這次搭建的項目是一個子模塊聚合的項目,結構如下;

    這個聚合的項目分為生產者(Producer)消費者(Consumer)兩個子模塊。

    導入 Maven 依賴

    <properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><spring.version>4.3.10.RELEASE</spring.version></properties><dependencyManagement><dependencies><dependency><groupId>org.apache.activemq</groupId><artifactId>activemq-all</artifactId><version>5.15.9</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-jms</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.apache.commons</groupId><artifactId>commons-pool2</artifactId><version>2.6.2</version></dependency><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-test</artifactId><version>4.2.5.RELEASE</version></dependency></dependencies></dependencyManagement>

    溫馨提示
    由于我這里使用的是子模塊聚合的方式,所以,如果你不是這種方式的項目,直接給出各個依賴的版本在你的項目中即可!

    5.2 不使用 Spring 配置文件方式

    這一節的講解中,我們將采用不使用 Spring 的配置文件的方式,Maven 的相關依賴在上面已經給出,請參考上一節的內容。

    生產者(Producer)

    首先,我們來看一下生產者端,生產者端主要負責發送消息到 Broker 中,發送的目的地(Destination)可以分為隊列(Queue)和主題(Topic),下面,我們就看看如何不采用 Spring 配置文件的方式發送消息

    public static void main(String[] args) {ConnectionFactory cf = new ActiveMQConnectionFactory("tcp://localhost:61616");Connection connection = null;try {connection = cf.createConnection();connection.start();Session session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);Queue destination = session.createQueue("queue2");JmsQueueSenderWithNotXml jmsQueueSender = new JmsQueueSenderWithNotXml();jmsQueueSender.setConnectionFactory(cf);jmsQueueSender.setQueue(destination);jmsQueueSender.simpleSend();jmsQueueSender.sendWithConversion();} catch (JMSException e) {e.printStackTrace();}}private JmsTemplate jmsTemplate;private Queue queue;public void setConnectionFactory(ConnectionFactory cf) {this.jmsTemplate = new JmsTemplate(cf);}public void setQueue(Queue queue) {this.queue = queue;}/** @Author 歐陽思海* @Description 發送簡單消息* @Date 15:45 2019/8/16* @Param []* @return void**/public void simpleSend() {this.jmsTemplate.send(this.queue, new MessageCreator() {public Message createMessage(Session session) throws JMSException {return session.createTextMessage("hello queue world");}});System.out.println("發送成功!");}/** @Author 歐陽思海* @Description 發送map類型的消息* @Date 15:46 2019/8/16* @Param []* @return void**/public void sendWithConversion() {Map map = new HashMap();map.put("Name", "sihai");map.put("Age", new Integer(18));jmsTemplate.convertAndSend("Queue3", map, new MessagePostProcessor() {public Message postProcessMessage(Message message) throws JMSException {message.setIntProperty("num", 189);message.setJMSCorrelationID("00001");return message;}});System.out.println("發送成功!");}

    step1:上面是生產者端的所有代碼示例,在這個示例中,我們首先通過下面的代碼設置好ConnectionFactory 和Queue,并且調用JmsTemplateSpring提供的工具類提供兩個發送消息的方法 。

    private JmsTemplate jmsTemplate;private Queue queue;public void setConnectionFactory(ConnectionFactory cf) {this.jmsTemplate = new JmsTemplate(cf);}public void setQueue(Queue queue) {this.queue = queue;}/** @Author 歐陽思海* @Description 發送簡單消息* @Date 15:45 2019/8/16* @Param []* @return void**/public void simpleSend() {this.jmsTemplate.send(this.queue, new MessageCreator() {public Message createMessage(Session session) throws JMSException {return session.createTextMessage("hello queue world");}});System.out.println("發送成功!");}/** @Author 歐陽思海* @Description 發送map類型的消息* @Date 15:46 2019/8/16* @Param []* @return void**/public void sendWithConversion() {Map map = new HashMap();map.put("Name", "sihai");map.put("Age", new Integer(18));jmsTemplate.convertAndSend("Queue3", map, new MessagePostProcessor() {public Message postProcessMessage(Message message) throws JMSException {message.setIntProperty("num", 189);message.setJMSCorrelationID("00001");return message;}});System.out.println("發送成功!");}

    step2:使用Main方法,設置ConnectionFactory和Queue對象,接著,調用發送方法發送消息。

    public static void main(String[] args) {ConnectionFactory cf = new ActiveMQConnectionFactory("tcp://localhost:61616");Connection connection = null;try {connection = cf.createConnection();connection.start();Session session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);Queue destination = session.createQueue("queue2");JmsQueueSenderWithNotXml jmsQueueSender = new JmsQueueSenderWithNotXml();jmsQueueSender.setConnectionFactory(cf);jmsQueueSender.setQueue(destination);jmsQueueSender.simpleSend();jmsQueueSender.sendWithConversion();} catch (JMSException e) {e.printStackTrace();}}

    step2:接著,我們運行上面的代碼,輸出下面結果,再看一下ActiveMQ的控制臺,看看有沒有消息發送成功。

    發現有一條掛起的消息和入隊列的消息,說明發送成功!

    消費者(Consumer)

    對于消費者,在這一節先不展開講解,可以先參考上面的入門程序的消費端的代碼消費消息,接下來的方式再講解消費端的消費消息。

    5.3 使用 Spring 配置文件方式

    上面一節中,講解了不使用 Spring 配置的方式如何發送消息,主要是想讓大家了解一下其中的原理,這一節中,將使用 Spring 配置的方式講解,這種方式在實際的開發中還是用的比較多的。

    生產者(Producer)

    既然是配置文件的方式,那么,首先,不得不講如何進行xml配置了。

    step1: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:jms="http://www.springframework.org/schema/jms"xsi:schemaLocation="http://www.springframework.org/schema/beans https://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/jms https://www.springframework.org/schema/jms/spring-jms.xsd"><bean id="connectionFactory" class="org.apache.activemq.pool.PooledConnectionFactory" destroy-method="stop"><property name="connectionFactory"><bean class="org.apache.activemq.ActiveMQConnectionFactory"><property name="brokerURL"><value>tcp://localhost:61616</value></property></bean></property><property name="maxConnections" value="50"/></bean><bean id="destination" class="org.apache.activemq.command.ActiveMQQueue"><constructor-arg index="0" value="spring-queue"/></bean><!--<bean id="destinationTopic" class="org.apache.activemq.command.ActiveMQTopic"><constructor-arg index="0" value="spring-topic"/></bean>--><bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate"><property name="connectionFactory" ref="connectionFactory"/><property name="defaultDestination" ref="destination"/><property name="messageConverter"><bean class="org.springframework.jms.support.converter.SimpleMessageConverter"/></property></bean></beans>

    在上面的配置中,首先,需要配置connectionFactory(對應不使用配置的connectionFactory對象),然后,需要配置destination(對應不使用配置的destination),在這里使用的是向隊列發送消息,也可以使用主題(Topic),最后,配置 Spring 提供的jmsTemplate模板類。

    step2:使用Main方法運行

    public static void main(String[] args) {ApplicationContext application = new FileSystemXmlApplicationContext("G:\\ideaproject\\activemq\\Producer\\src\\main\\resources\\service-jms.xml");JmsTemplate jmsTemplate = (JmsTemplate) application.getBean("jmsTemplate");for (int i = 0; i < 10; i++) {int finalI = i;jmsTemplate.send((session) -> {TextMessage textMessage = session.createTextMessage();textMessage.setText("first message" + finalI);return textMessage;});}}

    在上面的代碼中,調用了JmsTemplate的send方法發送消息。運行之后,就成功發送消息了,這種方式還是簡潔不少的。

    溫馨提示
    上面我使用的是FileSystemXmlApplicationContext獲取xml配置文件,除此之外,你也可以使用ClassPathXmlApplicationContext來獲取。

    消費者(Consumer)

    在上一節中,沒有講解消費者,在這一節中,將重點講解。

    step1:首先,我們還是需要配置xml文件

    <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans"xmlns:context="http://www.springframework.org/schema/context"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:amq="http://activemq.apache.org/schema/core"xmlns:jms="http://www.springframework.org/schema/jms"xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans-4.1.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context-4.1.xsdhttp://www.springframework.org/schema/jmshttp://www.springframework.org/schema/jms/spring-jms-4.1.xsdhttp://activemq.apache.org/schema/corehttp://activemq.apache.org/schema/core/activemq-core-5.8.0.xsd"><!--連接工廠--><bean id="connectionFactory" class="org.apache.activemq.pool.PooledConnectionFactory" destroy-method="stop"><property name="connectionFactory"><bean class="org.apache.activemq.ActiveMQConnectionFactory"><property name="brokerURL"><value>tcp://localhost:61616</value></property></bean></property><property name="maxConnections" value="50"/></bean><!--配置隊列--><bean id="destination" class="org.apache.activemq.command.ActiveMQQueue"><constructor-arg index="0" value="queue2"/></bean><!-- 配置主題(topic)--><!-- <bean id="destinationTopic" class="org.apache.activemq.command.ActiveMQTopic"><constructor-arg index="0" value="spring-topic"/></bean>--><!--配置spring的jms模板--><bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate"><property name="connectionFactory" ref="connectionFactory"/><property name="defaultDestination" ref="destination"/><property name="messageConverter"><bean class="org.springframework.jms.support.converter.SimpleMessageConverter"/></property></bean><!-- 消息監聽器 --><!--<bean id="messageListener" class="com.sihai.activemq.listener.MyMessageListener"/>--><bean id="messageListener" class="com.sihai.activemq.listener.MySessionAwareMessageListener"></bean><!--jta事務--><!--<bean id="transactionManager" class="org.springframework.transaction.jta.JtaTransactionManager"/>--><!-- 消息監聽器容器 --><bean id="jmsContainer" class="org.springframework.jms.listener.DefaultMessageListenerContainer"><property name="connectionFactory" ref="connectionFactory"/><property name="destination" ref="destination"/><property name="messageListener" ref="messageListener"/><!--配置本地資源事務--><!--<property name="sessionTransacted" value="true"/>--><!--配置jta事務--><!--<property name="transactionManager" ref="transactionManager"/>--></bean><!--<!– 監聽注解支持 –><jms:annotation-driven />--></beans>

    最前面的配置和生產者是一樣的,需要配置connectionFactory(對應不使用配置的connectionFactory對象),然后,需要配置destination(對應不使用配置的destination)。

    區別在于,消費者端需要配置一個消息監聽器容器,如下。

    <!-- 消息監聽器 --><!--<bean id="messageListener" class="com.sihai.activemq.listener.MyMessageListener"/>--><bean id="messageListener" class="com.sihai.activemq.listener.MySessionAwareMessageListener"></bean><!--jta事務--><!--<bean id="transactionManager" class="org.springframework.transaction.jta.JtaTransactionManager"/>--><!-- 消息監聽器容器 --><bean id="jmsContainer" class="org.springframework.jms.listener.DefaultMessageListenerContainer"><property name="connectionFactory" ref="connectionFactory"/><property name="destination" ref="destination"/><property name="messageListener" ref="messageListener"/><!--配置本地資源事務--><!--<property name="sessionTransacted" value="true"/>--><!--配置jta事務--><!--<property name="transactionManager" ref="transactionManager"/>--></bean>

    那么這個怎么配置呢?請接著看。

    step2:消息監聽器容器配置首先,我們需要寫一個類,實現MessageListener接口,然后實現一個名為onMessage的方法,通過這個方法就可以監聽是否有消息,有消息就消費

    /*** @ClassName MyMessageListener* @Description 消息消費監聽器實現* @Author 歐陽思海* @Date 2019/8/13 20:39* @Version 1.0**/ @Component public class MyMessageListener implements MessageListener {@Overridepublic void onMessage(Message message) {if (message instanceof TextMessage) {try {System.out.println(((TextMessage) message).getText());}catch (JMSException ex) {throw new RuntimeException(ex);}}else {throw new IllegalArgumentException("Message must be of type TextMessage");}} }

    如此,配置就完成了。

    step3:啟動spring容器,運行。

    /** @Author 歐陽思海* @Description xml配置方式獲取消息* @Date 18:09 2019/8/16* @Param []* @return void**/@Testpublic void test_01() throws IOException {ClassPathXmlApplicationContext application = new ClassPathXmlApplicationContext("G:\\ideaproject\\activemq\\Consumer\\src\\main\\resources\\service-jms.xml");/*JmsTemplate jmsTemplate = (JmsTemplate) application.getBean("jmsTemplate");String msg = (String) jmsTemplate.receiveAndConvert();System.out.println(msg);*/System.in.read();}

    在上面的代碼中,System.in.read(),這個作用就是一直等待,有消息就消費。

    step4:開啟消息監聽器事務在消息處理的過程中是可以開啟事務的,如果出現處理失敗的情況,就會回滾。在消息監聽容器當中可以配置一個屬性是sessionTransacted的本地事務,如果value為true,就代表開啟本地事務。具體配置如下:

    <!-- 消息監聽器容器 --><bean id="jmsContainer" class="org.springframework.jms.listener.DefaultMessageListenerContainer"><property name="connectionFactory" ref="connectionFactory"/><property name="destination" ref="destination"/><property name="messageListener" ref="messageListener"/><!--配置本地資源事務--><property name="sessionTransacted" value="true"/> </bean>

    消息監聽器容器

    上面的消費者的講解中,其實,最重要的就是消息監聽器容器配置了,這一部分,我們就詳細的講解一下消息監聽器容器的配置方法。

    1 實現MessageListener接口這種方式就是上面的實例使用的方式,先看看這個接口。

    public interface MessageListener {void onMessage(Message var1); }

    這個接口很簡單,只有一個方法onMessage,通過拿到Message參數讀取消息,這里就不再多說了。

    2 實現SessionAwareMessageListener接口這個接口平時很少用到,但是,其實是有這個接口可以實現的,這個接口和上面的MessageListener接口有點不一樣,這個接口是Spring提供的。

    public interface SessionAwareMessageListener<M extends Message> {void onMessage(M var1, Session var2) throws JMSException; }

    另外,你可以看到,這個接口提供的是一個泛型接口,可以是M extends Message這個類型,同時,實現的方式onMessage,還多了一個Session參數,可以在獲取消息的同時處理Session。

    使用實例

    /*** @ClassName MySessionAwareMessageListener* @Description 實現SessionAwareMessageListener的消息監聽器* @Author 歐陽思海* @Date 2019/8/16 16:02* @Version 1.0**/ public class MySessionAwareMessageListener implements SessionAwareMessageListener {@Overridepublic void onMessage(Message message, Session session) throws JMSException {if (message instanceof TextMessage) {try {System.out.println(((TextMessage) message).getText());}catch (JMSException ex) {throw new RuntimeException(ex);}}else {throw new IllegalArgumentException("Message must be of type TextMessage");}} }

    5.4 注解方式(0配置)

    前面已經介紹了兩種方式,分別是不使用xml配置方式使用xml配置的方式,但是,由于現在微服務的興起,約定優于配置是現在的一種趨勢,所以,在這一節中,我們使用注解的方式來處理。

    生產者(Producer)

    由于使用注解的方式,所以,我們不再需要xml配置文件了,但是,我們可以參照上面的xml的配置方式來配置注解的方式。

    step1:首先,我們需要一個 Java 配置類,如下;

    /*** @ClassName ProducerConfig* @Description 不用xml的配置類* @Author 歐陽思海* @Date 2019/8/16 17:41* @Version 1.0**/ @Configuration public class ProducerConfig {@Bean//配置ConnectionFactory用于生成connectionpublic ActiveMQConnectionFactory connectionFactory() {ActiveMQConnectionFactory activeMQConnectionFactory= new ActiveMQConnectionFactory("tcp://localhost:61616");return activeMQConnectionFactory;}@Bean//注冊SingleConnectionFactory,這個spring的一個包裝工廠 用于管理真正的ConnectionFactorypublic SingleConnectionFactory singleConnectionFactory(ActiveMQConnectionFactory activeMQconnectionFactory) {SingleConnectionFactory connectionFactory = new SingleConnectionFactory();//設置目標工廠connectionFactory.setTargetConnectionFactory(activeMQconnectionFactory);return connectionFactory;}@Bean//配置生產者,jmsTemplatepublic JmsTemplate jmsTemplate(SingleConnectionFactory connectionFactory) {JmsTemplate jmsTemplate = new JmsTemplate();jmsTemplate.setConnectionFactory(connectionFactory);return jmsTemplate;}/*** 配置隊列目的的: 根據測試需要配置其中一個* 1.隊列 點對點 queue* 2.主題 一對多 topic*/@Bean //public ActiveMQQueue queueDestination() {ActiveMQQueue activeMQQueue = new ActiveMQQueue("queue-anno");return activeMQQueue;}@Beanpublic ActiveMQTopic topicDestination() {ActiveMQTopic activeMQTopic = new ActiveMQTopic("topic-anno");return activeMQTopic;} }

    上面的配置的每一個方法就對應xml配置的每一個節點,對應起來配置會比較簡單,每一個方法都使用了@Bean這個注解,類上使用Configuration,將這些配置加入到 spring 容器中。

    step2:啟動 spring 容器,發送消息;

    /*** @ClassName JmsSenderWithAnnotation* @Description 注解發送方式* @Author 歐陽思海* @Date 2019/8/16 18:04* @Version 1.0**/ public class JmsSenderWithAnnotation {/** @Author 歐陽思海* @Description 測試點對點* @Date 18:05 2019/8/16* @Param []* @return void**/@Testpublic void testActiveMqAnnotation() {AnnotationConfigApplicationContext aContext =new AnnotationConfigApplicationContext(ProducerConfig.class);//獲得發送者的模板對象JmsTemplate jmsTemplate = aContext.getBean(JmsTemplate.class);Destination bean = (Destination) aContext.getBean("queueDestination");//發送消息jmsTemplate.send(bean, new MessageCreator() {@Overridepublic Message createMessage(Session session) throws JMSException {TextMessage message = session.createTextMessage();message.setText("activemq message for queue");return message;}});}/** @Author 歐陽思海* @Description 測試topic發送* @Date 18:06 2019/8/16* @Param []* @return void**/@Testpublic void testActiveMqAnnotation2() {AnnotationConfigApplicationContext aContext =new AnnotationConfigApplicationContext(ProducerConfig.class);//獲得發送者的模板對象JmsTemplate jmsTemplate = aContext.getBean(JmsTemplate.class);Destination bean = (Destination) aContext.getBean("topicDestination");//發送消息jmsTemplate.send(bean, new MessageCreator() {@Overridepublic Message createMessage(Session session) throws JMSException {TextMessage message = session.createTextMessage();message.setText("activemq message for topic");return message;}});} }

    分別運行這兩個測試,查看ActiveMQ控制臺,發現Queue和Topic都有一條消息發送成功;

    消費者(Consumer)

    消費者的大概也差不多,跟xml的配置一樣,多的也是消息監聽容器的配置,來看看;

    step1:首先,Java 配置類

    *** @ClassName ConsumerConfig* @Description 不用xml的配置類* @Author 歐陽思海* @Date 2019/8/16 17:44* @Version 1.0**/ @ComponentScan(basePackages = {"com.sihai"}) @EnableJms @Configuration public class ConsumerConfig {@Bean//配置ConnectionFactory用于生成connectionpublic ActiveMQConnectionFactory connectionFactory() {ActiveMQConnectionFactory activeMQConnectionFactory= new ActiveMQConnectionFactory("tcp://localhost:61616");return activeMQConnectionFactory;}@Bean//注冊SingleConnectionFactory,這個spring的一個包裝工廠 用于管理真正的ConnectionFactorypublic SingleConnectionFactory singleConnectionFactory(ActiveMQConnectionFactory activeMQconnectionFactory) {SingleConnectionFactory connectionFactory = new SingleConnectionFactory();//設置目標工廠connectionFactory.setTargetConnectionFactory(activeMQconnectionFactory);return connectionFactory;}/*在xml當中的如下配置 效果相同* <bean class="org.springframework.jms.listener.DefaultMessageListenerContainer">* <property name="connectionFactory" ref="connectionFactory" />* <property name="destination" ref="topicDestination" />* <property name="messageListener" ref="itemListenerMessage" />* </bean>**/@Beanpublic DefaultMessageListenerContainer jmsListenerContainerFactory(SingleConnectionFactory singleConnectionFactory, MyMessageListener myMessageListener, Destination destination) {//創建容器DefaultMessageListenerContainer jmsContainer = new DefaultMessageListenerContainer();//設置監聽器jmsContainer.setMessageListener(myMessageListener);//設置連接工廠jmsContainer.setConnectionFactory(singleConnectionFactory);//設置監聽目的地的名字/也可以直接設置對象目的地jmsContainer.setDestination(destination);return jmsContainer;}/*** 1.隊列 點對點 queue* 2.主題 一對多 topic*/@Beanpublic ActiveMQQueue queueDestination() {ActiveMQQueue activeMQQueue = new ActiveMQQueue("queue-anno");return activeMQQueue;}/*@Beanpublic ActiveMQTopic topicDestination() {ActiveMQTopic activeMQTopic = new ActiveMQTopic("topic-anno");return activeMQTopic;}*/ }

    其中只有一個消息監聽容器的配置是和生產者的配置不同的消息監聽容器的配置需要配置消息監聽器、連接工廠和目的地(Destination)

    /*在xml當中的如下配置 效果相同* <bean class="org.springframework.jms.listener.DefaultMessageListenerContainer">* <property name="connectionFactory" ref="connectionFactory" />* <property name="destination" ref="topicDestination" />* <property name="messageListener" ref="itemListenerMessage" />* </bean>**/@Beanpublic DefaultMessageListenerContainer jmsListenerContainerFactory(SingleConnectionFactory singleConnectionFactory, MyMessageListener myMessageListener, Destination destination) {//創建容器DefaultMessageListenerContainer jmsContainer = new DefaultMessageListenerContainer();//設置監聽器jmsContainer.setMessageListener(myMessageListener);//設置連接工廠jmsContainer.setConnectionFactory(singleConnectionFactory);//設置監聽目的地的名字/也可以直接設置對象目的地jmsContainer.setDestination(destination);return jmsContainer;}

    step2:消息監聽器

    /*** @ClassName MyMessageListener* @Description 消息消費監聽器實現* @Author 歐陽思海* @Date 2019/8/13 20:39* @Version 1.0**/ @Component public class MyMessageListener implements MessageListener {@Overridepublic void onMessage(Message message) {if (message instanceof TextMessage) {try {System.out.println(((TextMessage) message).getText());}catch (JMSException ex) {throw new RuntimeException(ex);}}else {throw new IllegalArgumentException("Message must be of type TextMessage");}} }

    這個前面已經講過了,這里就不再累贅了,但是,這里我需要講的是消息監聽器注解方式的配置,如下。

    step3:消息監聽器注解方式的配置方法

    /*** @ClassName JmsAnnotation* @Description 注解方式監聽* @Author 歐陽思海* @Date 2019/8/16 17:01* @Version 1.0**/ @Component @EnableJms public class JmsAnnotation {@JmsListener(destination = "queue-anno")public void onMessage(Message message) {if (message instanceof TextMessage) {try {System.out.println(((TextMessage) message).getText());}catch (JMSException ex) {throw new RuntimeException(ex);}}else {throw new IllegalArgumentException("Message must be of type TextMessage");}} }

    你會發現,在消息監聽器的類上面需要兩個配置@Component和@EnableJms,用于標記這是一個消息監聽器,另外,在onMessage方法上,需要一個@JmsListener(destination = "queue-anno")注解,可以標記需要哪個destination 。

    注意:如果采用注解的消息監聽,那么需要修改Java類的消息監聽的容器的配置,否則會出現問題

    step4:消息監聽容器配置更改

    /*在xml當中的如下配置 效果相同* <bean class="org.springframework.jms.listener.DefaultMessageListenerContainer">* <property name="connectionFactory" ref="connectionFactory" />* <property name="destination" ref="topicDestination" />* <property name="messageListener" ref="itemListenerMessage" />* </bean>**/@Beanpublic DefaultMessageListenerContainer jmsListenerContainerFactory(SingleConnectionFactory singleConnectionFactory, MyMessageListener myMessageListener, Destination destination) {//創建容器DefaultMessageListenerContainer jmsContainer = new DefaultMessageListenerContainer();//設置監聽器jmsContainer.setMessageListener(myMessageListener);//設置連接工廠jmsContainer.setConnectionFactory(singleConnectionFactory);//設置監聽目的地的名字/也可以直接設置對象目的地jmsContainer.setDestination(destination);return jmsContainer;}

    改為

    @Beanpublic DefaultJmsListenerContainerFactory jmsListenerContainerFactory() {DefaultJmsListenerContainerFactory factory = new DefaultJmsListenerContainerFactory();factory.setConnectionFactory(connectionFactory()); // factory.setDestinationResolver(destinationResolver());factory.setSessionTransacted(true);factory.setConcurrency("3-10");return factory;}

    上面的修改會發現,實現接口的監聽器使用的是DefaultMessageListenerContainer,而注解的方式使用的是DefaultJmsListenerContainerFactory,所以,這里需要特別注意。

    此時,消息監聽器是注解的方式的Java配置類就是下面這樣的。

    /*** @ClassName ConsumerConfig* @Description 不用xml的配置類* @Author 歐陽思海* @Date 2019/8/16 17:44* @Version 1.0**/ @ComponentScan(basePackages = {"com.sihai"}) @EnableJms @Configuration public class ConsumerConfig {@Bean//配置ConnectionFactory用于生成connectionpublic ActiveMQConnectionFactory connectionFactory() {ActiveMQConnectionFactory activeMQConnectionFactory= new ActiveMQConnectionFactory("tcp://localhost:61616");return activeMQConnectionFactory;}@Bean//注冊SingleConnectionFactory,這個spring的一個包裝工廠 用于管理真正的ConnectionFactorypublic SingleConnectionFactory singleConnectionFactory(ActiveMQConnectionFactory activeMQconnectionFactory) {SingleConnectionFactory connectionFactory = new SingleConnectionFactory();//設置目標工廠connectionFactory.setTargetConnectionFactory(activeMQconnectionFactory);return connectionFactory;}@Beanpublic DefaultJmsListenerContainerFactory jmsListenerContainerFactory() {DefaultJmsListenerContainerFactory factory = new DefaultJmsListenerContainerFactory();factory.setConnectionFactory(connectionFactory()); // factory.setDestinationResolver(destinationResolver());factory.setSessionTransacted(true);factory.setConcurrency("3-10");return factory;}/*** 1.隊列 點對點 queue* 2.主題 一對多 topic*/@Beanpublic ActiveMQQueue queueDestination() {ActiveMQQueue activeMQQueue = new ActiveMQQueue("queue-anno");return activeMQQueue;}/*@Beanpublic ActiveMQTopic topicDestination() {ActiveMQTopic activeMQTopic = new ActiveMQTopic("topic-anno");return activeMQTopic;}*/ }

    step5:啟動容器,消費消息

    /*** @ClassName SpringSender* @Description* @Author 歐陽思海* @Date 2019/8/13 17:22* @Version 1.0**/ public class SpringReceiver {/** @Author 歐陽思海* @Description xml配置方式獲取消息* @Date 18:09 2019/8/16* @Param []* @return void**/@Testpublic void test_01() throws IOException {ApplicationContext application = new FileSystemXmlApplicationContext("G:\\ideaproject\\activemq\\Consumer\\src\\main\\resources\\service-jms.xml");/*JmsTemplate jmsTemplate = (JmsTemplate) application.getBean("jmsTemplate");String msg = (String) jmsTemplate.receiveAndConvert();System.out.println(msg);*/System.in.read();}/** @Author 歐陽思海* @Description 注解方式獲取消息* @Date 18:10 2019/8/16* @Param []* @return void**/@Testpublic void test_02() throws IOException {AnnotationConfigApplicationContext aContext =new AnnotationConfigApplicationContext(ConsumerConfig.class);/*JmsTemplate jmsTemplate = (JmsTemplate) application.getBean("jmsTemplate");String msg = (String) jmsTemplate.receiveAndConvert();System.out.println(msg);*/System.in.read();} }

    終于,到這里把ActiveMQ整合Spring的全部內容就講述完結了,這一部分講了三個部分,分別是:

    • 不使用 Spring 配置文件方式
    • 使用 Spring 配置文件方式
    • 注解方式(0配置)

    6 ActiveMQ支持的傳輸協議

    6.1 默認協議介紹

    在ActiveMQ中支持的協議還是挺多的,這也是ActiveMQ的一個特點之一,例如,默認支持AMQP、MQTT、OpenWire、STOMP、WebSocket,這些默認的協議的配置都是在activemq.xml配置文件中的。

    <transportConnectors><!-- DOS protection, limit concurrent connections to 1000 and frame size to 100MB --><transportConnector name="openwire" uri="tcp://0.0.0.0:61616?maximumConnections=1000&wireFormat.maxFrameSize=104857600"/><transportConnector name="amqp" uri="amqp://0.0.0.0:5672?maximumConnections=1000&wireFormat.maxFrameSize=104857600"/><transportConnector name="stomp" uri="stomp://0.0.0.0:61613?maximumConnections=1000&wireFormat.maxFrameSize=104857600"/><transportConnector name="mqtt" uri="mqtt://0.0.0.0:1883?maximumConnections=1000&wireFormat.maxFrameSize=104857600"/><transportConnector name="ws" uri="ws://0.0.0.0:61614?maximumConnections=1000&wireFormat.maxFrameSize=104857600"/></transportConnectors>

    注意:上面的每種協議的端口都必須是不一樣的。

    6.2 其他協議

    除了上面的協議外,還支持這些協議:TCP、UDP 、NIO、SSL、Http(s)、vm

    那么如何使用這些協議呢?

    只需要在上面的activemq.xml配置文件中的transportConnectors節點添加就可以,例如,添加 nio協議

    <transportConnectors><!-- 新增協議 --><transportConnector name="nio" uri="nio://0.0.0.0:61619"/><!-- DOS protection, limit concurrent connections to 1000 and frame size to 100MB --><transportConnector name="openwire" uri="tcp://0.0.0.0:61616?maximumConnections=1000&wireFormat.maxFrameSize=104857600"/><transportConnector name="amqp" uri="amqp://0.0.0.0:5672?maximumConnections=1000&wireFormat.maxFrameSize=104857600"/><transportConnector name="stomp" uri="stomp://0.0.0.0:61613?maximumConnections=1000&wireFormat.maxFrameSize=104857600"/><transportConnector name="mqtt" uri="mqtt://0.0.0.0:1883?maximumConnections=1000&wireFormat.maxFrameSize=104857600"/><transportConnector name="ws" uri="ws://0.0.0.0:61614?maximumConnections=1000&wireFormat.maxFrameSize=104857600"/></transportConnectors>

    其他協議的添加方法也是相似的!

    6.3 簡化配置

    在ActiveMQ中還有一種更加簡單的配置方法,在uri中可以使用 auto 來簡化配置,ActiveMQ將監聽器端口的消息自動適配相應的協議。

    <transportConnector name="auto" uri="auto://0.0.0.0:61619"/>

    如果需要更加安全,還可以在此基礎上添加ssl協議。

    <transportConnector name="auto+ssl" uri="auto+ssl://0.0.0.0:61619"/>

    如果還想要提高傳輸的性能,可以配合上面的nio協議,提高網絡性能。

    <transportConnector name="auto+nio" uri="auto+nio://0.0.0.0:61619"/>

    7 ActiveMQ的持久化存儲機制

    持久化的作用是什么呢?

    作用主要是為避免系統以外宕機而導致消息丟失,在ActiveMQ中支持多種持久化機制,比如,JDBC、AMQ、KahaDB、LevelDB,下面簡單介紹一下這幾種機制。

    • JDBC:基于數據庫存儲的方式,可以存儲在Mysql等數據庫中,這種機制的性能瓶頸在Mysql等數據庫,所以其性能是不太好的。

    配置方法在activemq.xml配置文件中配置,這里我們使用Mysql進行配置。

    step1:修改persistenceAdapter節點

    <persistenceAdapter><jdbcPersistenceAdapter dataSource="#mysqlDataSource" createTablesOnStartup="true"/><!--<kahaDB directory="${activemq.data}/kahadb"/>--></persistenceAdapter>

    其中,dataSource="#mysqlDataSource"是數據源引用。

    step2:配置Mysql數據源

    <bean id="mysqlDataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"><property name="driverClassName" value="com.mysql.jdbc.Driver"/><property name="url" value="jdbc:mysql://localhost:3306/test"/><property name="username" value="root"/><property name="password" value="123456"/></bean>

    這就是spring的配置方式。

    step3:導入數據庫連接池、驅動等Jar包在ActiveMQ的目錄中有一個lib目錄,是存放jar包的目錄。

    將下面幾個Jar放入。

    step4:啟動ActiveMQ,查看結果啟動之后,打開mysql數據庫,發現生成了三張數據表。這樣就成功了,每次生成消息之后,就會將消息的信息存儲到這三張表中,消費之后,再刪除信息。

    • AMQ:基于文件存儲,這種方式會把消息寫入日志文件,并且是順序存儲方式,這種方式比JDBC方式要好,缺點是:會為每個Destination創建索引,占用大量磁盤空間。

    配置方法在activemq.xml配置文件中配置,更加詳細參數請參考:https://activemq.apache.org/amq-message-store。

    <broker brokerName="broker" persistent="true" useShutdownHook="false"><persistenceAdapter><amqPersistenceAdapter directory="數據存儲目錄" maxFileLength="32mb"/></persistenceAdapter></broker>

    • KahaDB:這個5.4版本之后出現的默認的持久化方式,與AMQ很相似,不同的是只為Destination創建一個索引。

    配置方法在activemq.xml配置文件中配置,更加詳細參數請參考:https://activemq.apache.org/kahadb。

    <broker brokerName="broker"><persistenceAdapter><kahaDB directory="數據存儲目錄" journalMaxFileLength="32mb"/></persistenceAdapter></broker>

    • LevelDB:5.6版本后推出的新的持久化方式。這種比KahaDB更快,跟KahaDB類似,但是不是用自定義B數實現。但是需要注意的是,目前官網已經不推薦使用這種方式,而是推薦使用KahaDB。

    配置方法在activemq.xml配置文件中配置,更加詳細的參數請參考:https://activemq.apache.org/leveldb-store。

    <broker brokerName="broker" ... >...<persistenceAdapter><levelDB directory="數據存儲目錄"/></persistenceAdapter>...</broker>

    8 ActiveMQ網絡連接支持

    Broker的網絡配置主要有三種配置方法,分別是靜態配置、動態配置和主從配置。

    8.1 靜態配置

    靜態傳輸提供了一種硬編碼機制,可以使用URI列表發現其他連接。使用此發現機制的連接將嘗試連接到列表中的所有URI,直到成功為止。

    在activemq.xml配置文件中配置。

    <networkConnectors><networkConnector uri="static:(tcp://localhoat:61616)"/></networkConnectors>

    配置語法

    static:(uri1,uri2,uri3,…)?options

    舉例

    static:(tcp://localhost:61616,tcp://remotehost:61617?trace=false,vm://localbroker)?initialReconnectDelay=100

    uri的屬性說明

    8.2 動態配置

    在activemq.xml配置文件中配置。

    <networkConnectors><networkConnector uri="multicast://default"/></networkConnectors>

    8.3 主從配置

    Master-Slave模型是非常常見的,主從模型主要是為了防止一個網絡節點出現問題而提出的,提高了穩定性。

    在ActiveMQ中也是可配置的,我們可以在activemq.xml配置文件中進行相關配置。

    <networkConnectors><networkConnector uri="masterslave:(tcp://host1:61616,tcp://host2:61616,tcp://..)"/> </networkConnectors>

    注意:Master-Slave方式的第一個url需要是master,其他是slave。

    另外,NetworkConnector 節點還有其他屬性可以配置,具體詳情可以查看官網:https://activemq.apache.org/networks-of-brokers。

    8.4 容錯的客戶端連接方法

    在前面的客戶端連接ActiveMQ的時候只是使用一個簡單的url進行連接。

    ActiveMQConnectionFactory activeMQConnectionFactory= new ActiveMQConnectionFactory("tcp://localhost:61616");

    但是,這種方式會出現一個問題,一旦這臺ActiveMQ宕機了,就連接不上了,所以,有另外一種容錯的方式,當一臺出現宕機,可以連接上其他的機器,這樣就不會出現問題了。

    ActiveMQConnectionFactory activeMQConnectionFactory= new ActiveMQConnectionFactory("failover:(tcp://localhost:61616,tcp://remotehost:61616)");

    其他屬性參數請參考:https://activemq.apache.org/failover-transport-reference。

    文章有不當之處,歡迎指正,如果喜歡微信閱讀,你也可以關注我的微信公眾號:好好學java,獲取優質學習資源。

    《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀

    總結

    以上是生活随笔為你收集整理的给女朋友讲ActiveMQ是啥?的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    www国产亚洲精品久久网站 | 久久久久网站 | 激情久久小说 | 免费国产在线精品 | 超级碰视频 | 久久免费视频在线观看 | 一区二区精品久久 | 久草99| 久久激情五月激情 | 九草在线视频 | 综合色天天 | 亚洲成人资源在线 | 国产色综合 | 日本一区二区高清不卡 | 97品白浆高清久久久久久 | 2019中文 | 国产香蕉视频在线播放 | 在线看毛片网站 | 日韩中文在线视频 | 国产精品高清一区二区三区 | 久久 国产一区 | 91.精品高清在线观看 | av在线一级| 啪啪免费视频网站 | 天天爱天天操天天爽 | 国产精品视频久久久 | 国产亚洲精品久久久久久 | 日本精品一区二区三区在线观看 | 不卡的av电影在线观看 | 久免费 | 在线观看国产91 | 久久撸在线视频 | 手机看片99 | 国内精品久久久久影院一蜜桃 | 国产探花 | 久久视频在线免费观看 | 亚洲精区二区三区四区麻豆 | 精品国内 | 99久久精 | 91精品国产乱码 | 国产精品久99 | 久草在线手机视频 | 国产高清在线免费观看 | 一区二区三区在线电影 | 国产不卡视频在线播放 | 亚洲精品美女 | 在线国产不卡 | 91在线永久| 亚洲成人资源 | 日韩视频一区二区在线观看 | 91传媒在线看 | 欧美国产日韩一区二区三区 | 激情婷婷亚洲 | 91av视频导航 | 久久九九视频 | 激情久久综合 | 一区二区三区高清不卡 | 欧美日韩精品区 | 欧美激情视频一区二区三区免费 | 手机av片 | 国产一区免费在线 | 天天色天天草天天射 | 啪一啪在线 | 国产精品黄网站在线观看 | 色www永久免费 | 欧美日韩一区二区三区在线观看视频 | 深夜国产在线 | 日本精a在线观看 | 久草线| 人人射人人射 | 国产精品去看片 | 黄视频色网站 | 在线播放视频一区 | 黄色av一级| 91插插插免费视频 | 日本中文字幕在线观看 | 免费男女羞羞的视频网站中文字幕 | 免费又黄又爽的视频 | 成人va视频 | 亚州天堂| 在线观看国产一区二区 | 成人啪啪18免费游戏链接 | 99欧美精品| 久久综合久久综合这里只有精品 | 久久综合狠狠 | 天天射天天爽 | 精选久久 | 黄色免费网战 | 精品黄色片 | 欧美日韩一区二区视频在线观看 | 在线精品亚洲一区二区 | 亚洲黄色免费电影 | 狠狠色狠狠色合久久伊人 | 日本成人黄色片 | 日韩一区精品 | 日本性生活一级片 | 六月色丁香 | 国产精品麻豆三级一区视频 | 一级一片免费看 | 国产一区二区三精品久久久无广告 | 国产精品久久久久影视 | 黄色不卡av| 精品日韩在线一区 | 欧美视频在线二区 | 日韩有码网站 | 青青河边草手机免费 | 欧美综合色在线图区 | 国产高清视频在线播放一区 | 久久精品亚洲一区二区三区观看模式 | 国产精品剧情 | 国内精品久久天天躁人人爽 | 黄色软件在线看 | av黄色免费在线观看 | 福利视频一区二区 | 四虎影视精品成人 | 欧美日韩视频在线观看一区二区 | 九九激情视频 | 国产精品成人一区二区三区 | 最新日本中文字幕 | 日本99热 | a色视频| 9i看片成人免费看片 | av五月婷婷 | 久久激情视频 久久 | 97香蕉久久国产在线观看 | 91人人爽人人爽人人精88v | 九色精品 | 国产精品久久久久久久久久久久午夜 | 在线有码中文字幕 | 欧美激情视频免费看 | 亚洲一级免费观看 | 玖玖玖精品 | 久久久久久久免费观看 | 国产精品一区二区三区在线 | 久久毛片视频 | 久久女教师 | 一区二区av | 成人亚洲综合 | 1000部国产精品成人观看 | 精品专区一区二区 | 亚洲人成在线观看 | 丁香婷婷综合色啪 | www.888.av| 91九色porny蝌蚪视频 | 亚洲精品乱码久久久久久高潮 | 国产精品久久久久一区 | 综合色播 | 天天草夜夜 | 国产精品久久久久9999吃药 | 中文字幕一区在线观看视频 | www色com| 久久人人爽人人爽人人片av软件 | 天天操天天干天天综合网 | 在线观看精品一区 | 日本中文字幕在线观看 | 在线观看免费黄视频 | 亚洲精品成人免费 | av在线播放国产 | 亚洲午夜精品在线观看 | 免费成人黄色av | 免费看一级 | 日日干夜夜爱 | 91精选在线观看 | 国产一区二区精品在线 | 福利网址在线观看 | 久久久久久久久免费视频 | 午夜视频99 | 中文字幕欧美三区 | 国产成人一区在线 | 97超碰免费在线观看 | 2019天天干天天色 | 夜夜骑天天操 | 久久99在线观看 | 亚洲精品欧美视频 | 久久99欧美 | 亚洲人成人在线 | 亚洲影院色 | 五月婷婷操 | 97视频在线播放 | 久久一区二区免费视频 | 中文字幕免费不卡视频 | 热久久国产 | 国产高清绿奴videos | 久草观看视频 | 人人射人人爽 | 激情在线网站 | 久久观看 | 日韩两性视频 | 狠狠干免费 | 中文字幕在线字幕中文 | 丁香av| 一区久久久 | 97超级碰碰碰视频在线观看 | 日本色小说视频 | 国产一区二区三区在线 | 国产一区二区三区午夜 | 草久在线观看 | 天天射天天拍 | 黄色激情网址 | 99免费视频 | av综合在线观看 | 天天躁日日躁狠狠躁av中文 | 国产网站在线免费观看 | 免费网站观看www在线观看 | 日韩区欠美精品av视频 | 日本在线视频一区二区三区 | 天天鲁天天干天天射 | 国产在线视频一区二区三区 | 97视频在线观看播放 | 亚洲一区日韩精品 | 狠狠地日| 不卡的av电影在线观看 | 久久精品视频免费 | 久久国产热视频 | 国产免费xvideos视频入口 | 国产精品一区二区久久精品 | 中文字幕在线不卡国产视频 | 国产美女免费观看 | 在线成人欧美 | 中文字幕一区二区三区四区视频 | 免费看污在线观看 | 亚洲国产中文字幕在线观看 | av免费试看 | 成人av免费在线 | 麻豆网站免费观看 | 国产精品成人免费一区久久羞羞 | 91系列在线观看 | 国产香蕉视频在线播放 | 亚洲 欧美 91 | 在线免费高清视频 | 久久五月网 | 午夜精品剧场 | 久久精品亚洲一区二区三区观看模式 | 91精品久久久久久综合乱菊 | a电影免费看 | 久久免费成人网 | 91手机电影 | 久久草在线免费 | 欧美日韩不卡在线视频 | 天天操天天综合网 | 国产亚洲视频在线免费观看 | 久久久久久久久久久久亚洲 | 91av社区| 国产精品99久久久久久小说 | 又黄又刺激的网站 | 久久深夜 | 99精品国产高清在线观看 | 亚洲热久久| 久久精品99国产精品酒店日本 | 成人在线免费观看视视频 | 国产九九精品视频 | 一区二区 不卡 | 91亚洲精品在线 | 国产免费久久av | 婷婷草 | 91在线看黄 | 国产一区二区在线看 | 久久久久一区二区三区四区 | 青青色影院 | 91亚洲国产成人久久精品网站 | 在线观影网站 | 亚洲日韩欧美一区二区在线 | 九月婷婷综合网 | 久久人人爽人人爽人人 | 久久99国产精品免费网站 | 日韩毛片在线播放 | 成年人在线免费看视频 | 亚洲一区二区精品在线 | 国产麻豆精品一区 | 亚州精品一二三区 | 欧美精品久 | 免费人成在线观看 | 久久久国产精品麻豆 | 日韩在线免费不卡 | 亚洲欧洲精品一区 | 波多野结衣电影久久 | 欧美精品久久久久久久久免 | av福利资源 | 国产日产精品一区二区三区四区的观看方式 | 免费看片网页 | 91视频久久久久久 | 精品国产一区二 | 国产在线视频不卡 | 欧美日韩视频观看 | 一区二区三区中文字幕在线 | 西西www444| 97成人超碰 | 国产一二区在线观看 | 91av视频免费在线观看 | 黄色性av | 成人午夜影院 | 免费观看性生交大片3 | 久久 精品一区 | 午夜精品福利在线 | 国产精品一区一区三区 | 黄网站免费久久 | 天天狠狠干 | 久久久久久久久久久精 | 永久免费精品视频 | 超碰国产人人 | 久久国产剧场电影 | 久久亚洲福利 | 中文字幕在线播放日韩 | 97av超碰 | av午夜电影 | 精品在线观看一区二区 | 亚洲精品高清视频在线观看 | 国产精品色婷婷视频 | 精品久久一区 | 日韩网站在线免费观看 | av亚洲产国偷v产偷v自拍小说 | 亚洲精品网页 | 91免费观看国产 | 久久久精品在线观看 | 日韩在线观看不卡 | 日韩视频在线观看视频 | 狠狠色伊人亚洲综合网站色 | 国产日本亚洲 | 黄色aaa毛片| 亚洲国产精品女人久久久 | 免费又黄又爽的视频 | 国内成人精品2018免费看 | 国产福利一区在线观看 | 免费观看av网站 | 午夜视频在线观看一区二区 | 成人a在线观看高清电影 | www.久久婷婷 | 亚洲精品午夜国产va久久成人 | 亚洲精品国产精品99久久 | 黄在线免费观看 | 国产精品99久久免费黑人 | www.天天射 | 国产 亚洲 欧美 在线 | 综合五月| 青青河边草免费直播 | 一区二区三区播放 | 麻豆视频免费网站 | 天天躁天天躁天天躁婷 | 婷婷综合网 | 免费精品在线 | 亚洲天天看 | 亚洲综合五月 | 超碰在线99 | 国产视频亚洲精品 | 92精品国产成人观看免费 | 国产在线视频一区二区 | 玖玖综合网 | 国产九九九视频 | 狠狠ri| 黄色av一区 | 日本亚洲国产 | 啪啪激情网| 成人午夜免费剧场 | 久久在现视频 | 成人欧美日韩国产 | 欧美-第1页-屁屁影院 | 在线观看黄色大片 | 国产精品久久久久久久久久久久午夜片 | 国产一区二区免费在线观看 | 麻豆精品传媒视频 | 日韩在线电影一区二区 | 久久久精品视频成人 | 综合久久2023 | 精品久久久久久久久亚洲 | 成年人免费看的视频 | 性色av免费观看 | 亚洲激情av | 人人干,人人爽 | 色婷婷国产精品一区在线观看 | 岛国精品一区二区 | 国产黄色片免费 | 在线观看视频97 | 久久久精品高清 | 国产在线观看不卡 | 日本中文字幕网 | 91亚洲欧美 | 国产精品一级在线 | 日本丶国产丶欧美色综合 | 中文字幕在线免费观看 | 亚洲乱码精品久久久 | 999久久国精品免费观看网站 | 97视频在线免费观看 | 亚洲视频axxx | 国产精品久久久久久一二三四五 | 亚洲精区二区三区四区麻豆 | 国产97色 | 国产最新在线 | 国产一级片视频 | 5月丁香婷婷综合 | 少妇精69xxtheporn | 在线视频一二区 | 在线观看韩日电影免费 | 国产精品12 | 亚洲欧美成aⅴ人在线观看 四虎在线观看 | 亚洲精品ww| 欧美精品网站 | 久久久www成人免费精品 | 日韩中文字幕在线不卡 | 色婷婷骚婷婷 | 国产精品青草综合久久久久99 | 人人射 | 97视频在线观看成人 | www久久久久 | 国产精品 日韩 欧美 | 黄色精品一区二区 | 91污视频在线 | 在线你懂的视频 | 久久手机免费观看 | 91视频久久久久 | 人人爽人人爽人人片 | 97人人模人人爽人人喊中文字 | 国产日韩欧美精品在线观看 | 国产不卡免费av | 日韩mv欧美mv国产精品 | 日韩欧美一区二区三区黑寡妇 | 国产老太婆免费交性大片 | 久久国产午夜精品理论片最新版本 | 日韩首页 | 国产在线第三页 | 久久久久久久国产精品 | 97在线精品| 综合久久综合久久 | 天天曰天天曰 | 人人玩人人添人人澡97 | 成人av网页 | 亚洲成人蜜桃 | 国产精品一区二区久久精品爱微奶 | 少妇高潮冒白浆 | 国产麻豆果冻传媒在线观看 | 奇米网网址 | 岛国av在线 | 日韩在线第一区 | 在线观看视频在线 | 久久99精品热在线观看 | 国产69精品久久app免费版 | 欧美日韩中文另类 | 亚洲国产中文字幕在线观看 | 国产又粗又猛又黄视频 | 开心激情五月网 | 一区二区三区日韩在线 | 国产精品免费人成网站 | 日韩在线色| 69国产在线观看 | 国产高清99 | 美女视频又黄又免费 | 天堂av网址| www.五月天婷婷 | 中日韩三级视频 | 日本久久电影 | 中文字幕成人一区 | 日韩高清国产精品 | 中文字幕日韩国产 | 欧美日韩高清免费 | 欧美日韩在线电影 | 午夜.dj高清免费观看视频 | 精品电影一区 | 在线免费观看黄网站 | 美女av在线免费 | 国产一级电影免费观看 | 国产一区二区在线精品 | www.夜夜操.com| 国产精品网红直播 | 黄网在线免费观看 | 亚洲精品88欧美一区二区 | 一区在线免费观看 | 最新国产在线 | 日日摸日日 | 日韩av在线网站 | 久久精品成人欧美大片古装 | 亚洲精品在线免费观看视频 | 久久久久久久久久久电影 | 婷婷综合网 | 伊人激情网| 国产夫妻av在线 | 欧美日韩在线免费视频 | 日韩欧美电影网 | 久久精品99国产精品 | 午夜黄网 | 精品国产一区二区三区久久 | 国产精品欧美 | 麻豆传媒视频在线免费观看 | japanesexxxhd奶水 国产一区二区在线免费观看 | 在线综合 亚洲 欧美在线视频 | 中国黄色一级大片 | 五月天综合网站 | 美女久久久久久久 | 伊人电影在线观看 | 国产在线视频在线观看 | 国产一级片视频 | 天天曰天天射 | 亚洲精品乱码久久久久久蜜桃欧美 | 日韩天堂在线观看 | 一级成人免费视频 | 欧美日韩亚洲在线观看 | 成人av.com | 欧美在线日韩在线 | 91精品蜜桃 | 色丁香综合 | 美女福利视频网 | 国内99视频 | 免费观看国产精品视频 | 国产人在线成免费视频 | 精品久久久久一区二区国产 | 久青草视频在线观看 | 国产精品亚洲a | 日韩成人xxxx| 日韩欧美99 | 狠狠成人 | 女人18精品一区二区三区 | 欧美aaa级片| www成人精品 | 久久久久久综合网天天 | 一区二区三区久久精品 | 五月天六月婷婷 | 深夜免费福利视频 | 国产成人在线播放 | 国产亚洲精品久久久久久久久久 | 综合久久久久久 | 97视频在线观看播放 | 天天干夜夜操视频 | 国产老妇av | 国产精品一区欧美 | 久久婷婷色综合 | 欧美性黄网官网 | 欧美日韩一区二区在线观看 | 免费看网站在线 | 日日夜夜精品视频 | 国产麻豆精品免费视频 | 久久综合色播五月 | 91麻豆精品国产91久久久久久久久 | 精品免费在线视频 | 91高清免费在线观看 | 久久99国产综合精品免费 | 午夜精品一二三区 | ,午夜性刺激免费看视频 | 六月色婷| 丁香激情网 | 国产一区二区三区视频在线 | 日韩专区视频 | 久久久久 | 精品中文字幕在线播放 | 91福利视频免费观看 | 国产亚洲婷婷 | 激情综合网色播五月 | 在线电影播放 | 欧美成人a在线 | 高清av免费看 | 91九色视频在线观看 | 久久久久久国产精品亚洲78 | 日韩亚洲国产精品 | 中文字幕在线资源 | 97超碰在线久草超碰在线观看 | 在线播放精品一区二区三区 | 91免费视频黄 | 国产精品视频永久免费播放 | 91桃色在线免费观看 | 亚洲精品国产精品乱码不99热 | 日韩中文字幕视频在线 | 成人黄色小说视频 | 私人av| 黄在线免费观看 | 精品久久久网 | 五月婷婷,六月丁香 | 欧美综合在线视频 | 欧美日韩亚洲第一 | 午夜精品一区二区三区免费视频 | 免费在线成人av电影 | 亚洲一区二区精品在线 | 超碰97人人干 | 精品视频99| 国产精品手机视频 | 亚洲精品久久久久58 | 丁香五月亚洲综合在线 | 在线观看91久久久久久 | 久久综合色天天久久综合图片 | 69av视频在线| 国产日韩欧美视频 | 成人小电影在线看 | 97激情影院 | 97超碰中文字幕 | 在线观看视频一区二区三区 | 日日夜操| 国产精品1区2区在线观看 | 国产一级一片免费播放放 | 在线黄频| 国产精品美女视频 | 99精品乱码国产在线观看 | 99热最新精品 | 久久国产精品一国产精品 | www.久久精品视频 | 在线 成人| 日韩电影中文 | 很污的网站 | 亚洲香蕉在线观看 | 国产又黄又爽无遮挡 | 亚洲波多野结衣 | 亚洲视频免费在线观看 | 久久99精品国产一区二区三区 | 婷婷六月中文字幕 | 亚州国产精品视频 | 久久综合九色综合97_ 久久久 | 成人在线免费小视频 | 亚洲综合婷婷 | 午夜久久网| 欧美成人a在线 | 日韩欧美在线国产 | 天天操综合网站 | 一区二区久久久久 | 国产精品普通话 | 久久色在线观看 | 欧美日韩中文字幕综合视频 | 激情视频免费在线观看 | 97爱爱爱 | 亚洲天堂网在线播放 | 国产精品精品国产婷婷这里av | 精品在线视频观看 | 24小时日本在线www免费的 | 毛片美女网站 | 伊人永久 | 久色 网| 国产亚洲久一区二区 | 人人狠狠| 欧美视频网址 | 99久久久久久久 | 在线国产日本 | 国产日韩欧美在线影视 | 96亚洲精品久久久蜜桃 | 国产亚洲精品美女 | 亚洲精品高清一区二区三区四区 | 日韩三级精品 | 日韩免费成人av | 免费h精品视频在线播放 | 国产亚洲亚洲 | 9草在线| 国产精品免费观看视频 | 最近日本韩国中文字幕 | 在线视频在线观看 | 99欧美精品 | 亚洲精品视频在线观看免费 | 国产高清免费 | 免费毛片一区二区三区久久久 | 日韩在线理论 | 亚洲91精品在线观看 | 手机av在线不卡 | 亚洲成a人片在线观看网站口工 | 在线导航av | 99在线免费视频观看 | 日本精品视频在线 | 伊人影院得得 | 国产精品一区二区中文字幕 | 国产精品女人久久久 | 涩涩资源网 | 日本一区二区高清不卡 | 久久久久久久久久久久久国产精品 | 天天操天天操天天操 | 国产综合福利在线 | 成人精品一区二区三区电影免费 | 亚洲一级片在线看 | 亚洲精品国偷自产在线99热 | 日本精品一区二区三区在线播放视频 | 亚洲区另类春色综合小说 | 极品久久久久 | 久草久视频 | 国产欧美中文字幕 | av丝袜在线 | 亚洲情婷婷 | 久产久精国产品 | 狠狠色丁香婷综合久久 | 狠色在线 | 三级免费黄色 | 久久久久久影视 | 日韩欧美亚州 | 中文字幕乱码视频 | 91麻豆看国产在线紧急地址 | 国产高清久久久久 | 人人爽人人香蕉 | 亚洲欧美精品一区二区 | 99热高清| 亚洲欧美日韩国产一区二区 | 丁香综合五月 | 四虎国产精品成人免费4hu | 午夜视频福利 | 色吊丝在线永久观看最新版本 | 黄色成人小视频 | 中文字幕在线观看三区 | 欧美日韩超碰 | 天天草天天干天天 | 亚洲春色综合另类校园电影 | 国产欧美久久久精品影院 | 久久精品视频网 | 日韩在线视频线视频免费网站 | 日韩黄色在线电影 | 中文字幕日韩国产 | 69av在线播放 | 亚洲国产精品免费 | 日韩动漫免费观看高清完整版在线观看 | 久久久久久亚洲精品 | 色婷婷av一区 | 日日干日日操 | www.天天色| 国产高清中文字幕 | 免费观看性生交 | 国模一区二区三区四区 | 色综合亚洲精品激情狠狠 | 91精品老司机久久一区啪 | 欧美不卡视频在线 | 99在线热播精品免费99热 | 中文字幕丝袜 | 免费h精品视频在线播放 | 国产免费又黄又爽 | 成人a视频片观看免费 | 91成人网在线 | 国产成人免费 | 中文字幕日韩一区二区三区不卡 | 天天玩天天操天天射 | 麻豆精品视频在线观看免费 | 人人爽人人爽人人片av | 久久久久激情 | 99久久9| 手机在线小视频 | 日本高清免费中文字幕 | 中文字幕免费在线看 | 精品久久久成人 | 精品视频成人 | 伊人影院在线观看 | 韩国av永久免费 | 精品在线免费观看 | 国产精品久久网站 | 狠狠色免费 | 91精品久久久久久久久久久久久 | 热久久国产 | 国产 视频 久久 | 欧美另类激情 | 日韩v在线 | 日韩啪啪小视频 | 亚洲国产一区av | 人人爽人人做 | 久久伊人精品天天 | 极品美女被弄高潮视频网站 | 91大神在线观看视频 | 国产亚洲午夜高清国产拍精品 | 一区二区三区福利 | 69久久久久久久 | 婷婷社区五月天 | 午夜精品久久久久久久99无限制 | 亚洲最新av| www.色五月.com | 天天操天天操天天操天天 | 日本精品久久 | a在线一区 | 99爱精品在线 | 色综合久久中文字幕综合网 | 黄色一级免费 | 日韩成人欧美 | 插久久 | 精品欧美在线视频 | 日本三级在线观看中文字 | 色综合天天综合网国产成人网 | 久久久99精品免费观看乱色 | 久久久午夜精品理论片中文字幕 | 欧美综合国产 | 91社区国产高清 | 国产高清永久免费 | 99精品电影 | 久久久综合九色合综国产精品 | 四虎欧美 | 99久久夜色精品国产亚洲 | 国产亚洲久一区二区 | 在线观看国产成人av片 | 免费亚洲一区二区 | 黄色亚洲 | 国产手机视频在线播放 | 中文字幕观看在线 | 一级欧美一级日韩 | 夜夜爱av | 亚洲干视频在线观看 | 午夜精品久久久久 | 西西大胆免费视频 | 天天草天天摸 | 美女视频黄频大全免费 | 日日干激情五月 | 国产精品久久久久久久久久妇女 | 色偷偷88欧美精品久久久 | av在线免费网 | 亚洲成人频道 | 九九精品久久久 | 午夜精品av在线 | 国产99自拍 | 黄色av一区二区三区 | 日韩www在线 | 草久久精品 | 久久免费视频国产 | 黄色aa久久 | 久99久在线视频 | 在线视频成人 | 亚洲欧洲精品一区二区 | 在线观看91 | 国产精品久久久久永久免费看 | 日韩精品在线一区 | 五月婷婷开心中文字幕 | 狠狠色狠狠色综合日日小说 | 最新日本中文字幕 | 九九在线国产视频 | 成人黄色免费观看 | 91精品视频免费看 | 在线观看91久久久久久 | www久久精品| 97超碰色| 国产免费黄视频在线观看 | 日韩黄色av网站 | 探花在线观看 | 中文字幕你懂的 | 国内精品久久久久久中文字幕 | 亚洲四虎| 色全色在线资源网 | 国产免费叼嘿网站免费 | 亚洲永久国产精品 | 亚洲精品国产精品国产 | 国产一二三精品 | 久久tv视频 | 在线看国产一区 | 天天碰天天操视频 | 久久精品com | 99精品在线视频观看 | 插久久 | 精品美女视频 | 97精品国产97久久久久久粉红 | av中文字幕不卡 | 开心丁香婷婷深爱五月 | 国产午夜精品一区二区三区在线观看 | 免费观看黄色12片一级视频 | 成人一区影院 | 国产成人专区 | 国产小视频在线观看 | 日韩精品在线看 | 97日日碰人人模人人澡分享吧 | 国产免费观看久久黄 | 亚洲精品美女久久久 | 五月婷婷,六月丁香 | 91精品啪啪| 69国产在线观看 | 中文字幕免费在线 | www.久久视频 | 麻花豆传媒mv在线观看网站 | 成人高清在线 | 成人午夜电影久久影院 | 日韩av区 | 九九涩涩av台湾日本热热 | 精品久久久久久久久久岛国gif | 日韩理论电影在线观看 | 91在线观看视频网站 | 欧美激情视频一区二区三区免费 | 亚洲欧洲日韩 | 成人av手机在线 | 99九九99九九九视频精品 | 韩国精品在线观看 | 在线观看亚洲成人 | 国产高清在线a视频大全 | 亚洲国产99 | 色天天综合网 | 在线免费观看的av网站 | av中文在线播放 | 一区二区三区四区五区在线 | 丝袜少妇在线 | 西西大胆免费视频 | 欧美性一级观看 | av资源中文字幕 | 在线久热 | 色婷婷综合久久久久中文字幕1 | 西西www4444大胆视频 | 玖玖视频在线 | 亚洲视频,欧洲视频 | 精品播放 | 日本午夜在线亚洲.国产 | 国产精品久久久久久妇 | 欧美日韩中文在线视频 | 精品 激情 | 国产不卡在线看 | 99精品在线视频观看 | 91黄站| 欧美色图视频一区 | 国产精品一区二区在线看 | 成人免费视频免费观看 | 久久99九九99精品 | 国产麻豆电影在线观看 | 国产五月| 日韩精品久久一区二区 | 丁香六月久久综合狠狠色 | 欧美孕交vivoestv另类 | 综合久久网 | 人人澡人人添人人爽一区二区 | 中文字幕在线观看网址 | 麻豆国产电影 | 91中文在线观看 | 天天操天天拍 | www在线观看国产 | 五月天亚洲综合小说网 | 亚洲尺码电影av久久 | ,午夜性刺激免费看视频 | 免费看三级网站 | 99久久www免费 | 久久久麻豆 | 久久99国产精品久久99 | 天天干夜夜擦 | 精品999在线观看 | 久久精品视频99 | 成人一区二区三区在线 | 欧洲精品在线视频 | 丁香六月婷婷开心 | 婷香五月| 777视频在线观看 | 国产精品久久久久永久免费看 | 欧美日韩久久一区 | a黄色影院 | 国产在线毛片 | 国产黄色片一级三级 | 一区二区三区在线影院 | 96国产在线 | 亚洲日本国产精品 | 婷婷激情5月天 | 国产999| 99视频免费观看 | 日韩免费视频观看 | 日韩国产精品久久 | 日韩精品中文字幕在线观看 | 一区二区精品在线观看 | 欧美精品国产综合久久 | 色播激情五月 | 久久不见久久见免费影院 | 麻豆精品在线 | 中文字幕一区二区三区四区久久 | 亚洲一级免费观看 | 激情久久影院 | 天天操天天操天天 | 亚洲区另类春色综合小说 | 日韩视频中文字幕在线观看 | 亚洲日本色| 国产又粗又长又硬免费视频 | 狠狠操狠狠 | 18网站在线观看 | 中文国产字幕在线观看 | 91人人澡人人爽人人精品 | 色婷婷a | 精品久久网 | 国产91精品在线播放 | 久久看片 | 一区二区三区免费在线观看视频 | 日韩在线视频一区二区三区 | 曰韩精品 | 久草视频免费在线播放 | 亚洲精品一区二区久 | 九九免费视频 | 色吊丝av中文字幕 | 美女网站视频色 | 日韩精品一区二区三区视频播放 | 国产精品久久久久久久午夜 | 综合天堂av久久久久久久 | 九色精品在线 | 国产成人亚洲精品自产在线 | 在线看v片| 成人欧美一区二区三区黑人麻豆 | 成人免费 在线播放 | 99热这里有 | 成人永久视频 | 最近日韩中文字幕中文 | 久久综合久久综合久久综合 | 深爱激情五月综合 | 中文字幕亚洲在线观看 | 成人黄色资源 | 亚洲精品玖玖玖av在线看 | 亚洲精品综合在线观看 | 中文字幕电影高清在线观看 | 国产视频一区二区在线观看 | 色在线视频 | 国内久久精品视频 | 婷婷国产一区二区三区 | 91精品少妇偷拍99 | 香蕉视频啪啪 | 天天干天天操天天爱 | 日韩网站在线观看 | 9999免费视频 | 日韩午夜电影网 | 国产视频1区2区3区 久久夜视频 | www,黄视频| av中文字幕免费在线观看 | 91成人精品一区在线播放 | 五月花丁香婷婷 | 四虎永久免费网站 | 日本久久精品视频 | av在线直接看 | www天天干 | 97av色 | 欧美日韩1区 | www国产亚洲精品久久麻豆 | 狠狠成人 | 91精品国产成人 | a视频在线观看免费 | 亚洲精品国产精品久久99热 |