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

工作六年才發(fā)現(xiàn),@Transactional 藏著這么多坑

開發(fā) 前端
說了這么多坑,相信大家對@Transactional注解有了更深入的理解。雖然@Transactional給我們帶來了很大的便利,但如果不正確使用,就會埋下很多隱患。

兄弟們,工作這些年,踩過的坑數(shù)不勝數(shù),其中關(guān)于@Transactional注解的坑,可真是讓我印象深刻。今天,我就把這些年遇到的坑整理出來,分享給大家,希望能讓大家少走一些彎路。

一、@Transactional 基本概念回顧

在開始填坑之前,咱們先簡單回顧一下@Transactional注解的基本概念。@Transactional是 Spring 框架提供的用于聲明式事務(wù)管理的注解,它可以應(yīng)用在方法或類上,用于指定該方法或類中的所有公共方法在執(zhí)行時需要進行事務(wù)管理。

使用@Transactional注解可以讓我們無需手動編寫事務(wù)開啟、提交、回滾的代碼,大大簡化了事務(wù)管理的工作。但是,如果你以為只要加上這個注解就萬事大吉了,那可就大錯特錯了,接下來咱們就來看看那些隱藏的坑。

二、注解生效條件的坑

(一)非 public 方法無效

你以為把@Transactional注解加在任何方法上都能生效嗎?錯啦!Spring 的@Transactional注解默認只能應(yīng)用在 public 修飾的方法上。如果我們把注解加在 protected、private 或者默認訪問修飾符的方法上,注解會失效,事務(wù)不會被管理。

我就曾經(jīng)犯過這樣的錯誤,在一個工具類里寫了一個 private 方法,加上了@Transactional注解,結(jié)果發(fā)現(xiàn)事務(wù)根本沒有生效,數(shù)據(jù)出現(xiàn)了不一致的情況。當時找了好久的原因,最后才發(fā)現(xiàn)是方法訪問修飾符的問題。

為什么會這樣呢?這是因為 Spring 在掃描方法的時候,默認只會處理 public 方法。如果我們希望在非 public 方法上使用事務(wù),可以通過配置來修改這個行為,不過一般情況下,不建議這么做,還是按照規(guī)范把事務(wù)注解加在 public 方法上比較好。

(二)類內(nèi)部方法調(diào)用失效

假設(shè)我們有一個類UserService,里面有兩個方法,一個 public 的addUser方法和一個 private 的updateUser方法,addUser方法中調(diào)用了updateUser方法,并且在addUser方法上加上了@Transactional注解。這時候,如果你認為updateUser方法中的操作也會在同一個事務(wù)中執(zhí)行,那就錯了。

當我們在同一個類內(nèi)部調(diào)用方法時,Spring 的事務(wù)代理機制不會起作用,因為此時調(diào)用的是目標對象本身,而不是代理對象。所以,updateUser方法中的操作不會被納入到事務(wù)管理中,如果在updateUser方法中出現(xiàn)異常,不會觸發(fā)事務(wù)的回滾。

舉個例子,比如在addUser方法中,先插入一條用戶數(shù)據(jù),然后調(diào)用updateUser方法更新用戶的某個字段,如果updateUser方法中拋出了異常,而addUser方法沒有捕獲這個異常,按照我們的預(yù)期,應(yīng)該回滾插入操作,但實際上,由于事務(wù)沒有覆蓋到updateUser方法,插入操作已經(jīng)提交,導(dǎo)致數(shù)據(jù)不一致。

解決這個問題的方法是,將需要事務(wù)管理的方法暴露為 public 方法,或者通過注入自身的代理對象來調(diào)用方法。比如,在 Spring 中,我們可以通過@Autowired注入自己,然后通過代理對象來調(diào)用方法,這樣就能讓事務(wù)生效了。

三、方法調(diào)用方式的坑

(一)異步調(diào)用事務(wù)失效

