在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Spring事務(wù)傳播性的相關(guān)知識(shí)

OSC開源社區(qū) ? 來源:vivo互聯(lián)網(wǎng)技術(shù) ? 2024-01-10 09:29 ? 次閱讀

作者:vivo 互聯(lián)網(wǎng)服務(wù)器團(tuán)隊(duì) - Zhou Shaobin

本文主要介紹了Spring事務(wù)傳播性的相關(guān)知識(shí)。

Spring中定義了7種事務(wù)傳播性:

PROPAGATION_REQUIRED

PROPAGATION_SUPPORTS

PROPAGATION_MANDATORY

PROPAGATION_REQUIRES_NEW

PROPAGATION_NOT_SUPPORTED

PROPAGATION_NEVER

PROPAGATION_NESTED

在Spring環(huán)境中,含有事務(wù)的方法嵌套調(diào)用,事務(wù)是如何傳遞的規(guī)則,以及每種規(guī)則是如何開展工作的。文章還提到每種事務(wù)傳播性是如何使用的,方便讀者依據(jù)實(shí)際的場(chǎng)景,使用不同的事務(wù)規(guī)則。

一、什么是Spring事務(wù)的傳播性

Spring 事務(wù)傳播性是指, 在Spring的環(huán)境中,當(dāng)多個(gè)含有事務(wù)的方法嵌套調(diào)用時(shí),每個(gè)事務(wù)方法都處于自己事務(wù)的上下文中,其提交或者回滾行為應(yīng)該如何處理。

通俗講,就是當(dāng)一個(gè)事務(wù)方法調(diào)用另外一個(gè)事務(wù)方法時(shí),事務(wù)如何跨上下文傳播。

cf2af760-aee1-11ee-8b88-92fbcf53809c.jpg

1)當(dāng)事務(wù)方法A調(diào)用事務(wù)方法B時(shí),事務(wù)方法B是合并到事務(wù)方法A中,還是開啟新事務(wù)?

2)當(dāng)事務(wù)方法B拋出異常時(shí) ,在合并事務(wù)或者開啟新的事務(wù)的場(chǎng)景中,事務(wù)的回滾是如何處理的 ?

以上事務(wù)的處理規(guī)則,都取決于事務(wù)傳播級(jí)別的設(shè)置。

二、事務(wù)的傳播性都有哪些行為

cf2ee46a-aee1-11ee-8b88-92fbcf53809c.jpg

事務(wù)的傳播行為,主要分為三種類型,分別是:支持當(dāng)前事務(wù)不支持當(dāng)前事務(wù)嵌套事務(wù)

2.1 支持當(dāng)前事務(wù)

REQUIRED:默認(rèn)的事務(wù)傳播級(jí)別,表示如果當(dāng)前方法已在事務(wù)內(nèi),該方法就在當(dāng)前事務(wù)中執(zhí)行,否則,開啟一個(gè)新的事務(wù)并在其上下文中執(zhí)行。

SUPPORTED:當(dāng)前方法在事務(wù)內(nèi),則在其上下文中執(zhí)行該方法,否則,開啟一個(gè)新的事務(wù)。

MANDATORY:必須在事務(wù)中執(zhí)行,否則,將拋出異常。

2.2 不支持當(dāng)前事務(wù)

REQUIRES_NEW:無(wú)論當(dāng)前是否有事務(wù)上下文,都會(huì)開啟一個(gè)事務(wù) 。如果已經(jīng)有一個(gè)事務(wù)在執(zhí)行 ,則正在執(zhí)行的事務(wù)將被掛起 ,新開啟的事務(wù)會(huì)被執(zhí)行。

事務(wù)之間相互獨(dú)立,互不干擾。

NOT_SUPPORTED:不支持事務(wù),如果當(dāng)前存在事務(wù)上下文,則掛起當(dāng)前事務(wù),然后以非事務(wù)的方式執(zhí)行。

NEVER:不能在事務(wù)中執(zhí)行,如果當(dāng)前存在事務(wù)上下文,則拋出異常。

2.3嵌套事務(wù)

