精品欧美一区二区三区在线观看 _久久久久国色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ù)棧公眾號

日韩影视在线观看| 中文字幕精品一区二| 538任你躁精品视频网免费| 一区二区三区精品视频在线| 国产超碰91| 国产又粗又爽视频| 久久久久午夜电影| 亚洲激情自拍图| 五月婷婷丁香综合网| 婷婷在线播放| 26uuu欧美| 成人淫片在线看| 国产网友自拍视频| 精品国产a一区二区三区v免费| 欧美日本一道本在线视频| 久久av综合网| 成人高清网站| av在线不卡电影| 国产欧美欧洲在线观看| 日韩欧美亚洲一区二区三区| 日韩久久精品| 日韩精品中文字幕视频在线| 91精品999| 欧美gay视频| 亚洲一区二区精品久久av| 日韩国产在线一区| 亚洲AV成人无码精电影在线| 国产成年妇视频| 夜久久久久久| 欧美日韩xxxxx| 国产精品麻豆一区| 久久99国产精一区二区三区| 欧美sm美女调教| 精品国偷自产在线| 激情久久综合网| 欧美舌奴丨vk视频| 亚洲成人高清在线| a级片一区二区| 日本综合在线| 国产视频911| 精品1区2区| www日本高清| 国产在线精品一区二区夜色| 国产精品白丝jk喷水视频一区| 国产乡下妇女做爰毛片| 伊人情人综合网| 日韩中文第一页| 一级肉体全黄裸片| 久久不卡国产精品一区二区| 日韩禁在线播放| av无码一区二区三区| 一级毛片精品毛片| 91精品国产麻豆| 黄色小视频免费网站| 成人自拍视频网| 欧美亚洲一区二区在线| 日韩在线第三页| 欧美大片免费高清观看| 疯狂做受xxxx欧美肥白少妇| 国产青青在线视频| 欧美男男激情videos| 亚洲宅男天堂在线观看无病毒| 91九色国产ts另类人妖| 成年人网站在线| 亚洲精品一二三四区| 欧美亚洲视频一区| 日韩激情av| 亚洲高清视频中文字幕| 成人免费播放器| 国产在线精彩视频| 色综合久久中文字幕| 国产在线观看福利| 国产日韩另类视频一区| 欧美性受xxxx黑人xyx性爽| 成人一级片免费看| www免费在线观看| 亚洲女同ⅹxx女同tv| 最近中文字幕免费mv| 国产高清一区二区三区视频| 玉足女爽爽91| www.成年人视频| 欧美男人天堂| 日韩精品免费一区二区在线观看| 在线播放日韩专区| 任我爽在线视频| 欧美一区二区| 91精品国产免费久久久久久 | 久久天堂电影网| 欧美精品色哟哟| 久久xxxx| 亚洲va欧美va国产综合剧情| 亚洲精品国产精品国| 91麻豆产精品久久久久久| 亚洲精品自在在线观看| 曰本三级在线| 色伊人久久综合中文字幕| 美女在线视频一区二区| 91综合久久爱com| 在线播放日韩欧美| 激情综合网五月婷婷| 免费日韩av片| 亚洲精品免费在线视频| 香蕉视频国产在线| 自拍偷自拍亚洲精品播放| 成人免费播放器| 激情欧美一区二区三区黑长吊| 日韩一区二区麻豆国产| 99久久精品免费视频| 亚洲激情中文| 国产不卡在线观看| 亚洲AV无码成人片在线观看 | 一区二区视频免费看| 国产欧美精品| 亚洲一区中文字幕| 国产高清自拍视频在线观看| 亚洲综合色自拍一区| 色综合天天色综合| 欧美偷窥清纯综合图区| 久久亚洲欧美日韩精品专区| 激情视频网站在线观看| 国产老女人精品毛片久久| 欧美一级二级三级九九九| 手机在线免费看av| 欧美色网站导航| 亚洲精品视频大全| 激情六月综合| 亚洲www在线| 国产黄色免费在线观看| 狠狠做深爱婷婷久久综合一区 | 2023国产精华国产精品| 日韩在线小视频| 国产第一页在线观看| 成人激情午夜影院| 国产激情片在线观看| 亚洲男人在线| 日韩中文在线视频| 无码人妻丰满熟妇区bbbbxxxx | 好吊色欧美一区二区三区视频| 成年人视频免费在线观看| 黄色91在线观看| 久久久精品人妻一区二区三区| 四季av在线一区二区三区| 国产99视频精品免视看7| 污污网站免费在线观看| 欧美亚一区二区| 日韩免费一区二区三区| 春色校园综合激情亚洲| 日韩欧美国产不卡| 黄色免费一级视频| 美国三级日本三级久久99 | 成人爽a毛片| 欧美刺激性大交免费视频| 中文字幕人成人乱码亚洲电影| 国产九九视频一区二区三区| 伊人av成人| 欧美xxxx网站| www.久久久久| 国产毛片在线视频| 亚洲欧美自拍偷拍色图| www.色欧美| 石原莉奈在线亚洲三区| 久久视频在线看| 中文字幕一区二区人妻| 欧美国产一区在线| 天天操天天摸天天爽| 国产日产精品一区二区三区四区的观看方式| 国内精品久久久| 欧美一级性视频| 午夜一区二区三区在线观看| 91成人性视频| 手机看片福利在线观看| 色综合久久久久网| 91网站免费视频| 全部av―极品视觉盛宴亚洲| 亚洲欧美日韩综合一区| 国产精品美女久久久久| 欧美激情伊人电影| 日漫免费在线观看网站| 91国偷自产一区二区开放时间 | 国产免费久久久| 专区另类欧美日韩| 国模大尺度视频| 亚洲精品乱码| 国产亚洲精品美女久久久| 亚洲综合久久网| 国产女同性恋一区二区| 欧美成人福利在线观看| 国产一区二区在线观看免费| 亚洲a级在线播放观看| 欧美日韩经典丝袜| 日韩av一卡二卡| 伊人亚洲综合网| 一二三四社区欧美黄| 91网站免费入口| 国产在线精品免费| 一女被多男玩喷潮视频| japanese国产在线观看| 中文字幕 久热精品 视频在线 | 色综合久久网女同蕾丝边| 91久久国产最好的精华液| 欧美激情亚洲色图| 乱一区二区av| 北条麻妃69av| 久久国产电影| 国产精品视频免费观看| 深夜成人影院| 久久久久久久999精品视频| 亚洲日本在线播放| 欧美日韩国产在线播放网站| 免费在线观看日韩| 欧美激情综合五月色丁香| 国产黄色一区二区三区| 新67194成人永久网站| 日本午夜精品一区二区三区| 中文一区二区三区四区| 国产成人久久久精品一区| 中国av在线播放| 亚洲美女久久久| 亚洲第一页综合| 欧美日韩一区二区不卡| 九九热国产视频| 精品久久久久久久久久久| 国产va亚洲va在线va| 欧美精品momsxxx| 91九色蝌蚪成人| 成人国产一区| 国内精品在线一区| 色综合久久影院| 青青草国产精品97视觉盛宴| 亚洲精品成人三区| 香蕉久久精品日日躁夜夜躁| 91精品视频在线看| 一区二区视频免费完整版观看| 久久乐国产精品| 国产调教视频在线观看| 在线成人激情黄色| 香蕉久久国产av一区二区| 这里只有精品视频在线观看| 中文字幕有码无码人妻av蜜桃| 亚洲熟妇无码乱子av电影| 日本成人手机在线| 国产成人啪精品视频免费网| 国产精品视频一区二区在线观看| 99精品偷自拍| av地址在线观看| 精品一区二区三区视频| 日韩精品你懂的| 久久国产88| 玩弄中年熟妇正在播放| 欧美日本一区| 久久久久99精品成人片| 牛牛国产精品| 潘金莲一级淫片aaaaa免费看| 不卡在线一区二区| 日本不卡一区二区三区在线观看| 久久1电影院| 国内外成人免费视频| 999久久久久久久久6666| 99影视tv| 999精品视频在这里| 超碰97在线资源| 国产乱码精品一区二区三区亚洲人 | 日韩av超清在线观看| 91av视频在线免费观看| 97在线超碰| 久久久久久久久91| 牛牛精品一区二区| 欧美中文字幕第一页| 性欧美18xxxhd| 国产精品91视频| 精品日韩视频| 国产精品视频中文字幕91| 不卡亚洲精品| av一区观看| 高清日韩中文字幕| 精品视频高清无人区区二区三区| 亚洲精品在线播放| 欧美激情第一页在线观看| 少妇精品久久久一区二区三区| 日本不卡免费新一二三区| 91精品久久久久久久蜜月| 欧美 国产 精品| 伊人成人在线视频| 欧妇女乱妇女乱视频| 亚洲一区二区毛片| 538在线视频观看| 激情欧美日韩一区二区| 蜜桃传媒一区二区亚洲av| 日本一区二区在线看| 欧美专区一二三 | 国产精品一卡| 97国产在线播放| 韩国精品久久久| 超碰caoprom| 国产日韩欧美a| 国产一级生活片| 欧美视频一区二区三区在线观看 | 亚洲国产视频一区| 日韩精品乱码久久久久久| 亚洲图片自拍偷拍| 国产美女www| 欧美不卡一区二区三区| 日韩欧美在线番号| 久久国产精品影片| 在线看片福利| 亚洲va欧美va天堂v国产综合| 国产va在线播放| 色综合色狠狠综合色| 国产精品一区二区免费视频| 精品av综合导航| 超碰免费在线观看| 久久久在线观看| 91成人在线| 高清不卡日本v二区在线| 丝袜美腿一区二区三区动态图| 一本—道久久a久久精品蜜桃| 亚洲激情不卡| 亚洲黄色av片| 伊人久久亚洲热| 亚洲成熟丰满熟妇高潮xxxxx| 日韩综合在线视频| 亚洲av无码国产精品久久| 国产精品久久久久久久久免费樱桃| 岛国毛片在线观看| 欧美日韩国产在线播放网站| 天天操天天干天天操| 久久视频免费在线播放| 中韩乱幕日产无线码一区| 国产精成人品localhost| 91亚洲国产| 成年网站在线免费观看| 成人一区二区三区在线观看| 国产又粗又猛又爽又黄的视频四季 | 日韩av免费一区| 色播一区二区| 欧美成人一区二区在线| 好看的亚洲午夜视频在线| 手机av在线网| 国产精品不卡一区| 欧美国产一级片| 亚洲欧美日韩国产中文专区| 成年人在线网站| 高清视频在线观看一区| 93在线视频精品免费观看| 免费看污黄网站| 久久久久久久久久久久久夜| 久久精品国产亚洲av香蕉| 精品乱人伦小说| 青春草免费在线视频| 91老司机在线| 最新精品国产| 中国男女全黄大片| 樱桃视频在线观看一区| www黄色在线观看| 欧美精品在线第一页| 国产日韩欧美中文在线| 国产精品va在线观看无码| 国产乱码精品一区二区三区五月婷 | 欧美人成在线观看| 99国产精品国产精品毛片| 日韩三级视频在线播放| 精品盗摄一区二区三区| av在线free| 91久久久久久久久| 91亚洲国产高清| 午夜激情视频网| 国产精品久久久久毛片软件| 亚洲一区二区影视| 精品国内自产拍在线观看| 中文字幕视频精品一区二区三区| 黄色一级大片免费| 成人h动漫精品一区二区| 中文字幕一区二区三区精品| 亚洲男人天堂手机在线| 日韩pacopacomama| 亚洲春色在线| 国产成人小视频| 国产系列精品av| 亚洲精品美女在线观看| 国产成人精选| 中文字幕99| 精彩视频一区二区三区| 久青草免费视频| 日韩精品一区二区三区第95| 是的av在线| 日韩中文字幕一区| 国产一区二区视频在线| 99热国产在线观看| 一本大道亚洲视频| 国产精品高清一区二区| av动漫免费看| aa亚洲婷婷| 成年人免费观看视频网站| 色婷婷久久99综合精品jk白丝| 亚洲欧美在线不卡| 日韩欧美在线视频日韩欧美在线视频| 在线免费黄色| 高清不卡日本v二区在线| 国产精品www994| 91狠狠综合久久久久久|