在實際開發(fā)中,我們可能會使用異步方法來提高系統(tǒng)的性能,比如使用@Async注解來標記異步方法。這時候,如果在異步方法上使用了@Transactional注解,需要注意事務(wù)可能會失效。

原因是異步方法是在另一個線程中執(zhí)行的,而 Spring 的事務(wù)是基于線程綁定的,不同的線程擁有不同的事務(wù)上下文。當我們在主線程中調(diào)用異步方法時,異步方法所在的線程并沒有獲取到主線程的事務(wù)上下文,所以事務(wù)注解會失效。

我之前在處理一個發(fā)送短信的業(yè)務(wù)時,為了不阻塞主線程,將發(fā)送短信的方法標記為異步方法,并且加上了@Transactional注解,希望在發(fā)送短信失敗時回滾相關(guān)的業(yè)務(wù)操作。結(jié)果發(fā)現(xiàn),即使發(fā)送短信拋出了異常,相關(guān)的業(yè)務(wù)操作也沒有回滾,就是因為異步調(diào)用導(dǎo)致事務(wù)失效了。

要解決這個問題,我們需要確保異步方法所在的線程能夠獲取到事務(wù)上下文,或者在異步方法中單獨開啟事務(wù)。不過,一般情況下,異步操作和主線程的業(yè)務(wù)操作屬于不同的事務(wù)邊界,我們需要根據(jù)具體的業(yè)務(wù)需求來設(shè)計事務(wù)的管理方式。

(二)子類重寫方法注解失效

如果我們有一個父類BaseService,在父類的方法上加上了@Transactional注解,然后子類SubService繼承了父類,并重寫了這個方法。這時候,如果子類沒有在重寫的方法上添加@Transactional注解,那么父類的注解是否會生效呢?

答案是不一定。這取決于 Spring 的事務(wù)代理方式。如果使用的是基于接口的代理(JDK 動態(tài)代理),那么只有當子類實現(xiàn)了父類的接口時,父類的注解才會生效;如果使用的是基于類的代理(CGLIB 代理),那么子類重寫方法時,如果方法不是 final 的,父類的注解可能會生效,但如果子類的方法訪問修飾符比父類更嚴格,比如父類是 public,子類是 protected,那么注解會失效。

為了避免這種情況,我們最好在子類重寫的方法上顯式地加上@Transactional注解,明確指定事務(wù)的配置,這樣可以保證事務(wù)的行為符合我們的預(yù)期。

四、異常處理的坑

(一)未捕獲的 Checked 異常不回滾

@Transactional注解默認情況下只會回滾 RuntimeException 及其子類(即未檢查異常),對于 Checked 異常(即受檢查異常),如果沒有被捕獲,事務(wù)不會自動回滾。

這是一個非常容易踩的坑。比如,我們在方法中調(diào)用了一個可能拋出 SQLException(Checked 異常)的數(shù)據(jù)庫操作,而沒有對這個異常進行處理,也沒有在@Transactional注解中指定回滾該異常,那么即使操作失敗,事務(wù)也不會回滾,數(shù)據(jù)會被提交。

我曾經(jīng)在處理一個文件上傳的業(yè)務(wù)時,需要同時將文件信息保存到數(shù)據(jù)庫中。在保存數(shù)據(jù)庫時,可能會因為唯一約束沖突拋出 SQLException,而我沒有在方法上添加rollbackFor = SQLException.class,結(jié)果導(dǎo)致文件上傳成功了,但數(shù)據(jù)庫中的文件信息沒有回滾,出現(xiàn)了數(shù)據(jù)不一致的情況。

所以,當我們的方法可能拋出 Checked 異常時,一定要在@Transactional注解中指定需要回滾的異常類型,或者在方法內(nèi)部捕獲異常并轉(zhuǎn)換為 RuntimeException,這樣才能讓事務(wù)回滾。

(二)異常被捕獲導(dǎo)致回滾失效

即使我們的方法可能拋出需要回滾的異常,如果在方法內(nèi)部捕獲了這個異常并且沒有重新拋出,那么事務(wù)也不會回滾。