NESTED:嵌套事務(wù),如果當(dāng)前已存在一個(gè)事務(wù)的上下文中,則在嵌套事務(wù)中執(zhí)行,如果拋異常,則回滾嵌套事務(wù),而不影響其他事務(wù)的操作。

三、每種事務(wù)的傳播性如何工作

3.1 REQUIRED

默認(rèn)的事務(wù)傳播行為,保證多個(gè)嵌套的事務(wù)方法在同一個(gè)事務(wù)內(nèi)執(zhí)行,并且同時(shí)提交,或者出現(xiàn)異常時(shí),同時(shí)回滾。

這個(gè)機(jī)制可以滿足大多數(shù)業(yè)務(wù)場(chǎng)景。

cf396f52-aee1-11ee-8b88-92fbcf53809c.jpg

例子 :

cf421346-aee1-11ee-8b88-92fbcf53809c.jpg

cf4c16ca-aee1-11ee-8b88-92fbcf53809c.jpg

1)類TestAService的方法通過聲明式事務(wù)的方式,加上了事務(wù)注解@Transactional ,并設(shè)置事務(wù)的傳播性為REQUIRED。

2)調(diào)用者調(diào)用TestAService的A方法時(shí),如果調(diào)用者沒有開啟事務(wù),那么A方法會(huì)開啟一個(gè)事務(wù)。

A方法的具體執(zhí)行過程如下 :

a. 執(zhí)行insert,但沒有提交;

b.調(diào)用TestBServcie的B方法,由于B方法也聲明了事務(wù),并且傳播性是REQUIRED,所以方法B的事務(wù),合并到方法A開啟的事務(wù)中。

c.方法B執(zhí)行insert操作,此時(shí)也沒有提交。

3)由于這兩個(gè)方法的操作都在同一個(gè)事務(wù)中執(zhí)行,當(dāng)這兩個(gè)方法所有操作執(zhí)行成功之后,提交事務(wù)。

嵌套調(diào)用鏈路:

cf4fd530-aee1-11ee-8b88-92fbcf53809c.jpg

當(dāng)方法B 執(zhí)行時(shí)拋出了 Exception 異常后,事務(wù)是如何處理的 ?

1)方法B聲明了事務(wù),insert操作會(huì)回滾

2)由于方法A和方法B 同屬一個(gè)事務(wù),方法A也會(huì)執(zhí)行回滾,由此說明該規(guī)則保證了事務(wù)的原子性。

嵌套調(diào)用,異常后的鏈路:

cf544d90-aee1-11ee-8b88-92fbcf53809c.jpg

如果 方法B 拋出異常后,方法A 使用 try-catch 處理了方法B的異常(如下代碼),并沒有向外拋出,此時(shí)事務(wù)又如何處理的 ?

cf661444-aee1-11ee-8b88-92fbcf53809c.jpg

方法A也會(huì)回滾。

從事務(wù)的特性我們可知,事務(wù)具有原子性。方法A和方法B同屬一個(gè)事務(wù),當(dāng)方法B拋出異常,觸發(fā)回滾操作后,整個(gè)事務(wù)的操作都會(huì)回滾。

因此,Spring 在處理事務(wù)過程中,當(dāng)事務(wù)的傳播性設(shè)置為REQUIRED,在整個(gè)事務(wù)的調(diào)用鏈上,任何一個(gè)環(huán)節(jié)拋出的異常都會(huì)導(dǎo)致全局回滾。

3.2 REQUIRES_ NEW

每次都開啟一 個(gè)新的事務(wù)。

cf71346e-aee1-11ee-8b88-92fbcf53809c.jpg

例子:

cf74b526-aee1-11ee-8b88-92fbcf53809c.jpg

上面例子中,方法B的傳播性設(shè)置為 REQUIRES_NEW,方法A仍然是REQUIRED,當(dāng)A調(diào)用B時(shí),具體調(diào)用鏈路如下:

cf78fb4a-aee1-11ee-8b88-92fbcf53809c.jpg

具體執(zhí)行過程:

方法A被執(zhí)行前,如果調(diào)用者沒有開啟事務(wù),方法A開啟一個(gè)事務(wù)1,然后執(zhí)行insert ,此時(shí)沒有提交;

方法B的事務(wù)傳播性設(shè)置為REQUIRES_NEW,當(dāng)被方法A調(diào)用時(shí),此時(shí)方法A的事務(wù)1會(huì)被掛起,方法B開啟自己的事務(wù)2,然后執(zhí)行insert,此時(shí)并沒有提交;

當(dāng)方法B執(zhí)行完畢后,提交事務(wù)2;

恢復(fù)事務(wù)1,最終提交。

當(dāng) 方法B 執(zhí)行時(shí)拋出了異常,會(huì)發(fā)生什么?

方法B的insert操作會(huì)被回滾掉,方法A不受影響。但這里有個(gè)前提,方法A需要try-catch方法B的異常,使其異常不會(huì)往上傳遞,從而導(dǎo)致方法A接收到異常,導(dǎo)致回滾。

cf8e0e4a-aee1-11ee-8b88-92fbcf53809c.jpg

3.3 SUPPORTED

當(dāng)外層方法A存在事務(wù),方法B加入到當(dāng)前事務(wù)中,以事務(wù)的方式執(zhí)行。

cf9203ba-aee1-11ee-8b88-92fbcf53809c.jpg

當(dāng)外層方法A不存在事務(wù),方法B不會(huì)創(chuàng)建新的事務(wù),以非事務(wù)的方式執(zhí)行。

cf959822-aee1-11ee-8b88-92fbcf53809c.jpg

例子1:

cf99f494-aee1-11ee-8b88-92fbcf53809c.jpg

cf9d6eee-aee1-11ee-8b88-92fbcf53809c.jpg

以上例子,方法A沒有加事務(wù)注解,方法B的加了事務(wù)注解,并且傳播為SUPPORTS。

具體執(zhí)行過程:

方法A以非事務(wù)的方式執(zhí)行insert操作。

方法B被調(diào)用,由于其外層事務(wù)A沒有開啟事務(wù),方法B也是以非事務(wù)方法執(zhí)行insert操作。

cfa1c642-aee1-11ee-8b88-92fbcf53809c.jpg

例子2:

cfa58354-aee1-11ee-8b88-92fbcf53809c.jpg

以上例子,方法A和B都加上了事務(wù)注解,其中方法A的傳播性為REQUIRED,方法B的傳播性為SUPPORTS。

具體執(zhí)行過程:

如果方法A的調(diào)用方?jīng)]有開啟事務(wù),則方法A開啟事務(wù),并執(zhí)行insert操作,但沒有提交;

方法B被調(diào)用,由于其外層方法A開啟了事務(wù),因此方法B加入到方法A開啟的事務(wù)中,并執(zhí)行insert,但沒有提交;

當(dāng)事務(wù)中的所有操作執(zhí)行成功后,事務(wù)提交。

cfadd6d0-aee1-11ee-8b88-92fbcf53809c.jpg

3.4 NOT_SUPPORTED

不支持事務(wù)。

如果外層方法存在事務(wù),則掛起外層事務(wù),以非事務(wù)方式執(zhí)行,執(zhí)行完畢后,恢復(fù)外層事務(wù)。

cfb82f36-aee1-11ee-8b88-92fbcf53809c.jpg

例子:

cfbbb3f4-aee1-11ee-8b88-92fbcf53809c.jpg

以上例子:方法A和B都加上了事務(wù)注解,方法A的傳播性為REQUIRED,方法B為NOT_SUPPORTED。

具體執(zhí)行過程:

如A的調(diào)用方?jīng)]有開啟事務(wù),方法A開啟事務(wù),并執(zhí)行insert,但沒有提交。

方法A調(diào)用方法B時(shí),方法B的傳播性為NOT_SUPPORTED,不支持事務(wù),然后掛起外層方法A的事務(wù),方法B以非事務(wù)的方式執(zhí)行insert。

方法B執(zhí)行完畢后,恢復(fù)方法A的事務(wù),最終提交事務(wù)。

調(diào)用鏈路過程:

cfbf87cc-aee1-11ee-8b88-92fbcf53809c.jpg

3.5 NEVER

不支持事務(wù)

當(dāng)外層方法A開啟了事務(wù),方法B拋出異常

cfcb8202-aee1-11ee-8b88-92fbcf53809c.jpg