比如,我們在方法中使用了 try-catch 塊來處理異常,但是在 catch 塊中沒有調(diào)用TransactionAspectSupport.currentTransactionStatus().setRollbackOnly()方法,或者沒有重新拋出異常,那么事務(wù)會認為操作成功,從而提交事務(wù)。

正確的做法是,如果我們需要在捕獲異常后回滾事務(wù),可以在 catch 塊中調(diào)用setRollbackOnly()方法,或者重新拋出異常(可以是原異常,也可以是包裝后的 RuntimeException)。

(三)自定義異常回滾問題

在實際開發(fā)中,我們可能會定義自己的異常類。這時候,如果自定義異常是 RuntimeException 的子類,那么@Transactional注解會默認回滾;如果是 Checked 異常,就需要像處理其他 Checked 異常一樣,在注解中指定回滾該異常。

需要注意的是,自定義異常的繼承結(jié)構(gòu)一定要正確,否則可能會導(dǎo)致回滾策略不符合預(yù)期。比如,如果你定義了一個自定義異常MyException,并且讓它繼承自 Exception(Checked 異常),那么在沒有指定回滾該異常的情況下,事務(wù)不會回滾。

五、隔離級別和傳播行為的坑

(一)隔離級別設(shè)置不當

@Transactional注解可以通過isolation屬性來設(shè)置事務(wù)的隔離級別,不同的隔離級別會影響事務(wù)之間的可見性和數(shù)據(jù)一致性。如果隔離級別設(shè)置不當,可能會導(dǎo)致臟讀、不可重復(fù)讀、幻讀等問題。

比如,在默認情況下,Spring 的事務(wù)隔離級別是ISOLATION_DEFAULT,這取決于數(shù)據(jù)庫的默認隔離級別(MySQL 默認是可重復(fù)讀,Oracle 默認是讀已提交)。如果我們的業(yè)務(wù)對數(shù)據(jù)一致性要求很高,需要避免幻讀,就需要將隔離級別設(shè)置為ISOLATION_SERIALIZABLE,但這會影響系統(tǒng)的性能。

我曾經(jīng)在一個庫存管理的業(yè)務(wù)中,沒有正確設(shè)置隔離級別,導(dǎo)致出現(xiàn)了超賣的問題。后來分析發(fā)現(xiàn),是因為在高并發(fā)情況下,沒有使用合適的隔離級別,導(dǎo)致幻讀的發(fā)生,庫存數(shù)量被錯誤地修改。

所以,我們需要根據(jù)具體的業(yè)務(wù)場景來選擇合適的隔離級別,在數(shù)據(jù)一致性和性能之間找到平衡點。

(二)傳播行為理解錯誤

@Transactional注解的propagation屬性用于指定事務(wù)的傳播行為,即當一個事務(wù)方法被另一個事務(wù)方法調(diào)用時,如何處理事務(wù)的開啟和提交。如果對傳播行為理解錯誤,可能會導(dǎo)致事務(wù)范圍不正確,出現(xiàn)數(shù)據(jù)不一致的問題。

常見的傳播行為有REQUIRED(默認值,支持當前事務(wù),如果沒有則新建一個)、SUPPORTS(支持當前事務(wù),如果沒有則以非事務(wù)方式執(zhí)行)、REQUIRES_NEW(新建一個事務(wù),掛起當前事務(wù))、NOT_SUPPORTED(以非事務(wù)方式執(zhí)行,掛起當前事務(wù))等。

比如,當我們在方法 A(使用REQUIRED傳播行為)中調(diào)用方法 B(使用REQUIRES_NEW傳播行為)時,方法 B 會新建一個事務(wù),與方法 A 的事務(wù)無關(guān)。如果方法 B 執(zhí)行失敗,只會回滾方法 B 的事務(wù),不會影響方法 A 的事務(wù);而如果方法 A 執(zhí)行失敗,即使方法 B 已經(jīng)提交,方法 A 的事務(wù)回滾也不會影響方法 B 的結(jié)果,因為它們是兩個不同的事務(wù)。