例子:

cfd572ee-aee1-11ee-8b88-92fbcf53809c.jpg

以上代碼,兩個(gè)方法都打上了事務(wù)注解,方法A的傳播性是REQUIRED,方法B的傳播性是NEVER。

具體執(zhí)行過程:

方法A開啟事務(wù),執(zhí)行insert,沒有提交。

含有事務(wù)的方法A調(diào)用方法B,方法B的傳播性是NEVER,表示不支持事務(wù),因此方法B拋出異常。

方法A的事務(wù)執(zhí)行回滾。

cfdba3bc-aee1-11ee-8b88-92fbcf53809c.jpg

3.6 MANDATORY

必須在事務(wù)中執(zhí)行。

如果外層方法A沒有開啟事務(wù),方法B拋出異常。

cfe68804-aee1-11ee-8b88-92fbcf53809c.jpg

如果外層方法A開啟了事務(wù),方法B加入事務(wù),方法A&B在同一事務(wù)中執(zhí)行。

cfee5322-aee1-11ee-8b88-92fbcf53809c.jpg

例子:

cffb49ce-aee1-11ee-8b88-92fbcf53809c.jpg

以上例子,方法A沒有加事務(wù)注解,方法B 的傳播性為 MANDATORY。

具體執(zhí)行過程:

方法A的調(diào)用方如果本身沒有開啟事務(wù),方法A執(zhí)行前不會(huì)開啟事務(wù)。

當(dāng)非事務(wù)方法A調(diào)用方法B時(shí),由于方法B的傳播性為MANDATORY,必須在事務(wù)中執(zhí)行,條件不滿足,拋出異常。

cfff335e-aee1-11ee-8b88-92fbcf53809c.jpg

3.7 NESTED

嵌套事務(wù)

如果外層方法A不存在事務(wù),內(nèi)層方法B的規(guī)則與REQUIRED 一致。

如果外層方法A存在事務(wù),內(nèi)層方法B做為外層方法A事務(wù)的子事務(wù)執(zhí)行,兩個(gè)方法是一起提交,但子事務(wù)是獨(dú)立回滾。

內(nèi)層方法B拋出異常,則會(huì)回滾方法B的所有操作,但不影響外層事務(wù)方法A。(方法A需要try-catch子事務(wù),避免異常傳遞到父層事務(wù))

外層方法A回滾,則內(nèi)層方法B也會(huì)回滾。

該傳播性的特點(diǎn)是可以保存狀態(tài)點(diǎn),當(dāng)回滾時(shí),只會(huì)回滾到某一個(gè)狀態(tài)點(diǎn),保證了子事務(wù)之間的獨(dú)立性,避免嵌套事務(wù)的全局回滾。

d0034e76-aee1-11ee-8b88-92fbcf53809c.jpg

例子:

d012ff38-aee1-11ee-8b88-92fbcf53809c.jpg

以上例子,方法A的傳播性為REQUIRED,方法B為NESTED。

具體執(zhí)行過程:

方法A執(zhí)行時(shí),如調(diào)用方?jīng)]有開啟事務(wù),則開啟一個(gè)事務(wù)。

方法B被外層方法A調(diào)用時(shí),因?yàn)榉椒˙的傳播性為NESTED,方法B在此處建立savepoint,標(biāo)記insert行為。

當(dāng)方法B拋出異常,其insert操作會(huì)回滾,但只會(huì)回滾到savepoint,(前提是方法A要try-catch方法B,使方法B的異常不會(huì)往外傳遞)。

方法B回滾后,方法A的事務(wù)提交。

調(diào)用鏈路:

d02ed262-aee1-11ee-8b88-92fbcf53809c.jpg

四、總結(jié)

本文解釋了Spring框架中的事務(wù)傳播性,即多個(gè)業(yè)務(wù)方法之間調(diào)用時(shí)事務(wù)如何處理的規(guī)則。Spring提供了七種傳播級(jí)別,如

PROPAGATION_REQUIRED、

PROPAGATION_REQUIRES_NEW等。