我之前在一個轉(zhuǎn)賬業(yè)務(wù)中,錯誤地使用了SUPPORTS傳播行為,導(dǎo)致在沒有外部事務(wù)的情況下,轉(zhuǎn)賬操作以非事務(wù)方式執(zhí)行,當出現(xiàn)異常時,沒有回滾數(shù)據(jù),造成了資金的損失。這真是一個深刻的教訓(xùn),所以大家一定要正確理解和使用事務(wù)的傳播行為。

六、數(shù)據(jù)庫方言的坑

(一)不同數(shù)據(jù)庫對事務(wù)的支持差異

不同的數(shù)據(jù)庫對事務(wù)的支持程度和語法略有不同。比如,MySQL 的 InnoDB 引擎支持事務(wù),而 MyISAM 引擎不支持事務(wù);Oracle 和 MySQL 在事務(wù)的隔離級別、鎖機制等方面也存在差異。

如果我們在使用@Transactional注解時,沒有考慮到數(shù)據(jù)庫的差異,可能會導(dǎo)致事務(wù)行為不符合預(yù)期。比如,在使用 MyISAM 引擎的表上使用@Transactional注解,事務(wù)會失效,因為該引擎根本不支持事務(wù)。

所以,在開發(fā)過程中,我們需要根據(jù)實際使用的數(shù)據(jù)庫來選擇合適的表引擎和事務(wù)配置,確保事務(wù)能夠正確生效。

(二)DDL 操作與事務(wù)

在一些數(shù)據(jù)庫中,DDL 操作(如創(chuàng)建表、修改表結(jié)構(gòu)等)會自動提交事務(wù),即使在事務(wù)塊中執(zhí)行 DDL 操作,也會導(dǎo)致事務(wù)提交,后面的 DML 操作不會回滾。

比如,在 MySQL 中,執(zhí)行 DDL 操作會隱式提交當前事務(wù),所以如果我們在一個帶有@Transactional注解的方法中先執(zhí)行 DML 操作,然后執(zhí)行 DDL 操作,DML 操作會被提交,即使 DDL 操作失敗,DML 操作也不會回滾。

這就需要我們注意,不要在事務(wù)方法中混合執(zhí)行 DDL 和 DML 操作,或者根據(jù)數(shù)據(jù)庫的特性來合理設(shè)計事務(wù)的范圍。

七、其他細節(jié)的坑

(一)@Transactional 注解在類上的作用

如果我們在類上添加@Transactional注解,那么該類中的所有 public 方法都會應(yīng)用事務(wù)管理。但是,如果子類繼承了這個類,并且子類沒有重寫方法,那么子類的方法也會應(yīng)用父類的事務(wù)注解;如果子類重寫了方法,子類的方法可以選擇是否添加自己的事務(wù)注解,來覆蓋父類的配置。

需要注意的是,在類上添加注解時,要確保該類是 Spring 容器管理的 bean,否則注解不會生效。

(二)事務(wù)超時設(shè)置

@Transactional注解可以通過timeout屬性來設(shè)置事務(wù)的超時時間,如果事務(wù)在指定的時間內(nèi)沒有完成,會自動回滾。如果我們沒有設(shè)置超時時間,默認是使用底層事務(wù)系統(tǒng)的默認超時時間(比如數(shù)據(jù)庫的默認超時時間)。

在一些長時間運行的事務(wù)中,如果不設(shè)置超時時間,可能會導(dǎo)致事務(wù)長時間占用數(shù)據(jù)庫資源,影響系統(tǒng)的性能,甚至導(dǎo)致死鎖。所以,對于需要控制執(zhí)行時間的事務(wù),一定要設(shè)置合適的超時時間。

(三)只讀事務(wù)優(yōu)化

如果我們的方法只是讀取數(shù)據(jù),不會對數(shù)據(jù)進行修改,那么可以將@Transactional注解的readOnly屬性設(shè)置為true,這樣可以告訴數(shù)據(jù)庫使用只讀事務(wù),數(shù)據(jù)庫可以進行一些優(yōu)化,提高查詢性能。

這是一個容易被忽視的優(yōu)化點,合理使用只讀事務(wù)可以在一定程度上提升系統(tǒng)的性能。

八、總結(jié)

說了這么多坑,相信大家對@Transactional注解有了更深入的理解。雖然@Transactional給我們帶來了很大的便利,但如果不正確使用,就會埋下很多隱患。

在使用@Transactional注解時,我們需要注意以下幾點:

  1. 注解只能應(yīng)用在 public 方法上,類內(nèi)部方法調(diào)用需要通過代理對象來保證事務(wù)生效。
  2. 正確處理異常,明確需要回滾的異常類型,避免異常被捕獲導(dǎo)致回滾失效。
  3. 根據(jù)業(yè)務(wù)場景選擇合適的隔離級別和傳播行為,平衡數(shù)據(jù)一致性和性能。
  4. 考慮數(shù)據(jù)庫的差異,選擇合適的表引擎和事務(wù)配置,避免 DDL 操作對事務(wù)的影響。
  5. 注意其他細節(jié),如類上注解的作用、事務(wù)超時設(shè)置、只讀事務(wù)優(yōu)化等。

希望大家在今后的開發(fā)中,能夠避開這些坑,正確使用@Transactional注解,讓事務(wù)管理為我們的系統(tǒng)保駕護航。

責任編輯:武曉燕 來源: 石杉的架構(gòu)筆記
相關(guān)推薦

2024-03-07 12:54:00

AI模型

2024-08-30 10:02:06

事務(wù)HTTP編碼

2024-04-02 08:41:10

ArrayListSubList場景

2023-07-28 07:22:55

企業(yè)可觀測體系

2021-01-05 07:00:53

微信隱藏功能移動應(yīng)用

2025-09-08 08:13:25

2020-06-01 08:04:18

三目運算符代碼

2020-06-08 10:33:09

微信朋友圈移動應(yīng)用

2023-05-31 07:57:12

筆記本電腦信譽度

2017-08-11 14:21:33

軟件開發(fā)前端框架

2023-07-17 08:21:52

漏洞版本項目

2018-08-06 11:12:02

編程語言Python腳本語言

2024-07-12 09:35:38

前端工具檢驗

2018-06-26 15:00:24

Docker安全風(fēng)險

2023-11-13 08:49:54

2024-02-20 08:09:51

Java 8DateUtilsDate工具類

2022-07-06 11:47:27

JAVAfor循環(huán)

2016-11-28 10:15:26

云計算

2016-03-27 14:04:14

云計算云安全

2009-02-23 11:22:29

系統(tǒng)架構(gòu)師軟件開發(fā)經(jīng)驗
點贊
收藏

51CTO技術(shù)棧公眾號