每種級(jí)別都有適用場(chǎng)景和限制,本文提供了一些示例,介紹了聲明式事務(wù)如何使用,每種事務(wù)的規(guī)則,產(chǎn)生哪種行為,當(dāng)方法拋出異常時(shí),事務(wù)的提交和回滾是如何被處理的。正確處理事務(wù)對(duì)于任何企業(yè)級(jí)應(yīng)用程序都是必要的,了解Spring事務(wù)傳播性是構(gòu)建高效、可靠和可擴(kuò)展應(yīng)用程序的關(guān)鍵。

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 互聯(lián)網(wǎng)
    +關(guān)注

    關(guān)注

    54

    文章

    11154

    瀏覽量

    103290
  • 服務(wù)器
    +關(guān)注

    關(guān)注

    12

    文章

    9149

    瀏覽量

    85406
  • spring
    +關(guān)注

    關(guān)注

    0

    文章

    340

    瀏覽量

    14341

原文標(biāo)題:Spring七種事務(wù)傳播性介紹

文章出處:【微信號(hào):OSC開源社區(qū),微信公眾號(hào):OSC開源社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    Spring事務(wù)失效的十種常見場(chǎng)景

    Spring的聲明式事務(wù)功能更是提供了極其方便的事務(wù)配置方式,配合Spring Boot的自動(dòng)配置,大多數(shù)Spring Boot項(xiàng)目只需要在
    的頭像 發(fā)表于 12-11 15:03 ?913次閱讀

    Spring事務(wù)實(shí)現(xiàn)原理

    作者:京東零售 范錫軍 1、引言 springspring-tx模塊提供了對(duì)事務(wù)管理支持,使用spring事務(wù)可以讓我們從復(fù)雜的
    的頭像 發(fā)表于 11-08 10:10 ?822次閱讀
    <b class='flag-5'>Spring</b><b class='flag-5'>事務(wù)</b>實(shí)現(xiàn)原理

    什么是java spring

    什么是java springSpring是一個(gè)開源框架,它由Rod Johnson創(chuàng)建。它是為了解決企業(yè)應(yīng)用開發(fā)的復(fù)雜而創(chuàng)建的。Spring使用基本的JavaBean來完成以前只可能由EJB完成
    發(fā)表于 09-11 11:16

    Spring的兩種方式事務(wù)管理和API接口介紹

    Spring事務(wù)管理
    發(fā)表于 03-21 06:52

    Spring事務(wù)分析的實(shí)現(xiàn)方式

    Spring事務(wù)原理分析
    發(fā)表于 07-02 15:19

    詳解Spring事務(wù)管理

    在學(xué)習(xí)spring事務(wù)管理時(shí),我忍不住要問,spring為什么進(jìn)行事務(wù)管理,spring怎么進(jìn)行的事務(wù)
    發(fā)表于 07-12 06:54

    Spring事務(wù)管理詳解說明

    Spring事務(wù)管理詳解
    發(fā)表于 05-20 13:46

    spring中聲明式事務(wù)實(shí)現(xiàn)原理猜想

    ? @Transactional注解簡(jiǎn)介 @Transactional 是spring中聲明式事務(wù)管理的注解配置方式,相信這個(gè)注解的作用大家都很清楚。 @Transactional 注解可以幫助
    的頭像 發(fā)表于 10-13 09:20 ?1629次閱讀

    淺談Spring事務(wù)的那些坑

    對(duì)于從事java開發(fā)工作的同學(xué)來說,spring事務(wù)肯定再熟悉不過了。在某些業(yè)務(wù)場(chǎng)景下,如果同時(shí)有多張表的寫入操作,為了保證操作的原子(要么同時(shí)成功,要么同時(shí)失敗)避免數(shù)據(jù)不一致的情況,我們一般都會(huì)使用
    的頭像 發(fā)表于 10-11 10:31 ?751次閱讀

    發(fā)現(xiàn)一個(gè)Spring事務(wù)的巨坑bug 你必須要小心了

    1.錯(cuò)誤的訪問權(quán)限 2.方法被定義成final的 3.方法內(nèi)部調(diào)用 4.當(dāng)前實(shí)體沒有被spring管理 5.錯(cuò)誤的spring事務(wù)傳播特性 6.數(shù)據(jù)庫(kù)不支持
    的頭像 發(fā)表于 10-11 18:17 ?855次閱讀

    淺談Spring事務(wù)底層原理

    開啟Spring事務(wù)本質(zhì)上就是增加了一個(gè)Advisor,但我們使用@EnableTransactionManagement注解來開啟Spring事務(wù)是,該注解代理的功能就是向
    的頭像 發(fā)表于 12-06 09:56 ?694次閱讀

    Spring Boot Web相關(guān)的基礎(chǔ)知識(shí)

    Boot的第一個(gè)接口。接下來將會(huì)將會(huì)介紹使用Spring Boot開發(fā)Web應(yīng)用的相關(guān)內(nèi)容,其主要包括使用spring-boot-starter-web組件來實(shí)現(xiàn)Web應(yīng)用開發(fā)、URL地址映射、參數(shù)傳遞、數(shù)據(jù)校驗(yàn)規(guī)、統(tǒng)一數(shù)據(jù)返
    的頭像 發(fā)表于 03-17 15:03 ?658次閱讀

    Spring事務(wù)在哪幾種情況下會(huì)不生效?

    日常開發(fā)中,我們經(jīng)常使用到spring事務(wù)。最近星球一位還有去美團(tuán)面試,被問了這么一道面試題: Spring 事務(wù)在哪幾種情況下會(huì)不生效?
    的頭像 發(fā)表于 05-10 17:53 ?934次閱讀
    <b class='flag-5'>Spring</b><b class='flag-5'>事務(wù)</b>在哪幾種情況下會(huì)不生效?

    8個(gè)Spring事務(wù)失效的場(chǎng)景介紹

    作為Java開發(fā)工程師,相信大家對(duì)Spring事務(wù)的使用并不陌生。但是你可能只是停留在基礎(chǔ)的使用層面上,在遇到一些比較特殊的場(chǎng)景,事務(wù)可能沒有生效,直接在生產(chǎn)上暴露了,這可能就會(huì)導(dǎo)致比較嚴(yán)重的生產(chǎn)
    的頭像 發(fā)表于 05-11 10:41 ?674次閱讀
    8個(gè)<b class='flag-5'>Spring</b><b class='flag-5'>事務(wù)</b>失效的場(chǎng)景介紹

    spring事務(wù)失效的一些場(chǎng)景

    對(duì)于從事java開發(fā)工作的同學(xué)來說,spring事務(wù)肯定再熟悉不過了。 在某些業(yè)務(wù)場(chǎng)景下,如果一個(gè)請(qǐng)求中,需要同時(shí)寫入多張表的數(shù)據(jù)。為了保證操作的原子(要么同時(shí)成功,要么同時(shí)失敗),避免數(shù)據(jù)
    的頭像 發(fā)表于 10-08 14:27 ?446次閱讀
    <b class='flag-5'>spring</b><b class='flag-5'>事務(wù)</b>失效的一些場(chǎng)景
    主站蜘蛛池模板: 久久手机免费视频| 大量真实偷拍情侣视频野战| 欧美特级黄| 六月丁香婷婷网| 国产大乳喷奶水在线看| 免费艹逼视频| 国漫在线观看| 亚洲成网站www久久九| 天天摸天天操天天射| 久久天天躁狠狠躁夜夜躁| 94久久国产乱子伦精品免费| 68日本xxxxxxxxx777| 最近2018中文字幕免费看手机| 免费黄色大片在线观看| 一道精品视频一区二区三区男同| www色在线| 色偷偷91综合久久噜噜| 欧美精品成人a多人在线观看| 高级毛片| 日本69xxxxxxx69| 美欧毛片| 色激情网| 国产一级大片在线观看| 天天操天天干天天爽| h在线观看视频| 天堂中文在线免费观看| 久久这里只精品热在线8| 狠狠干夜夜爽| 欧美不卡视频在线| 日本免费小视频| 91在线电影| 911精品国产91久久久久| 天天看天天摸天天操| 午夜剧院免费| 在线视频一区二区三区四区| 天天怕夜夜怕狠狠怕| 性试验k8经典| 中文字幕第7页| 在线观看免费xx高清视频| 免费网站啪啪大全| 免费看三级黄色片|