午夜欧美精品| 福利一区二区免费视频| 不卡的av电影在线观看| 日本久久久久久久久久久| 国产又粗又黄又猛| 久久在线观看| 一本久道中文字幕精品亚洲嫩| 亚洲高清在线播放| 国产综合视频在线| 香蕉久久a毛片| 久久亚洲精品成人| 成年人网站免费看| 97久久精品一区二区三区的观看方式| 亚洲观看高清完整版在线观看| 日韩少妇中文字幕| 男人天堂综合网| 蜜桃av一区二区在线观看| 久久久久久网站| 亚洲激情图片网| 天天久久夜夜| 日韩精品一区二区在线观看| 粗暴91大变态调教| free性欧美16hd| 国产精品另类一区| 免费日韩电影在线观看| 亚洲精品久久久久久久久久久久久久 | 日韩精品一区二区亚洲av性色| 久久香蕉网站| 日韩欧美视频在线| 涩涩网站在线看| 亚洲小少妇裸体bbw| 精品国产视频在线观看| 69视频在线观看免费| 三上悠亚激情av一区二区三区| 亚洲欧美另类久久久精品2019| 欧美视频1区| 亚洲成人久久精品| 国产曰批免费观看久久久| 国产精品扒开腿做爽爽爽视频| 亚洲国产综合久久| 欧美精品激情| 久久99国产精品久久久久久久久| 一级特黄曰皮片视频| 亚洲人和日本人hd| 日韩精品高清视频| 亚洲精品中文字幕在线播放| 视频在线一区| 欧美www视频| 色哟哟网站在线观看| 国产视频网站一区二区三区| 欧美日韩不卡在线| 亚洲老女人av| 成人午夜一级| 6080yy午夜一二三区久久| 美女少妇一区二区| 亚洲国产伊人| 8x8x8国产精品| www.亚洲自拍| 日韩在线观看一区二区三区| 日韩一区二区精品葵司在线| 日韩精品xxx| 黑色丝袜福利片av久久| 日韩av在线不卡| 熟女俱乐部一区二区视频在线| 亚洲人成精品久久久| 国产亚洲激情在线| www.日本高清视频| 性欧美欧美巨大69| 欧美成人精品xxx| 国产一级免费av| 国产精品日本| 国产精品入口日韩视频大尺度| 亚洲精品一区二区二区| 极品美女销魂一区二区三区免费| 成人一区二区电影| 可以免费观看的毛片| 99re视频精品| 欧美日韩一区在线播放| av在线三区| 亚洲老妇xxxxxx| 男人天堂手机在线视频| 特黄毛片在线观看| 欧美日韩中文国产| 亚洲熟妇一区二区| 一区二区三区韩国免费中文网站| 伊人久久精品视频| 国产乱国产乱老熟300| 国产亚洲午夜| 成人激情电影一区二区| 成人毛片在线精品国产| 国产无遮挡一区二区三区毛片日本| 欧美精品七区| 18av在线视频| 欧美性猛交xxxxx免费看| 久久久久久蜜桃一区二区| 97久久综合精品久久久综合| 亚洲欧洲偷拍精品| 91精品久久久久久久久久另类| 少妇久久久久久被弄高潮| 国产一区二区三区久久| 国产日韩欧美在线| 天堂成人在线观看| 中文字幕一区不卡| 无码aⅴ精品一区二区三区浪潮 | 午夜日韩在线观看| www.天天射.com| 粉嫩精品导航导航| 中文字幕免费国产精品| 日韩免费一二三区| 激情丁香综合五月| 日本视频一区在线观看| 免费男女羞羞的视频网站在线观看| 日本精品一级二级| 9.1在线观看免费| 久久伦理在线| 日韩美女视频免费看| 亚洲黄色片视频| 国产精品久久毛片av大全日韩| 尤物av无码色av无码| 国产精品1区| 一区二区三区精品99久久| 日本在线小视频| 国产一区二区三区国产| 色一情一乱一伦一区二区三欧美| 91九色porn在线资源| 91精品国产一区二区三区蜜臀| 亚洲精品视频久久久| 在线 亚洲欧美在线综合一区| 国产欧美日韩中文字幕| 激情福利在线| 第一福利永久视频精品| 成人做爰www看视频软件 | 丰满的少妇愉情hd高清果冻传媒 | 噜噜噜躁狠狠躁狠狠精品视频| 99超碰麻豆| av电影免费在线观看| 欧美日韩精品一区二区三区| 免费看污片网站| 亚洲欧美卡通另类91av| 国产一级精品aaaaa看| 欧美人与性动交α欧美精品济南到 | 91蜜桃免费观看视频| 草草视频在线免费观看| 亚洲专区**| 久久久久久久久久国产精品| 精品久久在线观看| 亚洲乱码国产乱码精品精98午夜 | 精品视频在线你懂得| 久久久久久尹人网香蕉| 免费观看毛片网站| 亚洲mv在线观看| 捆绑凌虐一区二区三区| 在线亚洲欧美| 久久久久国产精品视频| 午夜不卡影院| 亚洲视屏在线播放| 中文在线资源天堂| 亚洲欧洲三级电影| 天天操夜夜操很很操| 黄色工厂这里只有精品| 国产一区二区精品在线| 2022成人影院| 亚洲视频日韩精品| 亚洲中文字幕在线一区| 亚洲人成精品久久久久久| 手机在线观看日韩av| 激情欧美一区| 女人一区二区三区| 成人精品电影在线| 日韩在线观看精品| 性一交一乱一色一视频麻豆| 亚洲主播在线播放| 国产精品久久久免费观看| 久久国产精品99国产| 香蕉久久夜色| 中文无码日韩欧| 18性欧美xxxⅹ性满足| 国产高清视频在线播放| 欧美日韩国产三级| 久久精品视频9| 久久久久久麻豆| 91 视频免费观看| 在线欧美视频| 亚洲欧美99| 大奶一区二区三区| 国产精品成人一区二区三区吃奶| 午夜在线播放| 亚洲精品99久久久久| 看黄色一级大片| 亚洲一区二区中文在线| 88久久精品无码一区二区毛片| 久久97超碰国产精品超碰| 日韩精品视频在线观看视频 | 成人午夜精品在线| 久激情内射婷内射蜜桃| av免费观看网址| 亚洲视频免费在线观看| 日本天堂在线播放| 日本不卡高清视频| 国产曰肥老太婆无遮挡| 日韩电影免费在线观看| 国产精品一区免费观看| 久久久久黄色| 欧美二区乱c黑人| 91在线不卡| 日韩www在线| 99在线精品视频免费观看软件| 欧美性猛交xxxx富婆| 国产这里有精品| 中文av字幕一区| 成人免费无码大片a毛片| 国产一区欧美一区| 日韩欧美黄色大片| 国产欧美午夜| japanese在线播放| 久久电影院7| 欧洲精品在线一区| 狼人精品一区二区三区在线| 成人午夜在线影院| 91成人抖音| 国产高清视频一区三区| 蜜桃麻豆av在线| 欧美激情aaaa| jizz性欧美| 久久精品视频网站| freemovies性欧美| 亚洲欧美精品伊人久久| 无码国产色欲xxxx视频| 精品久久一区二区三区| 国产精品视频a| 欧美美女一区二区在线观看| 波多野结衣人妻| 日韩欧美黄色动漫| 日韩精品在线不卡| 亚洲成人免费在线观看| 久久亚洲AV无码| 亚洲一区二区三区视频在线播放| 中日韩一级黄色片| 亚洲欧洲精品成人久久奇米网| 人妻av无码一区二区三区| 久久欧美一区二区| 在哪里可以看毛片| 欧美激情一区二区三区蜜桃视频 | 国产欧美一区二区三区在线老狼| 风间由美一二三区av片| 2欧美一区二区三区在线观看视频| 中文字幕在线永久| 91免费视频大全| 国产三级av在线播放| 国产亚洲欧洲997久久综合| 国产精品密蕾丝袜| 亚洲国产精品黑人久久久| 性爱在线免费视频| 国产精品国产三级国产aⅴ中文 | 成人欧美一区二区三区视频xxx | 欧美一区少妇| 成人精品视频| 26uuu成人| 狠狠爱www人成狠狠爱综合网| 亚洲国产精品成人天堂| 一本综合精品| www日韩视频| 另类中文字幕网| 伊人久久久久久久久| 99久久精品情趣| 成熟人妻av无码专区| 中文字幕在线观看不卡视频| 天天看片中文字幕| 亚洲成av人片一区二区| 东京热一区二区三区四区| 欧美在线小视频| 国产视频www| 亚洲电影免费观看高清完整版在线 | 一区二区欧美在线| 国产调教视频在线观看| 久久久久久一区二区三区| 欧美电影免费看| 91在线视频导航| 亚洲系列另类av| 资源网第一页久久久| 亚洲精品影视| 亚洲欧美在线精品| 福利电影一区二区| 亚洲精品一区二区三区影院忠贞| 中文字幕日本乱码精品影院| 国产极品美女高潮无套嗷嗷叫酒店 | a级片一区二区| 久久激情婷婷| wwwxxxx在线观看| 国产亚洲人成网站| 精品在线免费观看视频| 欧美性极品少妇| 日本精品久久久久久| 中文字幕欧美国内| 成人免费高清观看| 国产日韩精品在线播放| 国产无遮挡裸体免费久久| 亚洲图片都市激情| 国产精品日本| 逼特逼视频在线观看| 国产精品三级视频| 韩国av中文字幕| 欧美一区三区二区| www.亚洲视频| 91成人在线观看国产| 亚洲不卡在线| 亚洲一区二区在线观| 亚洲一区日韩| 久久久久无码国产精品一区李宗瑞| 国产精品免费丝袜| 日韩三级一区二区| 亚洲国产欧美在线成人app| 麻豆视频网站在线观看| 国产成人一区二区| 色愁久久久久久| 日韩精品一区二区免费| 激情综合五月天| а天堂中文在线资源| 色婷婷综合久久久中文一区二区| 亚洲国产精品国自产拍久久| 日韩亚洲成人av在线| 制服诱惑亚洲| 欧美精品尤物在线| 国产亚洲精品久久久久婷婷瑜伽| 老熟女高潮一区二区三区| 亚洲色图都市小说| 亚洲中文字幕一区二区| 这里只有精品视频| 亚洲欧美在线成人| 欧美久久久久久| 国产精品日韩久久久| 国产二级一片内射视频播放| 亚洲综合激情另类小说区| 国产高清第一页| 久久天天躁日日躁| 国产精品3区| 在线观看免费黄色片| 国产主播一区二区三区| 永久免费看片视频教学| 欧美丰满嫩嫩电影| 国产秀色在线www免费观看| 成人在线视频福利| 综合激情一区| 人妻精油按摩bd高清中文字幕| 亚洲三级理论片| www.亚洲欧美| 欧美精品久久久久a| 成人高潮视频| 成人中文字幕在线播放| 91女神在线视频| 波多野结衣一区二区三区在线| 国产亚洲欧洲高清| 日韩黄色三级| 国产91沈先生在线播放| hitomi一区二区三区精品| 日本熟妇成熟毛茸茸| 国产丝袜精品第一页| 最新欧美电影| 一区二区三区在线观看www| 国产麻豆一精品一av一免费| 欧洲第一无人区观看| 亚洲国产精品大全| 中文字幕在线视频网站| 日韩欧美第二区在线观看| 捆绑紧缚一区二区三区视频| 久久久久久久久久网站| 亚洲第一区第二区| 欧美xxxxxx| 在线免费一区| 成人av资源在线| 狠狠躁夜夜躁人人爽视频| 精品国偷自产在线视频| youjizzjizz亚洲| 国产成人无码av在线播放dvd| 中文字幕成人网| 国精产品一品二品国精品69xx| 欧美亚洲视频在线观看| 日韩专区精品| 在线观看成人动漫| 欧洲一区在线观看| 暖暖在线中文免费日本| 色狠狠久久av五月综合| 国产xxx精品视频大全| 色av性av丰满av| 欧美成人一区二区三区电影| 麻豆精品少妇| 久久久久久久久久久久久久久国产 | 成人免费在线观看视频| 日韩免费在线观看av| 国产三级三级三级精品8ⅰ区| 国产熟女一区二区三区四区| 91国在线精品国内播放| 91麻豆国产自产在线观看亚洲| 亚洲av成人片无码| 6080亚洲精品一区二区| 欧美极度另类| 国产片侵犯亲女视频播放| 欧美极品少妇xxxxⅹ高跟鞋 | 水蜜桃色314在线观看| 国产精品美女久久久久久久网站|