3atv精品不卡视频,97人人超碰国产精品最新,中文字幕av一区二区三区人妻少妇,久久久精品波多野结衣,日韩一区二区三区精品

歡迎訪問 生活随笔!

生活随笔

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

编程问答

spring 多线程 事务 源码解析(一)

發布時間:2023/12/10 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 spring 多线程 事务 源码解析(一) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

大家好,我是烤鴨:

? ? 今天分享的是spring 多線程事務源碼分析。

環境:
spring-jdbc 5.0.4.REALEASE

今天分享一下spring事務的方法,這一篇還沒涉及到多線程。

簡單說一下doBegin的方法:


強轉獲取當前的事務對象,看看事務對象是否有連接保持器(是否是新的事務對象)
或者連接保持器的事務同步性(默認是新的事務對象,不同步,為false)。
滿足上面的條件,為當前連接設置一個新的連接保持器,設置當前保持器事務同步性為同步(true)。
獲取事務的之前的事務隔離級別,新事務的話,就把當前的事務隔離級別設置為當前事務的previousIsolationLevel。
當前事務是否自動提交,如果是自動提交,事務對象的 mustRestoreAutoCommit 屬性設置為true,設置自動提交為 false。
ps : mustRestoreAutoCommit這個屬性在事務完成之后的 doCleanupAfterCompletion方法中,判斷如果這個屬性為true,連接就setAutoCommit 為true。
事務開啟后準備正常的事務連接,設置事務的只讀標識為false。
設置當前事務的當前持有者激活屬性為true,表示事務在激活中。
設置連接器的超時時間,如果超時時間非默認,就設置超時時間。
※※※ 如果是新的事務連接器,用ThreadLocal的Map變量,key 是真實去包裝后的數據源,value 是當前的連接持有者。(將連接和線程綁定)

?

在詳細看一下 DataSourceTransactionManager 的doBegin方法:
需要傳兩個參數:

/*** This implementation sets the isolation level but ignores the timeout.*///@0 TransactionDefinition @Override // @0protected void doBegin(Object transaction, TransactionDefinition definition) {//強轉成數據源事務對象 @1DataSourceTransactionObject txObject = (DataSourceTransactionObject) transaction;Connection con = null;try {//事務對象是否有連接保持器 @2 或者 if (!txObject.hasConnectionHolder() || //連接保持器 是否是同步事務 @3txObject.getConnectionHolder().isSynchronizedWithTransaction()) {//獲取當前數據源的連接Connection newCon = obtainDataSource().getConnection();if (logger.isDebugEnabled()) {logger.debug("Acquired Connection [" + newCon + "] for JDBC transaction");}//設置 數據源事務對象 的連接持有者ConnectionHolder,與當前連接綁定txObject.setConnectionHolder(new ConnectionHolder(newCon), true);}// 設置連接持有者的事務為同步事務txObject.getConnectionHolder().setSynchronizedWithTransaction(true);con = txObject.getConnectionHolder().getConnection();// @5 準備為當前連接加事務,獲取并設置之前事務的隔離級別Integer previousIsolationLevel = DataSourceUtils.prepareConnectionForTransaction(con, definition);txObject.setPreviousIsolationLevel(previousIsolationLevel);// Switch to manual commit if necessary. This is very expensive in some JDBC drivers,// so we don't want to do it unnecessarily (for example if we've explicitly// configured the connection pool to set it already).// 必須時切換手動提交事務。在一些JDBC驅動中是很昂貴的,非必須的話不要用。(比如我們已經把連接池設置沖突)// 如果是自動提交,事務對象的必須恢復自動提交為true,連接的自動提交關閉。if (con.getAutoCommit()) {// doCleanupAfterCompletion方法中 事務結束時會判斷這個值為true時,連接才會自動提交。txObject.setMustRestoreAutoCommit(true);if (logger.isDebugEnabled()) {logger.debug("Switching JDBC Connection [" + con + "] to manual commit");}con.setAutoCommit(false);}// @6 準備開啟事務,設置事務的只讀標識為falseprepareTransactionalConnection(con, definition);// @7 設置當前事務被當前持有者 持有txObject.getConnectionHolder().setTransactionActive(true);// **** @8 這個方法就不貼了,就是看當前的definition對象是否有默認超時時間,如果沒有就將管理器的超時時間設置到當前連接對象int timeout = determineTimeout(definition);if (timeout != TransactionDefinition.TIMEOUT_DEFAULT) {txObject.getConnectionHolder().setTimeoutInSeconds(timeout);}// Bind the connection holder to the thread.// @9 將連接持有者和線程綁定if (txObject.isNewConnectionHolder()) {// 和線程綁定,key 是真實去包裝后的數據源,value 是當前的連接持有者 TransactionSynchronizationManager.bindResource(obtainDataSource(), txObject.getConnectionHolder());}}catch (Throwable ex) {//出異常,如果是新創建的就釋放連接,設置當前事務對象連接連接持有者為空if (txObject.isNewConnectionHolder()) {DataSourceUtils.releaseConnection(con, obtainDataSource());txObject.setConnectionHolder(null, false);}throw new CannotCreateTransactionException("Could not open JDBC Connection for transaction", ex);}}

@0:
?? ?TransactionDefinition就是一個關于事務的定義類(常量),其中包含隔離級別,傳播類型,只讀標識,超時時間等。

/*** Interface that defines Spring-compliant transaction properties.* Based on the propagation behavior definitions analogous to EJB CMT attributes.** <p>Note that isolation level and timeout settings will not get applied unless* an actual new transaction gets started. As only {@link #PROPAGATION_REQUIRED},* {@link #PROPAGATION_REQUIRES_NEW} and {@link #PROPAGATION_NESTED} can cause* that, it usually doesn't make sense to specify those settings in other cases.* Furthermore, be aware that not all transaction managers will support those* advanced features and thus might throw corresponding exceptions when given* non-default values.** <p>The {@link #isReadOnly() read-only flag} applies to any transaction context,* whether backed by an actual resource transaction or operating non-transactionally* at the resource level. In the latter case, the flag will only apply to managed* resources within the application, such as a Hibernate {@code Session}.*/// 接口定義了spring規則的事務屬性。基于類似EJB(Enterprise Java Bean)// CMT(Container-managed transaction) 屬性 的依賴傳播行為 。// 隔離級別和超時設定只有在真正的新事務開始時才生效。例如PROPAGATION_REQUIRED,// PROPAGATION_REQUIRES_NEW , PROPAGATION_NESTED 是可以的,通常不會在其他隔離級別// 指定這些設置。要知道不是所有的事務管理器都支持這些高級特性,如果沒給默認值,有可能// 拋出相應的異常。 public interface TransactionDefinition {/*** Support a current transaction; create a new one if none exists.* Analogous to the EJB transaction attribute of the same name.* <p>This is typically the default setting of a transaction definition,* and typically defines a transaction synchronization scope.*/// 支持當前事務;如果不存在就創建一個新的事務。// 類似 相同名字的 EJB 事務 屬性。// 這通常是事務定義的默認設置,通常定義事務的同步范圍。int PROPAGATION_REQUIRED = 0;/*** Support a current transaction; execute non-transactionally if none exists.* Analogous to the EJB transaction attribute of the same name.* <p><b>NOTE:</b> For transaction managers with transaction synchronization,* {@code PROPAGATION_SUPPORTS} is slightly different from no transaction* at all, as it defines a transaction scope that synchronization might apply to.* As a consequence, the same resources (a JDBC {@code Connection}, a* Hibernate {@code Session}, etc) will be shared for the entire specified* scope. Note that the exact behavior depends on the actual synchronization* configuration of the transaction manager!* <p>In general, use {@code PROPAGATION_SUPPORTS} with care! In particular, do* not rely on {@code PROPAGATION_REQUIRED} or {@code PROPAGATION_REQUIRES_NEW}* <i>within</i> a {@code PROPAGATION_SUPPORTS} scope (which may lead to* synchronization conflicts at runtime). If such nesting is unavoidable, make sure* to configure your transaction manager appropriately (typically switching to* "synchronization on actual transaction").* @see org.springframework.transaction.support.AbstractPlatformTransactionManager#setTransactionSynchronization* @see org.springframework.transaction.support.AbstractPlatformTransactionManager#SYNCHRONIZATION_ON_ACTUAL_TRANSACTION*/// 支持當前事務;如果不存在就按無事務的方式進行。// 對于事務同步的事務管理器{@code PROPAGATION_SUPPORTS}// 完全不同于非事務,因為可能定義了,同步可能會應用的事務范圍// 作為結果,相同的資源(jdbc 連接),Hibernate(Session 會話)等等// 會在指定的全部范圍內共享。真正的事務管理器的傳播行為取決于真正的同步配置。// // 通常,小心使用PROPAGATION_SUPPORTS!特別是,不要在PROPAGATION_SUPPORTS的范圍內(可能導致運行時同步沖突)// 使用PROPAGATION_REQUIRED和PROPAGATION_REQUIRES_NEW,如果這種嵌套不可避免,確保正確配置事務管理器。(通常切換到"真正事務上的同步")int PROPAGATION_SUPPORTS = 1;/*** Support a current transaction; throw an exception if no current transaction* exists. Analogous to the EJB transaction attribute of the same name.* <p>Note that transaction synchronization within a {@code PROPAGATION_MANDATORY}* scope will always be driven by the surrounding transaction.*/// 支持當前事務;如果不存在就按拋出異常。// 類似 相同名字的 EJB 事務 屬性。// ps:在 PROPAGATION_MANDATORY的范圍中的事務同步總會受周邊事務影響。int PROPAGATION_MANDATORY = 2;/*** Create a new transaction, suspending the current transaction if one exists.* Analogous to the EJB transaction attribute of the same name.* <p><b>NOTE:</b> Actual transaction suspension will not work out-of-the-box* on all transaction managers. This in particular applies to* {@link org.springframework.transaction.jta.JtaTransactionManager},* which requires the {@code javax.transaction.TransactionManager} to be* made available it to it (which is server-specific in standard Java EE).* <p>A {@code PROPAGATION_REQUIRES_NEW} scope always defines its own* transaction synchronizations. Existing synchronizations will be suspended* and resumed appropriately.* @see org.springframework.transaction.jta.JtaTransactionManager#setTransactionManager*/// 創建新的事務,如果當前有事務就暫停當前事務。// 類似 相同名字的 EJB 事務 屬性。// 真正的事務暫停不會在所有的事務管理器的箱體外工作。// 特別是對于 JtaTransactionManager 需要將 TransactionManager(J2EE 的服務端指定標準) 變得可行。// PROPAGATION_REQUIRES_NEW 范圍一直定義自己事務同步。// 已存在的事務會被適當的暫停和恢復。int PROPAGATION_REQUIRES_NEW = 3;/*** Do not support a current transaction; rather always execute non-transactionally.* Analogous to the EJB transaction attribute of the same name.* <p><b>NOTE:</b> Actual transaction suspension will not work out-of-the-box* on all transaction managers. This in particular applies to* {@link org.springframework.transaction.jta.JtaTransactionManager},* which requires the {@code javax.transaction.TransactionManager} to be* made available it to it (which is server-specific in standard Java EE).* <p>Note that transaction synchronization is <i>not</i> available within a* {@code PROPAGATION_NOT_SUPPORTED} scope. Existing synchronizations* will be suspended and resumed appropriately.* @see org.springframework.transaction.jta.JtaTransactionManager#setTransactionManager*/// 以無事務地方式允許,不支持當前的事務。// 類似 相同名字的 EJB 事務 屬性。// 真正的事務暫停不會在所有的事務管理器的箱體外工作。// 特別是對于 JtaTransactionManager 需要將 TransactionManager(J2EE 的服務端指定標準) 變得可行。// PROPAGATION_REQUIRES_NEW 范圍一直定義自己事務同步。// 已存在的事務會被適當的暫停和恢復。int PROPAGATION_NOT_SUPPORTED = 4;/*** Do not support a current transaction; throw an exception if a current transaction* exists. Analogous to the EJB transaction attribute of the same name.* <p>Note that transaction synchronization is <i>not</i> available within a* {@code PROPAGATION_NEVER} scope.*/// 不支持當前事務;如果當前事務存在就按拋出異常。// 類似 相同名字的 EJB 事務 屬性。// 事務同步在 PROPAGATION_NEVER 范圍內是別可用的。int PROPAGATION_NEVER = 5;/*** Execute within a nested transaction if a current transaction exists,* behave like {@link #PROPAGATION_REQUIRED} else. There is no analogous* feature in EJB.* <p><b>NOTE:</b> Actual creation of a nested transaction will only work on* specific transaction managers. Out of the box, this only applies to the JDBC* {@link org.springframework.jdbc.datasource.DataSourceTransactionManager}* when working on a JDBC 3.0 driver. Some JTA providers might support* nested transactions as well.* @see org.springframework.jdbc.datasource.DataSourceTransactionManager*/// 如果當前事務存在,在嵌套事務中執行,類似 PROPAGATION_REQUIRED 的行為。// 和 EJB 中沒有類似的。// 真正的嵌套事務的創建只會在指定的事務管理器中工作。// 當使用JDBC 3.0驅動時,在箱體外,唯一可用的是JDBC(DataSourceTransactionManager) 。// 一些 JTA 提供者也許也支持嵌套事務。int PROPAGATION_NESTED = 6;/*** Use the default isolation level of the underlying datastore.* All other levels correspond to the JDBC isolation levels.* @see java.sql.Connection*/// 在當前的數據倉庫下,使用默認的隔離級別。// 所有其他的級別和 JDBC 級別保持一致。int ISOLATION_DEFAULT = -1;/*** Indicates that dirty reads, non-repeatable reads and phantom reads* can occur.* <p>This level allows a row changed by one transaction to be read by another* transaction before any changes in that row have been committed (a "dirty read").* If any of the changes are rolled back, the second transaction will have* retrieved an invalid row.* @see java.sql.Connection#TRANSACTION_READ_UNCOMMITTED*/// 暗示臟讀,不可重復讀和幻讀有可能發生。// 這個級別允許事務改變一行數據,在這一行數據修改而提交之前,被另一個事務讀到了(臟讀)。// 如果任何改變回滾,第二個事務會恢復有一個非法的行數據。int ISOLATION_READ_UNCOMMITTED = Connection.TRANSACTION_READ_UNCOMMITTED;/*** Indicates that dirty reads are prevented; non-repeatable reads and* phantom reads can occur.* <p>This level only prohibits a transaction from reading a row* with uncommitted changes in it.* @see java.sql.Connection#TRANSACTION_READ_COMMITTED*/// 暗示臟讀會被禁止;不可重復讀和幻讀可能發生。// 這個級別會阻止事務讀取到未提交的改變。int ISOLATION_READ_COMMITTED = Connection.TRANSACTION_READ_COMMITTED;/*** Indicates that dirty reads and non-repeatable reads are prevented;* phantom reads can occur.* <p>This level prohibits a transaction from reading a row with uncommitted changes* in it, and it also prohibits the situation where one transaction reads a row,* a second transaction alters the row, and the first transaction re-reads the row,* getting different values the second time (a "non-repeatable read").* @see java.sql.Connection#TRANSACTION_REPEATABLE_READ*/// 暗示臟讀和不可重復讀會被禁止,幻讀可能發生。// 這個級別會阻止事務讀取到未提交的改變,// 也會阻止如果有事務讀取一行,第二個事務改變這行,第一個事務再讀取這行,// 第二次會有不一樣的值("不可重復讀")// 詳見 TRANSACTION_REPEATABLE_READint ISOLATION_REPEATABLE_READ = Connection.TRANSACTION_REPEATABLE_READ;/*** Indicates that dirty reads, non-repeatable reads and phantom reads* are prevented.* <p>This level includes the prohibitions in {@link #ISOLATION_REPEATABLE_READ}* and further prohibits the situation where one transaction reads all rows that* satisfy a {@code WHERE} condition, a second transaction inserts a row* that satisfies that {@code WHERE} condition, and the first transaction* re-reads for the same condition, retrieving the additional "phantom" row* in the second read.* @see java.sql.Connection#TRANSACTION_SERIALIZABLE*/// 暗示臟讀和不可重復讀和幻讀會被禁止。// 這個級別包含的禁止情況ISOLATION_REPEATABLE_READ和更多的情況,// 類似一個事務讀取所有的行(where條件)的情況,第二個事務根據(where條件)// 插入一行,第一個事務再重新執行剛才的sql,第二次讀取就會讀到額外的"幻影"行。int ISOLATION_SERIALIZABLE = Connection.TRANSACTION_SERIALIZABLE;/*** Use the default timeout of the underlying transaction system,* or none if timeouts are not supported.*/// 再當前的事務系統使用默認的超時時間,如果不支持超時時間就沒有。int TIMEOUT_DEFAULT = -1;/*** Return the propagation behavior.* <p>Must return one of the {@code PROPAGATION_XXX} constants* defined on {@link TransactionDefinition this interface}.* @return the propagation behavior* @see #PROPAGATION_REQUIRED* @see org.springframework.transaction.support.TransactionSynchronizationManager#isActualTransactionActive()*/// 返回傳播行為。// 必須返回 在 TransactionDefinition 接口中定義的 PROPAGATION_XXX 這樣的常量int getPropagationBehavior();/*** Return the isolation level.* <p>Must return one of the {@code ISOLATION_XXX} constants defined on* {@link TransactionDefinition this interface}. Those constants are designed* to match the values of the same constants on {@link java.sql.Connection}.* <p>Exclusively designed for use with {@link #PROPAGATION_REQUIRED} or* {@link #PROPAGATION_REQUIRES_NEW} since it only applies to newly started* transactions. Consider switching the "validateExistingTransactions" flag to* "true" on your transaction manager if you'd like isolation level declarations* to get rejected when participating in an existing transaction with a different* isolation level.* <p>Note that a transaction manager that does not support custom isolation levels* will throw an exception when given any other level than {@link #ISOLATION_DEFAULT}.* @return the isolation level* @see #ISOLATION_DEFAULT* @see org.springframework.transaction.support.AbstractPlatformTransactionManager#setValidateExistingTransaction*/// 返回隔離級別。// 必須返回 在 TransactionDefinition 接口中定義的 ISOLATION_XXX 這樣的常量// 這些常量被設計成和 link java.sql.Connection 中的常量一致。// PROPAGATION_REQUIRED 和 PROPAGATION_REQUIRES_NEW 被專門設計,應用于新開啟的事務。// 記得將事務管理器的"validateExistingTransactions"的標識切換至"true",// 如果你的隔離級別聲明被拒絕當有不同的隔離界別參加已存在事務時。// 事務管理器不支持普通的隔離級別,如果有默認隔離級別之外的,會拋異常。 int getIsolationLevel();/*** Return the transaction timeout.* <p>Must return a number of seconds, or {@link #TIMEOUT_DEFAULT}.* <p>Exclusively designed for use with {@link #PROPAGATION_REQUIRED} or* {@link #PROPAGATION_REQUIRES_NEW} since it only applies to newly started* transactions.* <p>Note that a transaction manager that does not support timeouts will throw* an exception when given any other timeout than {@link #TIMEOUT_DEFAULT}.* @return the transaction timeout*/// 返回事務的超時時間。// 必須返回秒數。(或者 默認超時時間)// PROPAGATION_REQUIRED 和 PROPAGATION_REQUIRES_NEW 被專門設計,應用于新開啟的事務。// 如果超時時間用在 不支持超時時間的事務管理器 會拋出異常。int getTimeout();/*** Return whether to optimize as a read-only transaction.* <p>The read-only flag applies to any transaction context, whether backed* by an actual resource transaction ({@link #PROPAGATION_REQUIRED}/* {@link #PROPAGATION_REQUIRES_NEW}) or operating non-transactionally at* the resource level ({@link #PROPAGATION_SUPPORTS}). In the latter case,* the flag will only apply to managed resources within the application,* such as a Hibernate {@code Session}.* <p>This just serves as a hint for the actual transaction subsystem;* it will <i>not necessarily</i> cause failure of write access attempts.* A transaction manager which cannot interpret the read-only hint will* <i>not</i> throw an exception when asked for a read-only transaction.* @return {@code true} if the transaction is to be optimized as read-only* @see org.springframework.transaction.support.TransactionSynchronization#beforeCommit(boolean)* @see org.springframework.transaction.support.TransactionSynchronizationManager#isCurrentTransactionReadOnly()*/// 返回事務是否只讀。// 只讀標識應用在事務作用域,無論是被真正的資源事務支持(如 PROPAGATION_REQUIRED/PROPAGATION_REQUIRES_NEW)// 或者在資源級別(PROPAGATION_SUPPORTS) 操作無事務,在后者的例子,例如 Hibernate(會話)。// 這只是對于真正的事務子系統的一個提示,不會必然導致寫嘗試進程的失敗。// 事務管理器不會解釋只讀的提示,當被一個只讀事務調用的時候不會拋出異常。// boolean isReadOnly();/*** Return the name of this transaction. Can be {@code null}.* <p>This will be used as the transaction name to be shown in a* transaction monitor, if applicable (for example, WebLogic's).* <p>In case of Spring's declarative transactions, the exposed name will be* the {@code fully-qualified class name + "." + method name} (by default).* @return the name of this transaction* @see org.springframework.transaction.interceptor.TransactionAspectSupport* @see org.springframework.transaction.support.TransactionSynchronizationManager#getCurrentTransactionName()*/// 返回事務的名稱,被用于事務監視中,可用的(如WebLogic)// 如果是spring的聲明事務,暴露的名稱就是(全類名+"."+方法名)@NullableString getName();}

@1:
?? ?transaction強轉成DataSourceTransactionObject,先去看一下 DataSourceTransactionObject 是什么類。
?? ?DataSourceTransactionObject是DataSourceTransactionManager的內部類。

? ??DataSourceTransactionObject類說明:

/*** DataSource transaction object, representing a ConnectionHolder.* Used as transaction object by DataSourceTransactionManager.*/// 數據源事務的對象,代表連接保持器,作為事務對象被DataSourceTransactionManager調用。

@2:
?? ?hasConnectionHolder()是JdbcTransactionObjectSupport的方法。判斷該類的connectionHandle 是否為空。

?? ?JdbcTransactionObjectSupport 是什么鬼,看一下,抽象類 實現了 SavepointManager 和 SmartTransactionObject。

/*** Convenient base class for JDBC-aware transaction objects. Can contain a* {@link ConnectionHolder} with a JDBC {@code Connection}, and implements the* {@link SavepointManager} interface based on that {@code ConnectionHolder}.** <p>Allows for programmatic management of JDBC {@link java.sql.Savepoint Savepoints}.* Spring's {@link org.springframework.transaction.support.DefaultTransactionStatus}* automatically delegates to this, as it autodetects transaction objects which* implement the {@link SavepointManager} interface.*///便于jdbc的事務對象繼承的基類。能夠獲得jdbc連接狀態,實現了SavepointManager接口。//允許對jdbc程序化管理,spring的默認事務狀態自動委托給這個,自動檢測事務對象。public abstract class JdbcTransactionObjectSupport implements SavepointManager, SmartTransactionObject

再看SavepointManager 。

仨方法: 創建/回滾到/釋放 保存點。

/*** Interface that specifies an API to programmatically manage transaction* savepoints in a generic fashion. Extended by TransactionStatus to* expose savepoint management functionality for a specific transaction.** <p>Note that savepoints can only work within an active transaction.* Just use this programmatic savepoint handling for advanced needs;* else, a subtransaction with PROPAGATION_NESTED is preferable.** <p>This interface is inspired by JDBC 3.0's Savepoint mechanism* but is independent from any specific persistence technology.**/// 是一個接口指定的API能夠在通常情況下程序化地管理事務保存點。// 對于指定的事務,擴展的事務狀態展示了功能化的保存點管理。// ps:保存點出現在活躍事務中,在高級需求中使用程序化保存點,// 當用到 PROPAGATION_NESTED 級別的子事務的時候更好。// 這個接口受啟發于jdbc3.0保存點原理,但是獨立于任何特定的持久化技術。public interface SavepointManager {/*** Create a new savepoint. You can roll back to a specific savepoint* via {@code rollbackToSavepoint}, and explicitly release a savepoint* that you don't need anymore via {@code releaseSavepoint}.* <p>Note that most transaction managers will automatically release* savepoints at transaction completion.* @return a savepoint object, to be passed into* {@link #rollbackToSavepoint} or {@link #releaseSavepoint}* @throws NestedTransactionNotSupportedException if the underlying* transaction does not support savepoints* @throws TransactionException if the savepoint could not be created,* for example because the transaction is not in an appropriate state* @see java.sql.Connection#setSavepoint*///創建保存點,能夠通過rollbackToSavepoint回滾到特定的保存點,可以在//不需要的時候通過releaseSavepoint方法釋放保存點。大部分事務管理器會在事務//完成的時候釋放保存點。Object createSavepoint() throws TransactionException;/*** Roll back to the given savepoint.* <p>The savepoint will <i>not</i> be automatically released afterwards.* You may explicitly call {@link #releaseSavepoint(Object)} or rely on* automatic release on transaction completion.* @param savepoint the savepoint to roll back to* @throws NestedTransactionNotSupportedException if the underlying* transaction does not support savepoints* @throws TransactionException if the rollback failed* @see java.sql.Connection#rollback(java.sql.Savepoint)*///回滾到給出的保存點。//保存點最后不會自動釋放。可以調用釋放方法或者等事務結束自動關閉。void rollbackToSavepoint(Object savepoint) throws TransactionException;/*** Explicitly release the given savepoint.* <p>Note that most transaction managers will automatically release* savepoints on transaction completion.* <p>Implementations should fail as silently as possible if proper* resource cleanup will eventually happen at transaction completion.* @param savepoint the savepoint to release* @throws NestedTransactionNotSupportedException if the underlying* transaction does not support savepoints* @throws TransactionException if the release failed* @see java.sql.Connection#releaseSavepoint*///釋放保存點//大部分事務管理器會在事務完成的時候釋放保存點。//如果正確的資源清理在事務結束時發生,這個方法實現可能失敗。void releaseSavepoint(Object savepoint) throws TransactionException;}

?一句話概括一下就是,嵌套事務中有個存檔,當我們設置了存檔,出異常的事務可以回滾到存檔,不至于全部回滾。
?? ? 嵌套事務(事務隔壁級別是PROPAGATION_NESTED) 食用更佳。


SmartTransactionObject

public interface SmartTransactionObject extends Flushable {/*** Interface to be implemented by transaction objects that are able to* return an internal rollback-only marker, typically from a another* transaction that has participated and marked it as rollback-only.** <p>Autodetected by DefaultTransactionStatus, to always return a* current rollbackOnly flag even if not resulting from the current* TransactionStatus.*///被用于事務對象實現的接口能夠返回一個內部的僅回滾標記,代表有另一個事務參與并標記為僅回滾。/*** Return whether the transaction is internally marked as rollback-only.* Can, for example, check the JTA UserTransaction.* @see javax.transaction.UserTransaction#getStatus* @see javax.transaction.Status#STATUS_MARKED_ROLLBACK*///返回是否有另一個事務參與。boolean isRollbackOnly();/*** Flush the underlying sessions to the datastore, if applicable:* for example, all affected Hibernate/JPA sessions.*///如果適用的話,刷新潛在的會話回數據源,比如所有的影響的Hibernate/JPA會話。(清理緩存區的資源)@Overridevoid flush();}

@3: isSynchronizedWithTransaction() 是ResourceHolderSupport 類中的方法

/*** Convenient base class for resource holders.** <p>Features rollback-only support for participating transactions.* Can expire after a certain number of seconds or milliseconds* in order to determine a transactional timeout.*///資源持有者的實用的基類//為了讓事務能夠在一定時間內過期,對于參與進來的事務提供僅回滾的支持public abstract class ResourceHolderSupport implements ResourceHolder/*** Return whether the resource is synchronized with a transaction.*/// 當前資源持有者是否與事務同步public boolean isSynchronizedWithTransaction() {return this.synchronizedWithTransaction;} }

?

?


再看實現的接口 ResourceHolder
?? ??? ???

/*** Generic interface to be implemented by resource holders.* Allows Spring's transaction infrastructure to introspect* and reset the holder when necessary.**///通用接口用來被資源持有者實現。允許spring的事務架構必要時直接看到和重置持有者。public interface ResourceHolder {/*** Reset the transactional state of this holder.*/// 重置持有者的事務狀態。void reset();/*** Notify this holder that it has been unbound from transaction synchronization.*/// 通知持有者已經和事務同步解綁了void unbound();/*** Determine whether this holder is considered as 'void',* i.e. as a leftover from a previous thread.*/// 決定持有者是否是'無效的'boolean isVoid();}

@5: 數據源工具類,這里用到的是prepareConnectionForTransaction,具體看下面的方法注釋。

/*** Helper class that provides static methods for obtaining JDBC Connections from* a {@link javax.sql.DataSource}. Includes special support for Spring-managed* transactional Connections, e.g. managed by {@link DataSourceTransactionManager}* or {@link org.springframework.transaction.jta.JtaTransactionManager}.** <p>Used internally by Spring's {@link org.springframework.jdbc.core.JdbcTemplate},* Spring's JDBC operation objects and the JDBC {@link DataSourceTransactionManager}.* Can also be used directly in application code.*///工具類提供靜態方法,從數據源中獲取jdbc連接,包括對spring管理的事務攔截的特別支撐,//在被spring的JdbcTemplate,spring的jdbc操作對象和jdbc事務管理器使用。也能被直接用在應用代碼中。 public abstract class DataSourceUtils {/*** Order value for TransactionSynchronization objects that clean up JDBC Connections.*/// TransactionSynchronization清理jdbc連接的對象的順序值public static final int CONNECTION_SYNCHRONIZATION_ORDER = 1000;private static final Log logger = LogFactory.getLog(DataSourceUtils.class);/*** Obtain a Connection from the given DataSource. Translates SQLExceptions into* the Spring hierarchy of unchecked generic data access exceptions, simplifying* calling code and making any exception that is thrown more meaningful.* <p>Is aware of a corresponding Connection bound to the current thread, for example* when using {@link DataSourceTransactionManager}. Will bind a Connection to the* thread if transaction synchronization is active, e.g. when running within a* {@link org.springframework.transaction.jta.JtaTransactionManager JTA} transaction).* @param dataSource the DataSource to obtain Connections from* @return a JDBC Connection from the given DataSource* @throws org.springframework.jdbc.CannotGetJdbcConnectionException* if the attempt to get a Connection failed* @see #releaseConnection*///通過數據源獲取連接。將sql異常拋給spring的層級中未檢查的普通數據,簡化調用代碼,讓任何異常都清晰//要知道比如使用連接池數據管理器,一致的連接是和當前線程綁定。//舉例子,如果JTA事務中,同步事務被激活,連接和線程綁定。public static Connection getConnection(DataSource dataSource) throws CannotGetJdbcConnectionException {try {return doGetConnection(dataSource);}catch (SQLException ex) {throw new CannotGetJdbcConnectionException("Failed to obtain JDBC Connection", ex);}catch (IllegalStateException ex) {throw new CannotGetJdbcConnectionException("Failed to obtain JDBC Connection: " + ex.getMessage());}}/*** Actually obtain a JDBC Connection from the given DataSource.* Same as {@link #getConnection}, but throwing the original SQLException.* <p>Is aware of a corresponding Connection bound to the current thread, for example* when using {@link DataSourceTransactionManager}. Will bind a Connection to the thread* if transaction synchronization is active (e.g. if in a JTA transaction).* <p>Directly accessed by {@link TransactionAwareDataSourceProxy}.* @param dataSource the DataSource to obtain Connections from* @return a JDBC Connection from the given DataSource* @throws SQLException if thrown by JDBC methods* @see #doReleaseConnection*///獲取當前數據源的真正連接//和getConnection方法一樣,但拋出的是原始的sql異常。//要知道比如使用連接池數據管理器,一致的連接是和當前線程綁定。//舉例子,如果JTA事務中,同步事務被激活,連接和線程綁定。public static Connection doGetConnection(DataSource dataSource) throws SQLException {Assert.notNull(dataSource, "No DataSource specified");ConnectionHolder conHolder = (ConnectionHolder) TransactionSynchronizationManager.getResource(dataSource);if (conHolder != null && (conHolder.hasConnection() || conHolder.isSynchronizedWithTransaction())) {conHolder.requested();if (!conHolder.hasConnection()) {logger.debug("Fetching resumed JDBC Connection from DataSource");conHolder.setConnection(fetchConnection(dataSource));}return conHolder.getConnection();}// Else we either got no holder or an empty thread-bound holder here.logger.debug("Fetching JDBC Connection from DataSource");Connection con = fetchConnection(dataSource);if (TransactionSynchronizationManager.isSynchronizationActive()) {logger.debug("Registering transaction synchronization for JDBC Connection");// Use same Connection for further JDBC actions within the transaction.// Thread-bound object will get removed by synchronization at transaction completion.ConnectionHolder holderToUse = conHolder;if (holderToUse == null) {holderToUse = new ConnectionHolder(con);}else {holderToUse.setConnection(con);}holderToUse.requested();TransactionSynchronizationManager.registerSynchronization(new ConnectionSynchronization(holderToUse, dataSource));holderToUse.setSynchronizedWithTransaction(true);if (holderToUse != conHolder) {TransactionSynchronizationManager.bindResource(dataSource, holderToUse);}}return con;}/*** Actually fetch a {@link Connection} from the given {@link DataSource},* defensively turning an unexpected {@code null} return value from* {@link DataSource#getConnection()} into an {@link IllegalStateException}.* @param dataSource the DataSource to obtain Connections from* @return a JDBC Connection from the given DataSource (never {@code null})* @throws SQLException if thrown by JDBC methods* @throws IllegalStateException if the DataSource returned a null value* @see DataSource#getConnection()*///從數據源獲取連接,如果返回空,拋異常。private static Connection fetchConnection(DataSource dataSource) throws SQLException {Connection con = dataSource.getConnection();if (con == null) {throw new IllegalStateException("DataSource returned null from getConnection(): " + dataSource);}return con;}/*** Prepare the given Connection with the given transaction semantics.* @param con the Connection to prepare* @param definition the transaction definition to apply* @return the previous isolation level, if any* @throws SQLException if thrown by JDBC methods* @see #resetConnectionAfterTransaction*///準備給傳入的連接加事務@Nullable public static Integer prepareConnectionForTransaction(Connection con, @Nullable TransactionDefinition definition)throws SQLException {Assert.notNull(con, "No Connection specified");// Set read-only flag.if (definition != null && definition.isReadOnly()) {try {if (logger.isDebugEnabled()) {logger.debug("Setting JDBC Connection [" + con + "] read-only");}con.setReadOnly(true);}catch (SQLException | RuntimeException ex) {Throwable exToCheck = ex;while (exToCheck != null) {if (exToCheck.getClass().getSimpleName().contains("Timeout")) {// Assume it's a connection timeout that would otherwise get lost: e.g. from JDBC 4.0throw ex;}exToCheck = exToCheck.getCause();}// "read-only not supported" SQLException -> ignore, it's just a hint anyway//只讀不支持sql異常,忽略這個,只是一個提示logger.debug("Could not set JDBC Connection read-only", ex);}}// Apply specific isolation level, if any.//接受任何的隔離級別Integer previousIsolationLevel = null;if (definition != null && definition.getIsolationLevel() != TransactionDefinition.ISOLATION_DEFAULT) {if (logger.isDebugEnabled()) {logger.debug("Changing isolation level of JDBC Connection [" + con + "] to " +definition.getIsolationLevel());}int currentIsolation = con.getTransactionIsolation();if (currentIsolation != definition.getIsolationLevel()) {previousIsolationLevel = currentIsolation;con.setTransactionIsolation(definition.getIsolationLevel());}}return previousIsolationLevel;}/*** Reset the given Connection after a transaction,* regarding read-only flag and isolation level.* @param con the Connection to reset* @param previousIsolationLevel the isolation level to restore, if any* @see #prepareConnectionForTransaction*///重置給定連接的事務,包括只讀標識和隔離級別public static void resetConnectionAfterTransaction(Connection con, @Nullable Integer previousIsolationLevel) {Assert.notNull(con, "No Connection specified");try {// Reset transaction isolation to previous value, if changed for the transaction.// 如果事務更改,則將事務隔離重置為前值if (previousIsolationLevel != null) {if (logger.isDebugEnabled()) {logger.debug("Resetting isolation level of JDBC Connection [" +con + "] to " + previousIsolationLevel);}con.setTransactionIsolation(previousIsolationLevel);}// Reset read-only flag.if (con.isReadOnly()) {if (logger.isDebugEnabled()) {logger.debug("Resetting read-only flag of JDBC Connection [" + con + "]");}con.setReadOnly(false);}}catch (Throwable ex) {logger.debug("Could not reset JDBC Connection after transaction", ex);}}/*** Determine whether the given JDBC Connection is transactional, that is,* bound to the current thread by Spring's transaction facilities.* @param con the Connection to check* @param dataSource the DataSource that the Connection was obtained from* (may be {@code null})* @return whether the Connection is transactional*///決定給定的jdbc連接是否支持事務,spring事務設置的是和當前線程綁定。public static boolean isConnectionTransactional(Connection con, @Nullable DataSource dataSource) {if (dataSource == null) {return false;}ConnectionHolder conHolder = (ConnectionHolder) TransactionSynchronizationManager.getResource(dataSource);return (conHolder != null && connectionEquals(conHolder, con));}/*** Apply the current transaction timeout, if any,* to the given JDBC Statement object.* @param stmt the JDBC Statement object* @param dataSource the DataSource that the Connection was obtained from* @throws SQLException if thrown by JDBC methods* @see java.sql.Statement#setQueryTimeout*///如果有的話,對于jdbc陳述對象的,應用當前事務的聲明的超時時間。public static void applyTransactionTimeout(Statement stmt, @Nullable DataSource dataSource) throws SQLException {applyTimeout(stmt, dataSource, -1);}/*** Apply the specified timeout - overridden by the current transaction timeout,* if any - to the given JDBC Statement object.* @param stmt the JDBC Statement object* @param dataSource the DataSource that the Connection was obtained from* @param timeout the timeout to apply (or 0 for no timeout outside of a transaction)* @throws SQLException if thrown by JDBC methods* @see java.sql.Statement#setQueryTimeout*///如果有的話,對于jdbc陳述對象的,接受被當前事務所覆蓋的特定的超時時間。public static void applyTimeout(Statement stmt, @Nullable DataSource dataSource, int timeout) throws SQLException {Assert.notNull(stmt, "No Statement specified");ConnectionHolder holder = null;if (dataSource != null) {holder = (ConnectionHolder) TransactionSynchronizationManager.getResource(dataSource);}if (holder != null && holder.hasTimeout()) {// Remaining transaction timeout overrides specified value.stmt.setQueryTimeout(holder.getTimeToLiveInSeconds());}else if (timeout >= 0) {// No current transaction timeout -> apply specified value.stmt.setQueryTimeout(timeout);}}/*** Close the given Connection, obtained from the given DataSource,* if it is not managed externally (that is, not bound to the thread).* @param con the Connection to close if necessary* (if this is {@code null}, the call will be ignored)* @param dataSource the DataSource that the Connection was obtained from* (may be {@code null})* @see #getConnection*///如果不是外部管理(非線程綁定),關閉從數據源獲取到的連接。public static void releaseConnection(@Nullable Connection con, @Nullable DataSource dataSource) {try {doReleaseConnection(con, dataSource);}catch (SQLException ex) {logger.debug("Could not close JDBC Connection", ex);}catch (Throwable ex) {logger.debug("Unexpected exception on closing JDBC Connection", ex);}}/*** Actually close the given Connection, obtained from the given DataSource.* Same as {@link #releaseConnection}, but throwing the original SQLException.* <p>Directly accessed by {@link TransactionAwareDataSourceProxy}.* @param con the Connection to close if necessary* (if this is {@code null}, the call will be ignored)* @param dataSource the DataSource that the Connection was obtained from* (may be {@code null})* @throws SQLException if thrown by JDBC methods* @see #doGetConnection*///真實關閉從數據源獲取到的連接,和釋放連接方法一樣,但是拋出一個sql異常public static void doReleaseConnection(@Nullable Connection con, @Nullable DataSource dataSource) throws SQLException {if (con == null) {return;}if (dataSource != null) {ConnectionHolder conHolder = (ConnectionHolder) TransactionSynchronizationManager.getResource(dataSource);if (conHolder != null && connectionEquals(conHolder, con)) {// It's the transactional Connection: Don't close it.conHolder.released();return;}}logger.debug("Returning JDBC Connection to DataSource");doCloseConnection(con, dataSource);}/*** Close the Connection, unless a {@link SmartDataSource} doesn't want us to.* @param con the Connection to close if necessary* @param dataSource the DataSource that the Connection was obtained from* @throws SQLException if thrown by JDBC methods* @see Connection#close()* @see SmartDataSource#shouldClose(Connection)*///關閉異常,除非SmartDataSource 不想讓我們關閉。public static void doCloseConnection(Connection con, @Nullable DataSource dataSource) throws SQLException {if (!(dataSource instanceof SmartDataSource) || ((SmartDataSource) dataSource).shouldClose(con)) {con.close();}}/*** Determine whether the given two Connections are equal, asking the target* Connection in case of a proxy. Used to detect equality even if the* user passed in a raw target Connection while the held one is a proxy.* @param conHolder the ConnectionHolder for the held Connection (potentially a proxy)* @param passedInCon the Connection passed-in by the user* (potentially a target Connection without proxy)* @return whether the given Connections are equal* @see #getTargetConnection*///比較兩個連接是否相同,詢問目標連接是否是代理,如果用戶在原目標連接傳遞,//當保持其中一個目標連接是代理的時候,檢測是否相同private static boolean connectionEquals(ConnectionHolder conHolder, Connection passedInCon) {if (!conHolder.hasConnection()) {return false;}Connection heldCon = conHolder.getConnection();// Explicitly check for identity too: for Connection handles that do not implement// "equals" properly, such as the ones Commons DBCP exposes).return (heldCon == passedInCon || heldCon.equals(passedInCon) ||getTargetConnection(heldCon).equals(passedInCon));}/*** Return the innermost target Connection of the given Connection. If the given* Connection is a proxy, it will be unwrapped until a non-proxy Connection is* found. Otherwise, the passed-in Connection will be returned as-is.* @param con the Connection proxy to unwrap* @return the innermost target Connection, or the passed-in one if no proxy* @see ConnectionProxy#getTargetConnection()*///返回最深層的目標連接,如果連接是代理的,將會去包裝直到非代理連接。//否則,傳遞的連接將會被返回。public static Connection getTargetConnection(Connection con) {Connection conToUse = con;while (conToUse instanceof ConnectionProxy) {conToUse = ((ConnectionProxy) conToUse).getTargetConnection();}return conToUse;}/*** Determine the connection synchronization order to use for the given* DataSource. Decreased for every level of nesting that a DataSource* has, checked through the level of DelegatingDataSource nesting.* @param dataSource the DataSource to check* @return the connection synchronization order to use* @see #CONNECTION_SYNCHRONIZATION_ORDER*///決定連接同步為了使用給定的數據源。減少數據源的嵌套層級,通過代理數據源的嵌套//檢測層級private static int getConnectionSynchronizationOrder(DataSource dataSource) {int order = CONNECTION_SYNCHRONIZATION_ORDER;DataSource currDs = dataSource;while (currDs instanceof DelegatingDataSource) {order--;currDs = ((DelegatingDataSource) currDs).getTargetDataSource();}return order;}/*** Callback for resource cleanup at the end of a non-native JDBC transaction* (e.g. when participating in a JtaTransactionManager transaction).* @see org.springframework.transaction.jta.JtaTransactionManager*///在非本地jdbc事務結束時資源清理的回調private static class ConnectionSynchronization extends TransactionSynchronizationAdapter {private final ConnectionHolder connectionHolder;private final DataSource dataSource;private int order;private boolean holderActive = true;public ConnectionSynchronization(ConnectionHolder connectionHolder, DataSource dataSource) {this.connectionHolder = connectionHolder;this.dataSource = dataSource;this.order = getConnectionSynchronizationOrder(dataSource);}@Overridepublic int getOrder() {return this.order;}@Overridepublic void suspend() {if (this.holderActive) {TransactionSynchronizationManager.unbindResource(this.dataSource);if (this.connectionHolder.hasConnection() && !this.connectionHolder.isOpen()) {// Release Connection on suspend if the application doesn't keep// a handle to it anymore. We will fetch a fresh Connection if the// application accesses the ConnectionHolder again after resume,// assuming that it will participate in the same transaction.//如果應用不再保持連接,暫停釋放資源。再應用再次獲取連接持有者后,會再次獲取新的連接,//假設仍會參與到相同的事務中releaseConnection(this.connectionHolder.getConnection(), this.dataSource);this.connectionHolder.setConnection(null);}}}@Overridepublic void resume() {if (this.holderActive) {TransactionSynchronizationManager.bindResource(this.dataSource, this.connectionHolder);}}@Overridepublic void beforeCompletion() {// Release Connection early if the holder is not open anymore// (that is, not used by another resource like a Hibernate Session// that has its own cleanup via transaction synchronization),// to avoid issues with strict JTA implementations that expect// the close call before transaction completion.// 如果連接不再開放,早早釋放連接,不像Hibernate的另一個資源在事務同步的時候有會// 自己清理,避免在事務結束前,JTA實現的問題。if (!this.connectionHolder.isOpen()) {TransactionSynchronizationManager.unbindResource(this.dataSource);this.holderActive = false;if (this.connectionHolder.hasConnection()) {releaseConnection(this.connectionHolder.getConnection(), this.dataSource);}}}@Overridepublic void afterCompletion(int status) {// If we haven't closed the Connection in beforeCompletion,// close it now. The holder might have been used for other// cleanup in the meantime, for example by a Hibernate Session.// 如果在完成前不關閉連接,現在關閉。這個保持可能同時已經被另一個清理所使用,比如Hibernate會話。if (this.holderActive) {// The thread-bound ConnectionHolder might not be available anymore,// since afterCompletion might get called from a different thread.// 這個線程綁定的連接持有者也許不再可用,自從完成之后可能會不同的線程回調。TransactionSynchronizationManager.unbindResourceIfPossible(this.dataSource);this.holderActive = false;if (this.connectionHolder.hasConnection()) {releaseConnection(this.connectionHolder.getConnection(), this.dataSource);// Reset the ConnectionHolder: It might remain bound to the thread.// 重置連接保持器:也許能夠和線程綁定。this.connectionHolder.setConnection(null);}}this.connectionHolder.reset();}}}

@6 :?? prepareTransactionalConnection 方法

/*** Prepare the transactional {@code Connection} right after transaction begin.* <p>The default implementation executes a "SET TRANSACTION READ ONLY" statement* if the {@link #setEnforceReadOnly "enforceReadOnly"} flag is set to {@code true}* and the transaction definition indicates a read-only transaction.* <p>The "SET TRANSACTION READ ONLY" is understood by Oracle, MySQL and Postgres* and may work with other databases as well. If you'd like to adapt this treatment,* override this method accordingly.* @param con the transactional JDBC Connection* @param definition the current transaction definition* @throws SQLException if thrown by JDBC API* @since 4.3.7* @see #setEnforceReadOnly*/// 事務開啟后準備正常的事務連接。// 如果 enforceReadOnly 標識是true、事務定義標示一個只讀事務,默認的實現執行了"設置事務為只讀" 語句。// "設置事務只讀"是oracle,mysql和postgres和其他數據庫的理解。 如果你想適應這個方式,按照一致規則重寫這個方法。protected void prepareTransactionalConnection(Connection con, TransactionDefinition definition)throws SQLException {if (isEnforceReadOnly() && definition.isReadOnly()) {Statement stmt = con.createStatement();try {stmt.executeUpdate("SET TRANSACTION READ ONLY");}finally {stmt.close();}}}

@7:?? ??? ?ConnectionHolder

/*** Connection holder, wrapping a JDBC Connection.* {@link DataSourceTransactionManager} binds instances of this class* to the thread, for a specific DataSource.** <p>Inherits rollback-only support for nested JDBC transactions* and reference count functionality from the base class.** <p>Note: This is an SPI class, not intended to be used by applications.*///連接持有者,是對jdbc連接的包裝。事務管理器是和當前類實例和線程綁定的,目的是指定連接池。//對于嵌套的hdbc事務,從基類繼承了僅回滾的支持和功能上的引用計數。//這是一個service provider interface class,不被任何應用使用。public class ConnectionHolder extends ResourceHolderSupport {public static final String SAVEPOINT_NAME_PREFIX = "SAVEPOINT_";@Nullableprivate ConnectionHandle connectionHandle;@Nullableprivate Connection currentConnection;private boolean transactionActive = false;@Nullableprivate Boolean savepointsSupported;private int savepointCounter = 0;/*** Create a new ConnectionHolder for the given ConnectionHandle.* @param connectionHandle the ConnectionHandle to hold*///創建連接持有者public ConnectionHolder(ConnectionHandle connectionHandle) {Assert.notNull(connectionHandle, "ConnectionHandle must not be null");this.connectionHandle = connectionHandle;}/*** Create a new ConnectionHolder for the given JDBC Connection,* wrapping it with a {@link SimpleConnectionHandle},* assuming that there is no ongoing transaction.* @param connection the JDBC Connection to hold* @see SimpleConnectionHandle* @see #ConnectionHolder(java.sql.Connection, boolean)*/public ConnectionHolder(Connection connection) {this.connectionHandle = new SimpleConnectionHandle(connection);}/*** Create a new ConnectionHolder for the given JDBC Connection,* wrapping it with a {@link SimpleConnectionHandle}.* @param connection the JDBC Connection to hold* @param transactionActive whether the given Connection is involved* in an ongoing transaction* @see SimpleConnectionHandle*/public ConnectionHolder(Connection connection, boolean transactionActive) {this(connection);this.transactionActive = transactionActive;}/*** Return the ConnectionHandle held by this ConnectionHolder.*/@Nullablepublic ConnectionHandle getConnectionHandle() {return this.connectionHandle;}/*** Return whether this holder currently has a Connection.*/protected boolean hasConnection() {return (this.connectionHandle != null);}/*** Set whether this holder represents an active, JDBC-managed transaction.* @see DataSourceTransactionManager*/protected void setTransactionActive(boolean transactionActive) {this.transactionActive = transactionActive;}/*** Return whether this holder represents an active, JDBC-managed transaction.*///返回當前持有者是否代表了活動的jdbc管理的事務。protected boolean isTransactionActive() {return this.transactionActive;}/*** Override the existing Connection handle with the given Connection.* Reset the handle if given {@code null}.* <p>Used for releasing the Connection on suspend (with a {@code null}* argument) and setting a fresh Connection on resume.*/protected void setConnection(@Nullable Connection connection) {if (this.currentConnection != null) {if (this.connectionHandle != null) {this.connectionHandle.releaseConnection(this.currentConnection);}this.currentConnection = null;}if (connection != null) {this.connectionHandle = new SimpleConnectionHandle(connection);}else {this.connectionHandle = null;}}/*** Return the current Connection held by this ConnectionHolder.* <p>This will be the same Connection until {@code released}* gets called on the ConnectionHolder, which will reset the* held Connection, fetching a new Connection on demand.* @see ConnectionHandle#getConnection()* @see #released()*/public Connection getConnection() {Assert.notNull(this.connectionHandle, "Active Connection is required");if (this.currentConnection == null) {this.currentConnection = this.connectionHandle.getConnection();}return this.currentConnection;}/*** Return whether JDBC 3.0 Savepoints are supported.* Caches the flag for the lifetime of this ConnectionHolder.* @throws SQLException if thrown by the JDBC driver*/public boolean supportsSavepoints() throws SQLException {if (this.savepointsSupported == null) {this.savepointsSupported = getConnection().getMetaData().supportsSavepoints();}return this.savepointsSupported;}/*** Create a new JDBC 3.0 Savepoint for the current Connection,* using generated savepoint names that are unique for the Connection.* @return the new Savepoint* @throws SQLException if thrown by the JDBC driver*/public Savepoint createSavepoint() throws SQLException {this.savepointCounter++;return getConnection().setSavepoint(SAVEPOINT_NAME_PREFIX + this.savepointCounter);}/*** Releases the current Connection held by this ConnectionHolder.* <p>This is necessary for ConnectionHandles that expect "Connection borrowing",* where each returned Connection is only temporarily leased and needs to be* returned once the data operation is done, to make the Connection available* for other operations within the same transaction.*/@Overridepublic void released() {super.released();if (!isOpen() && this.currentConnection != null) {if (this.connectionHandle != null) {this.connectionHandle.releaseConnection(this.currentConnection);}this.currentConnection = null;}}@Overridepublic void clear() {super.clear();this.transactionActive = false;this.savepointsSupported = null;this.savepointCounter = 0;}}

@8:?? ?TransactionSynchronizationManager 這個類比較重要,也就是多線程事務的關鍵。
?? ?簡單來說,這個類里邊維護了很多個線程副本(ThreadLocal)。我們都知道線程副本和當前線程綁定,
?? ?通過get方法可以獲取與當前線程與key對應的值。
?? ?其中包含 資源,事務的同步狀態,名稱,只讀標識,隔離級別,和真正的活躍的事務(多數都是代理,去除代理找到真正的非代理對象)。

?? ?這里的調用的綁定資源方法key是當前數據源,value是當前連接持有者。

/*** Central delegate that manages resources and transaction synchronizations per thread.* To be used by resource management code but not by typical application code.* * <p>Supports one resource per key without overwriting, that is, a resource needs* to be removed before a new one can be set for the same key.* Supports a list of transaction synchronizations if synchronization is active.** <p>Resource management code should check for thread-bound resources, e.g. JDBC* Connections or Hibernate Sessions, via {@code getResource}. Such code is* normally not supposed to bind resources to threads, as this is the responsibility* of transaction managers. A further option is to lazily bind on first use if* transaction synchronization is active, for performing transactions that span* an arbitrary number of resources.** <p>Transaction synchronization must be activated and deactivated by a transaction* manager via {@link #initSynchronization()} and {@link #clearSynchronization()}.* This is automatically supported by {@link AbstractPlatformTransactionManager},* and thus by all standard Spring transaction managers, such as* {@link org.springframework.transaction.jta.JtaTransactionManager} and* {@link org.springframework.jdbc.datasource.DataSourceTransactionManager}.** <p>Resource management code should only register synchronizations when this* manager is active, which can be checked via {@link #isSynchronizationActive};* it should perform immediate resource cleanup else. If transaction synchronization* isn't active, there is either no current transaction, or the transaction manager* doesn't support transaction synchronization.** <p>Synchronization is for example used to always return the same resources* within a JTA transaction, e.g. a JDBC Connection or a Hibernate Session for* any given DataSource or SessionFactory, respectively.**/// 中央對每個線程委托管理資源和事務同步。 public abstract class TransactionSynchronizationManager {private static final Log logger = LogFactory.getLog(TransactionSynchronizationManager.class);private static final ThreadLocal<Map<Object, Object>> resources =new NamedThreadLocal<>("Transactional resources");private static final ThreadLocal<Set<TransactionSynchronization>> synchronizations =new NamedThreadLocal<>("Transaction synchronizations");private static final ThreadLocal<String> currentTransactionName =new NamedThreadLocal<>("Current transaction name");private static final ThreadLocal<Boolean> currentTransactionReadOnly =new NamedThreadLocal<>("Current transaction read-only status");private static final ThreadLocal<Integer> currentTransactionIsolationLevel =new NamedThreadLocal<>("Current transaction isolation level");private static final ThreadLocal<Boolean> actualTransactionActive =new NamedThreadLocal<>("Actual transaction active");//-------------------------------------------------------------------------// Management of transaction-associated resource handles//--------------------------------------------------------------------------/*** Return all resources that are bound to the current thread.* <p>Mainly for debugging purposes. Resource managers should always invoke* {@code hasResource} for a specific resource key that they are interested in.* @return a Map with resource keys (usually the resource factory) and resource* values (usually the active resource object), or an empty Map if there are* currently no resources bound* @see #hasResource*/public static Map<Object, Object> getResourceMap() {Map<Object, Object> map = resources.get();return (map != null ? Collections.unmodifiableMap(map) : Collections.emptyMap());}/*** Check if there is a resource for the given key bound to the current thread.* @param key the key to check (usually the resource factory)* @return if there is a value bound to the current thread* @see ResourceTransactionManager#getResourceFactory()*/public static boolean hasResource(Object key) {Object actualKey = TransactionSynchronizationUtils.unwrapResourceIfNecessary(key);Object value = doGetResource(actualKey);return (value != null);}/*** Retrieve a resource for the given key that is bound to the current thread.* @param key the key to check (usually the resource factory)* @return a value bound to the current thread (usually the active* resource object), or {@code null} if none* @see ResourceTransactionManager#getResourceFactory()*/@Nullablepublic static Object getResource(Object key) {Object actualKey = TransactionSynchronizationUtils.unwrapResourceIfNecessary(key);Object value = doGetResource(actualKey);if (value != null && logger.isTraceEnabled()) {logger.trace("Retrieved value [" + value + "] for key [" + actualKey + "] bound to thread [" +Thread.currentThread().getName() + "]");}return value;}/*** Actually check the value of the resource that is bound for the given key.*/@Nullableprivate static Object doGetResource(Object actualKey) {Map<Object, Object> map = resources.get();if (map == null) {return null;}Object value = map.get(actualKey);// Transparently remove ResourceHolder that was marked as void...if (value instanceof ResourceHolder && ((ResourceHolder) value).isVoid()) {map.remove(actualKey);// Remove entire ThreadLocal if empty...if (map.isEmpty()) {resources.remove();}value = null;}return value;}/*** Bind the given resource for the given key to the current thread.* @param key the key to bind the value to (usually the resource factory)* @param value the value to bind (usually the active resource object)* @throws IllegalStateException if there is already a value bound to the thread* @see ResourceTransactionManager#getResourceFactory()*/// 將給定的key和給定的資源和當前線程綁定。// key和value對應(通常是資源工廠)// value和(通常是活躍的資源對象)綁定// 如果當前線程已經有一個值綁定了,會拋出異常public static void bindResource(Object key, Object value) throws IllegalStateException {//將key去包裝,直到找到非包裝對象 unwrapResourceIfNecessary 中方法判斷是aop還是實現InfrastructureProxy接口的,再調各種的去除包裝的方法Object actualKey = TransactionSynchronizationUtils.unwrapResourceIfNecessary(key);Assert.notNull(value, "Value must not be null");Map<Object, Object> map = resources.get();// set ThreadLocal Map if none foundif (map == null) {map = new HashMap<>();resources.set(map);}Object oldValue = map.put(actualKey, value);// Transparently suppress a ResourceHolder that was marked as void...// 無效的資源所有者被標記為透明if (oldValue instanceof ResourceHolder && ((ResourceHolder) oldValue).isVoid()) {oldValue = null;}if (oldValue != null) {throw new IllegalStateException("Already value [" + oldValue + "] for key [" +actualKey + "] bound to thread [" + Thread.currentThread().getName() + "]");}if (logger.isTraceEnabled()) {logger.trace("Bound value [" + value + "] for key [" + actualKey + "] to thread [" +Thread.currentThread().getName() + "]");}}/*** Unbind a resource for the given key from the current thread.* @param key the key to unbind (usually the resource factory)* @return the previously bound value (usually the active resource object)* @throws IllegalStateException if there is no value bound to the thread* @see ResourceTransactionManager#getResourceFactory()*/public static Object unbindResource(Object key) throws IllegalStateException {Object actualKey = TransactionSynchronizationUtils.unwrapResourceIfNecessary(key);Object value = doUnbindResource(actualKey);if (value == null) {throw new IllegalStateException("No value for key [" + actualKey + "] bound to thread [" + Thread.currentThread().getName() + "]");}return value;}/*** Unbind a resource for the given key from the current thread.* @param key the key to unbind (usually the resource factory)* @return the previously bound value, or {@code null} if none bound*/@Nullablepublic static Object unbindResourceIfPossible(Object key) {Object actualKey = TransactionSynchronizationUtils.unwrapResourceIfNecessary(key);return doUnbindResource(actualKey);}/*** Actually remove the value of the resource that is bound for the given key.*/@Nullableprivate static Object doUnbindResource(Object actualKey) {Map<Object, Object> map = resources.get();if (map == null) {return null;}Object value = map.remove(actualKey);// Remove entire ThreadLocal if empty...if (map.isEmpty()) {resources.remove();}// Transparently suppress a ResourceHolder that was marked as void...if (value instanceof ResourceHolder && ((ResourceHolder) value).isVoid()) {value = null;}if (value != null && logger.isTraceEnabled()) {logger.trace("Removed value [" + value + "] for key [" + actualKey + "] from thread [" +Thread.currentThread().getName() + "]");}return value;}//-------------------------------------------------------------------------// Management of transaction synchronizations//-------------------------------------------------------------------------/*** Return if transaction synchronization is active for the current thread.* Can be called before register to avoid unnecessary instance creation.* @see #registerSynchronization*/public static boolean isSynchronizationActive() {return (synchronizations.get() != null);}/*** Activate transaction synchronization for the current thread.* Called by a transaction manager on transaction begin.* @throws IllegalStateException if synchronization is already active*/public static void initSynchronization() throws IllegalStateException {if (isSynchronizationActive()) {throw new IllegalStateException("Cannot activate transaction synchronization - already active");}logger.trace("Initializing transaction synchronization");synchronizations.set(new LinkedHashSet<>());}/*** Register a new transaction synchronization for the current thread.* Typically called by resource management code.* <p>Note that synchronizations can implement the* {@link org.springframework.core.Ordered} interface.* They will be executed in an order according to their order value (if any).* @param synchronization the synchronization object to register* @throws IllegalStateException if transaction synchronization is not active* @see org.springframework.core.Ordered*/public static void registerSynchronization(TransactionSynchronization synchronization)throws IllegalStateException {Assert.notNull(synchronization, "TransactionSynchronization must not be null");if (!isSynchronizationActive()) {throw new IllegalStateException("Transaction synchronization is not active");}synchronizations.get().add(synchronization);}/*** Return an unmodifiable snapshot list of all registered synchronizations* for the current thread.* @return unmodifiable List of TransactionSynchronization instances* @throws IllegalStateException if synchronization is not active* @see TransactionSynchronization*/public static List<TransactionSynchronization> getSynchronizations() throws IllegalStateException {Set<TransactionSynchronization> synchs = synchronizations.get();if (synchs == null) {throw new IllegalStateException("Transaction synchronization is not active");}// Return unmodifiable snapshot, to avoid ConcurrentModificationExceptions// while iterating and invoking synchronization callbacks that in turn// might register further synchronizations.if (synchs.isEmpty()) {return Collections.emptyList();}else {// Sort lazily here, not in registerSynchronization.List<TransactionSynchronization> sortedSynchs = new ArrayList<>(synchs);AnnotationAwareOrderComparator.sort(sortedSynchs);return Collections.unmodifiableList(sortedSynchs);}}/*** Deactivate transaction synchronization for the current thread.* Called by the transaction manager on transaction cleanup.* @throws IllegalStateException if synchronization is not active*/public static void clearSynchronization() throws IllegalStateException {if (!isSynchronizationActive()) {throw new IllegalStateException("Cannot deactivate transaction synchronization - not active");}logger.trace("Clearing transaction synchronization");synchronizations.remove();}//-------------------------------------------------------------------------// Exposure of transaction characteristics//-------------------------------------------------------------------------/*** Expose the name of the current transaction, if any.* Called by the transaction manager on transaction begin and on cleanup.* @param name the name of the transaction, or {@code null} to reset it* @see org.springframework.transaction.TransactionDefinition#getName()*/public static void setCurrentTransactionName(@Nullable String name) {currentTransactionName.set(name);}/*** Return the name of the current transaction, or {@code null} if none set.* To be called by resource management code for optimizations per use case,* for example to optimize fetch strategies for specific named transactions.* @see org.springframework.transaction.TransactionDefinition#getName()*/@Nullablepublic static String getCurrentTransactionName() {return currentTransactionName.get();}/*** Expose a read-only flag for the current transaction.* Called by the transaction manager on transaction begin and on cleanup.* @param readOnly {@code true} to mark the current transaction* as read-only; {@code false} to reset such a read-only marker* @see org.springframework.transaction.TransactionDefinition#isReadOnly()*/public static void setCurrentTransactionReadOnly(boolean readOnly) {currentTransactionReadOnly.set(readOnly ? Boolean.TRUE : null);}/*** Return whether the current transaction is marked as read-only.* To be called by resource management code when preparing a newly* created resource (for example, a Hibernate Session).* <p>Note that transaction synchronizations receive the read-only flag* as argument for the {@code beforeCommit} callback, to be able* to suppress change detection on commit. The present method is meant* to be used for earlier read-only checks, for example to set the* flush mode of a Hibernate Session to "FlushMode.NEVER" upfront.* @see org.springframework.transaction.TransactionDefinition#isReadOnly()* @see TransactionSynchronization#beforeCommit(boolean)*/public static boolean isCurrentTransactionReadOnly() {return (currentTransactionReadOnly.get() != null);}/*** Expose an isolation level for the current transaction.* Called by the transaction manager on transaction begin and on cleanup.* @param isolationLevel the isolation level to expose, according to the* JDBC Connection constants (equivalent to the corresponding Spring* TransactionDefinition constants), or {@code null} to reset it* @see java.sql.Connection#TRANSACTION_READ_UNCOMMITTED* @see java.sql.Connection#TRANSACTION_READ_COMMITTED* @see java.sql.Connection#TRANSACTION_REPEATABLE_READ* @see java.sql.Connection#TRANSACTION_SERIALIZABLE* @see org.springframework.transaction.TransactionDefinition#ISOLATION_READ_UNCOMMITTED* @see org.springframework.transaction.TransactionDefinition#ISOLATION_READ_COMMITTED* @see org.springframework.transaction.TransactionDefinition#ISOLATION_REPEATABLE_READ* @see org.springframework.transaction.TransactionDefinition#ISOLATION_SERIALIZABLE* @see org.springframework.transaction.TransactionDefinition#getIsolationLevel()*/public static void setCurrentTransactionIsolationLevel(@Nullable Integer isolationLevel) {currentTransactionIsolationLevel.set(isolationLevel);}/*** Return the isolation level for the current transaction, if any.* To be called by resource management code when preparing a newly* created resource (for example, a JDBC Connection).* @return the currently exposed isolation level, according to the* JDBC Connection constants (equivalent to the corresponding Spring* TransactionDefinition constants), or {@code null} if none* @see java.sql.Connection#TRANSACTION_READ_UNCOMMITTED* @see java.sql.Connection#TRANSACTION_READ_COMMITTED* @see java.sql.Connection#TRANSACTION_REPEATABLE_READ* @see java.sql.Connection#TRANSACTION_SERIALIZABLE* @see org.springframework.transaction.TransactionDefinition#ISOLATION_READ_UNCOMMITTED* @see org.springframework.transaction.TransactionDefinition#ISOLATION_READ_COMMITTED* @see org.springframework.transaction.TransactionDefinition#ISOLATION_REPEATABLE_READ* @see org.springframework.transaction.TransactionDefinition#ISOLATION_SERIALIZABLE* @see org.springframework.transaction.TransactionDefinition#getIsolationLevel()*/@Nullablepublic static Integer getCurrentTransactionIsolationLevel() {return currentTransactionIsolationLevel.get();}/*** Expose whether there currently is an actual transaction active.* Called by the transaction manager on transaction begin and on cleanup.* @param active {@code true} to mark the current thread as being associated* with an actual transaction; {@code false} to reset that marker*/public static void setActualTransactionActive(boolean active) {actualTransactionActive.set(active ? Boolean.TRUE : null);}/*** Return whether there currently is an actual transaction active.* This indicates whether the current thread is associated with an actual* transaction rather than just with active transaction synchronization.* <p>To be called by resource management code that wants to discriminate* between active transaction synchronization (with or without backing* resource transaction; also on PROPAGATION_SUPPORTS) and an actual* transaction being active (with backing resource transaction;* on PROPAGATION_REQUIRED, PROPAGATION_REQUIRES_NEW, etc).* @see #isSynchronizationActive()*/public static boolean isActualTransactionActive() {return (actualTransactionActive.get() != null);}/*** Clear the entire transaction synchronization state for the current thread:* registered synchronizations as well as the various transaction characteristics.* @see #clearSynchronization()* @see #setCurrentTransactionName* @see #setCurrentTransactionReadOnly* @see #setCurrentTransactionIsolationLevel* @see #setActualTransactionActive*/public static void clear() {synchronizations.remove();currentTransactionName.remove();currentTransactionReadOnly.remove();currentTransactionIsolationLevel.remove();actualTransactionActive.remove();} }

?

總結

以上是生活随笔為你收集整理的spring 多线程 事务 源码解析(一)的全部內容,希望文章能夠幫你解決所遇到的問題。

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

中文字幕无码热在线视频 | 欧美自拍另类欧美综合图片区 | 亚洲精品一区二区三区在线观看 | 欧美真人作爱免费视频 | 国产人妻精品一区二区三区不卡 | 亚洲色偷偷男人的天堂 | 67194成是人免费无码 | 老熟妇乱子伦牲交视频 | 在线精品亚洲一区二区 | 成人免费视频在线观看 | 亚无码乱人伦一区二区 | 牲欲强的熟妇农村老妇女 | 鲁大师影院在线观看 | 激情综合激情五月俺也去 | 免费无码一区二区三区蜜桃大 | 精品久久久久久人妻无码中文字幕 | 亚洲国产日韩a在线播放 | 香蕉久久久久久av成人 | 国产av一区二区三区最新精品 | 国产做国产爱免费视频 | 亚洲色大成网站www | 九九综合va免费看 | 中文字幕乱码亚洲无线三区 | 国产偷国产偷精品高清尤物 | av无码久久久久不卡免费网站 | 亚洲精品国产精品乱码视色 | 亚洲精品午夜国产va久久成人 | 久久婷婷五月综合色国产香蕉 | 国产麻豆精品一区二区三区v视界 | 国产一精品一av一免费 | 无码国产色欲xxxxx视频 | 在线观看国产一区二区三区 | 国产成人综合色在线观看网站 | 亚洲成色www久久网站 | 久久国产精品偷任你爽任你 | 国产精品嫩草久久久久 | 欧美精品一区二区精品久久 | 国产精品无码一区二区三区不卡 | 免费国产黄网站在线观看 | 亚洲精品国产a久久久久久 | 欧美野外疯狂做受xxxx高潮 | 亚洲啪av永久无码精品放毛片 | 沈阳熟女露脸对白视频 | 美女极度色诱视频国产 | 一本加勒比波多野结衣 | 久久成人a毛片免费观看网站 | 香港三级日本三级妇三级 | 99国产精品白浆在线观看免费 | 国产精品免费大片 | 亚洲熟妇色xxxxx欧美老妇y | 欧美兽交xxxx×视频 | 国产精品福利视频导航 | 亚欧洲精品在线视频免费观看 | 18禁黄网站男男禁片免费观看 | 亚洲无人区一区二区三区 | 久久精品99久久香蕉国产色戒 | 伊人色综合久久天天小片 | 亚洲天堂2017无码 | 精品一区二区三区波多野结衣 | 精品欧美一区二区三区久久久 | 少妇性l交大片欧洲热妇乱xxx | 久久aⅴ免费观看 | 欧美 日韩 人妻 高清 中文 | 精品人妻人人做人人爽 | 永久免费精品精品永久-夜色 | 成人免费无码大片a毛片 | 久久久久亚洲精品中文字幕 | 国产suv精品一区二区五 | 美女扒开屁股让男人桶 | 久久人人爽人人爽人人片ⅴ | 99精品国产综合久久久久五月天 | 亚洲日本va午夜在线电影 | 亚洲欧美综合区丁香五月小说 | 国产亚洲精品久久久久久久久动漫 | 性开放的女人aaa片 | 国产色xx群视频射精 | 波多野42部无码喷潮在线 | 亚洲欧美日韩国产精品一区二区 | 少妇高潮喷潮久久久影院 | 少妇太爽了在线观看 | 2019午夜福利不卡片在线 | 东京一本一道一二三区 | 欧洲精品码一区二区三区免费看 | 亚洲熟妇色xxxxx欧美老妇y | 在线视频网站www色 | 精品国产一区二区三区四区在线看 | 久久久久成人精品免费播放动漫 | 久久亚洲日韩精品一区二区三区 | 国产精品手机免费 | 麻豆av传媒蜜桃天美传媒 | 曰韩少妇内射免费播放 | 狠狠综合久久久久综合网 | 日本护士xxxxhd少妇 | 波多野结衣 黑人 | 色情久久久av熟女人妻网站 | 亚洲成a人片在线观看无码3d | 久久综合九色综合97网 | 未满成年国产在线观看 | 国产97人人超碰caoprom | 亚洲爆乳大丰满无码专区 | 国产精品无码一区二区三区不卡 | 精品无码av一区二区三区 | 精品无码一区二区三区爱欲 | 国产三级精品三级男人的天堂 | 久久亚洲中文字幕精品一区 | 国产激情无码一区二区 | 国产精品va在线观看无码 | 日韩精品成人一区二区三区 | 亚洲呦女专区 | 国内精品久久毛片一区二区 | 国产av一区二区精品久久凹凸 | 日韩欧美中文字幕在线三区 | 7777奇米四色成人眼影 | 亚洲一区二区三区无码久久 | 成人性做爰aaa片免费看不忠 | 精品久久久久香蕉网 | 久久国产精品偷任你爽任你 | 无码任你躁久久久久久久 | 国产一区二区三区精品视频 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 少妇性俱乐部纵欲狂欢电影 | 兔费看少妇性l交大片免费 | 国产97人人超碰caoprom | 性生交大片免费看女人按摩摩 | 亚洲第一无码av无码专区 | 精品少妇爆乳无码av无码专区 | 小sao货水好多真紧h无码视频 | 中文字幕中文有码在线 | 免费播放一区二区三区 | 久久精品国产一区二区三区 | 99久久久无码国产aaa精品 | 免费观看的无遮挡av | 日本va欧美va欧美va精品 | 鲁鲁鲁爽爽爽在线视频观看 | 免费观看的无遮挡av | 亚洲精品一区二区三区在线观看 | 欧洲极品少妇 | 麻豆国产丝袜白领秘书在线观看 | 欧美日韩精品 | 国产97色在线 | 免 | 性做久久久久久久久 | 国色天香社区在线视频 | 国产人妻精品午夜福利免费 | 性生交大片免费看女人按摩摩 | 午夜嘿嘿嘿影院 | 东京热男人av天堂 | 久久无码中文字幕免费影院蜜桃 | 国产激情精品一区二区三区 | 亚洲一区二区三区香蕉 | 狠狠色噜噜狠狠狠狠7777米奇 | 中文字幕av日韩精品一区二区 | 野外少妇愉情中文字幕 | 久久午夜无码鲁丝片秋霞 | 骚片av蜜桃精品一区 | 无遮无挡爽爽免费视频 | 国产乱人伦av在线无码 | 欧美色就是色 | 精品国产一区二区三区四区在线看 | 3d动漫精品啪啪一区二区中 | 精品国精品国产自在久国产87 | 亚洲国产精品成人久久蜜臀 | 亚洲国产av美女网站 | 亚洲乱亚洲乱妇50p | 欧美xxxxx精品 | 国产精品对白交换视频 | 夜夜夜高潮夜夜爽夜夜爰爰 | 国产偷国产偷精品高清尤物 | 亚洲精品国偷拍自产在线观看蜜桃 | 久久精品一区二区三区四区 | 在线观看欧美一区二区三区 | 一本久道高清无码视频 | 亚洲a无码综合a国产av中文 | 日韩精品无码一区二区中文字幕 | 玩弄人妻少妇500系列视频 | 国产农村妇女高潮大叫 | 国产日产欧产精品精品app | 无码成人精品区在线观看 | 久久久久se色偷偷亚洲精品av | 无码国产色欲xxxxx视频 | 亚洲自偷自拍另类第1页 | 夜精品a片一区二区三区无码白浆 | 国产精品美女久久久 | 性色av无码免费一区二区三区 | 国产精品美女久久久网av | 亚洲人交乣女bbw | 人人妻人人澡人人爽欧美一区 | 无码人妻少妇伦在线电影 | 国产午夜精品一区二区三区嫩草 | 无码一区二区三区在线 | 日日躁夜夜躁狠狠躁 | 蜜桃av抽搐高潮一区二区 | 成人精品一区二区三区中文字幕 | 午夜嘿嘿嘿影院 | 牲欲强的熟妇农村老妇女视频 | 人人爽人人澡人人人妻 | 影音先锋中文字幕无码 | 国产精品久久久久久无码 | 日日摸天天摸爽爽狠狠97 | 一本色道久久综合狠狠躁 | 国产精品鲁鲁鲁 | 色情久久久av熟女人妻网站 | 国产亚洲精品久久久ai换 | 好屌草这里只有精品 | 成人试看120秒体验区 | 大乳丰满人妻中文字幕日本 | www国产精品内射老师 | 国产乡下妇女做爰 | 荫蒂被男人添的好舒服爽免费视频 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 亚洲国产精品一区二区美利坚 | 久久精品国产日本波多野结衣 | 偷窥日本少妇撒尿chinese | 日韩精品成人一区二区三区 | 亚洲熟妇色xxxxx欧美老妇 | 日韩在线不卡免费视频一区 | 国产成人无码a区在线观看视频app | 国产精品视频免费播放 | 97久久国产亚洲精品超碰热 | 亚洲精品综合五月久久小说 | 欧美精品国产综合久久 | 人人妻人人澡人人爽欧美一区九九 | 午夜性刺激在线视频免费 | 久久综合激激的五月天 | 亚洲自偷自偷在线制服 | 中文精品无码中文字幕无码专区 | 99国产精品白浆在线观看免费 | 久久国产精品精品国产色婷婷 | 男人的天堂av网站 | 精品成在人线av无码免费看 | 精品久久久久久人妻无码中文字幕 | 亚洲自偷自拍另类第1页 | 国产无套内射久久久国产 | 精品人妻人人做人人爽夜夜爽 | 欧美性猛交xxxx富婆 | 亚洲国产成人av在线观看 | 亚洲国产欧美国产综合一区 | 国产精品久久久久久亚洲毛片 | 漂亮人妻洗澡被公强 日日躁 | 日本肉体xxxx裸交 | 在线播放无码字幕亚洲 | 在线观看国产一区二区三区 | 亚洲日韩乱码中文无码蜜桃臀网站 | 美女扒开屁股让男人桶 | 国产一区二区三区精品视频 | 午夜福利不卡在线视频 | 丰满肥臀大屁股熟妇激情视频 | 国产一区二区三区日韩精品 | 午夜性刺激在线视频免费 | 精品无人国产偷自产在线 | 国精品人妻无码一区二区三区蜜柚 | 午夜男女很黄的视频 | 日本高清一区免费中文视频 | 性色欲网站人妻丰满中文久久不卡 | 日本欧美一区二区三区乱码 | 国产农村乱对白刺激视频 | 亚洲欧美日韩综合久久久 | 色五月丁香五月综合五月 | 最新国产乱人伦偷精品免费网站 | 自拍偷自拍亚洲精品10p | 久久精品丝袜高跟鞋 | 熟妇人妻激情偷爽文 | 久久午夜无码鲁丝片午夜精品 | 乱人伦人妻中文字幕无码 | 又色又爽又黄的美女裸体网站 | 少妇人妻偷人精品无码视频 | 又色又爽又黄的美女裸体网站 | 中文字幕人妻丝袜二区 | 日韩少妇内射免费播放 | а√天堂www在线天堂小说 | 久久久久国色av免费观看性色 | 中文精品久久久久人妻不卡 | 久久国产36精品色熟妇 | 熟女体下毛毛黑森林 | 亚洲第一无码av无码专区 | 日本肉体xxxx裸交 | 久久久久人妻一区精品色欧美 | 小泽玛莉亚一区二区视频在线 | 国产麻豆精品一区二区三区v视界 | 波多野结衣 黑人 | 亚洲一区二区三区在线观看网站 | 国产欧美熟妇另类久久久 | 亚洲 日韩 欧美 成人 在线观看 | 亚洲狠狠婷婷综合久久 | 99麻豆久久久国产精品免费 | 鲁鲁鲁爽爽爽在线视频观看 | 精品水蜜桃久久久久久久 | 四虎永久在线精品免费网址 | 亚洲一区二区三区四区 | 国产在线aaa片一区二区99 | 夜夜高潮次次欢爽av女 | 18无码粉嫩小泬无套在线观看 | 未满成年国产在线观看 | 亚洲一区二区三区在线观看网站 | 亚洲一区二区三区国产精华液 | 久久亚洲精品中文字幕无男同 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 真人与拘做受免费视频一 | 日韩av无码中文无码电影 | 中文字幕久久久久人妻 | 国产极品美女高潮无套在线观看 | 熟妇人妻中文av无码 | 99精品视频在线观看免费 | 人妻少妇被猛烈进入中文字幕 | 精品人妻中文字幕有码在线 | 国产人妖乱国产精品人妖 | 欧美老妇交乱视频在线观看 | 精品久久8x国产免费观看 | 国产亚洲精品久久久久久 | 久久99国产综合精品 | 亚洲码国产精品高潮在线 | 无码成人精品区在线观看 | 国产精品香蕉在线观看 | 波多野结衣av一区二区全免费观看 | 少妇无码一区二区二三区 | 国産精品久久久久久久 | 67194成是人免费无码 | av无码电影一区二区三区 | 国产超碰人人爽人人做人人添 | 亚洲乱码国产乱码精品精 | 无码人妻丰满熟妇区五十路百度 | 18无码粉嫩小泬无套在线观看 | 亚洲а∨天堂久久精品2021 | 国产精品无码永久免费888 | 成人亚洲精品久久久久 | 亚洲精品国产精品乱码视色 | 丰满少妇人妻久久久久久 | 未满成年国产在线观看 | 国产人妻人伦精品 | 亚洲理论电影在线观看 | 亚洲精品美女久久久久久久 | 国内精品久久久久久中文字幕 | 国产莉萝无码av在线播放 | 色欲人妻aaaaaaa无码 | 久久综合给合久久狠狠狠97色 | 精品无码国产自产拍在线观看蜜 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 疯狂三人交性欧美 | 国产99久久精品一区二区 | 久久97精品久久久久久久不卡 | 成人免费无码大片a毛片 | 99精品国产综合久久久久五月天 | 国产成人精品一区二区在线小狼 | 国产激情无码一区二区 | 人妻中文无码久热丝袜 | 国产精品亚洲lv粉色 | 国产av无码专区亚洲awww | 中文字幕人成乱码熟女app | 午夜免费福利小电影 | www国产亚洲精品久久网站 | 狂野欧美激情性xxxx | 两性色午夜视频免费播放 | 精品国产麻豆免费人成网站 | 久久这里只有精品视频9 | 欧美成人家庭影院 | 欧美熟妇另类久久久久久多毛 | 亚洲无人区一区二区三区 | 亚洲成在人网站无码天堂 | av在线亚洲欧洲日产一区二区 | 亚洲乱码日产精品bd | 无码av最新清无码专区吞精 | 国产人妻精品午夜福利免费 | 初尝人妻少妇中文字幕 | 久久zyz资源站无码中文动漫 | 野外少妇愉情中文字幕 | 成人亚洲精品久久久久 | 欧美成人高清在线播放 | 国产超碰人人爽人人做人人添 | 小泽玛莉亚一区二区视频在线 | 丰满肥臀大屁股熟妇激情视频 | 精品少妇爆乳无码av无码专区 | www国产亚洲精品久久网站 | 福利一区二区三区视频在线观看 | 久久www免费人成人片 | 国产精品无码永久免费888 | 天堂久久天堂av色综合 | 中文字幕无码免费久久99 | 桃花色综合影院 | ass日本丰满熟妇pics | 丰满岳乱妇在线观看中字无码 | 久久久精品成人免费观看 | 波多野结衣高清一区二区三区 | 亚洲熟妇色xxxxx欧美老妇 | 激情综合激情五月俺也去 | 色偷偷人人澡人人爽人人模 | 日本乱偷人妻中文字幕 | 永久免费观看美女裸体的网站 | 激情爆乳一区二区三区 | 亚洲无人区一区二区三区 | 特大黑人娇小亚洲女 | 国产无套内射久久久国产 | 亚洲国产av精品一区二区蜜芽 | 永久黄网站色视频免费直播 | 妺妺窝人体色www婷婷 | 乱码av麻豆丝袜熟女系列 | 国产成人一区二区三区别 | 大肉大捧一进一出好爽视频 | 久久人人爽人人爽人人片av高清 | 人妻少妇精品无码专区动漫 | 精品久久综合1区2区3区激情 | 又大又硬又爽免费视频 | 亚洲欧美中文字幕5发布 | 亚洲乱码中文字幕在线 | 免费观看的无遮挡av | 欧美激情一区二区三区成人 | 无码国内精品人妻少妇 | 沈阳熟女露脸对白视频 | 久久久久99精品国产片 | 亚洲大尺度无码无码专区 | 老熟妇仑乱视频一区二区 | 又色又爽又黄的美女裸体网站 | 日本一区二区三区免费高清 | 一本久久a久久精品vr综合 | 久久久精品成人免费观看 | 中国女人内谢69xxxx | 亚洲国产成人a精品不卡在线 | 国产精品无码mv在线观看 | 成人三级无码视频在线观看 | 宝宝好涨水快流出来免费视频 | 亚洲国产精品无码一区二区三区 | 精品亚洲韩国一区二区三区 | 国产色在线 | 国产 | 久久亚洲中文字幕精品一区 | 国产成人无码区免费内射一片色欲 | 未满小14洗澡无码视频网站 | 国产av无码专区亚洲a∨毛片 | 狂野欧美性猛交免费视频 | 国产99久久精品一区二区 | 午夜福利一区二区三区在线观看 | 亚洲成a人一区二区三区 | 国产乱人伦偷精品视频 | 露脸叫床粗话东北少妇 | 午夜成人1000部免费视频 | 俄罗斯老熟妇色xxxx | 成人无码影片精品久久久 | 久久久精品456亚洲影院 | 欧美老人巨大xxxx做受 | 欧美日韩久久久精品a片 | 麻豆国产丝袜白领秘书在线观看 | 99精品视频在线观看免费 | 久久精品中文字幕一区 | 无码人妻丰满熟妇区毛片18 | 玩弄少妇高潮ⅹxxxyw | 3d动漫精品啪啪一区二区中 | 欧美乱妇无乱码大黄a片 | 国内揄拍国内精品少妇国语 | 在线播放亚洲第一字幕 | 国产精品久久久久久久影院 | 亚欧洲精品在线视频免费观看 | 成人无码视频在线观看网站 | 国产乱子伦视频在线播放 | 色综合久久久无码网中文 | av人摸人人人澡人人超碰下载 | 亚洲人亚洲人成电影网站色 | 国产人妻久久精品二区三区老狼 | av人摸人人人澡人人超碰下载 | 欧美日韩在线亚洲综合国产人 | 国产免费久久久久久无码 | 永久免费观看美女裸体的网站 | 麻豆人妻少妇精品无码专区 | 中文字幕av日韩精品一区二区 | 国产午夜手机精彩视频 | 亚洲码国产精品高潮在线 | 无码毛片视频一区二区本码 | 亚洲精品一区二区三区在线 | 在线看片无码永久免费视频 | 日韩少妇内射免费播放 | 亚洲乱码日产精品bd | 婷婷五月综合激情中文字幕 | 伊在人天堂亚洲香蕉精品区 | 性欧美videos高清精品 | 老子影院午夜精品无码 | 爱做久久久久久 | 色综合久久88色综合天天 | 亚洲午夜久久久影院 | 中文久久乱码一区二区 | 无遮挡啪啪摇乳动态图 | 影音先锋中文字幕无码 | 国产亚洲美女精品久久久2020 | 人妻夜夜爽天天爽三区 | 成人性做爰aaa片免费看不忠 | 一区二区传媒有限公司 | 日本在线高清不卡免费播放 | 四虎4hu永久免费 | 亚洲精品国产第一综合99久久 | 国内少妇偷人精品视频 | 十八禁真人啪啪免费网站 | 极品尤物被啪到呻吟喷水 | 伊人久久大香线蕉午夜 | 一本色道婷婷久久欧美 | 四虎国产精品免费久久 | 国产av人人夜夜澡人人爽麻豆 | 国产香蕉尹人综合在线观看 | 人人妻人人澡人人爽欧美一区九九 | 免费观看激色视频网站 | 国产精品第一国产精品 | 亚洲爆乳精品无码一区二区三区 | 东京热无码av男人的天堂 | 又大又硬又爽免费视频 | 久久久久久国产精品无码下载 | 日本成熟视频免费视频 | 国产av无码专区亚洲a∨毛片 | 四虎影视成人永久免费观看视频 | 欧美野外疯狂做受xxxx高潮 | 大胆欧美熟妇xx | 啦啦啦www在线观看免费视频 | 我要看www免费看插插视频 | 无码午夜成人1000部免费视频 | 熟妇激情内射com | 国产麻豆精品精东影业av网站 | 久久精品99久久香蕉国产色戒 | 最新国产乱人伦偷精品免费网站 | 又湿又紧又大又爽a视频国产 | 午夜无码区在线观看 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 一个人免费观看的www视频 | 欧美 亚洲 国产 另类 | 鲁大师影院在线观看 | 99久久精品日本一区二区免费 | 中文字幕日产无线码一区 | 久久综合色之久久综合 | 黑人巨大精品欧美一区二区 | 熟妇女人妻丰满少妇中文字幕 | 精品久久8x国产免费观看 | 一个人看的视频www在线 | 亚洲爆乳精品无码一区二区三区 | 色五月丁香五月综合五月 | 精品午夜福利在线观看 | 国产亚洲精品久久久久久大师 | 亚洲春色在线视频 | 中文无码成人免费视频在线观看 | 久久综合给合久久狠狠狠97色 | 激情五月综合色婷婷一区二区 | 色婷婷久久一区二区三区麻豆 | 亚洲中文字幕久久无码 | 97se亚洲精品一区 | 四虎国产精品免费久久 | 日韩欧美中文字幕公布 | 少妇愉情理伦片bd | 久久久久久av无码免费看大片 | 国产猛烈高潮尖叫视频免费 | 男人和女人高潮免费网站 | 少妇无码一区二区二三区 | 日本www一道久久久免费榴莲 | 国产真实乱对白精彩久久 | 东京一本一道一二三区 | 国产亚洲精品久久久久久久 | 青草视频在线播放 | 俺去俺来也在线www色官网 | 丰满少妇弄高潮了www | 在线观看国产一区二区三区 | 国产激情无码一区二区app | 特大黑人娇小亚洲女 | 波多野结衣av一区二区全免费观看 | 成人精品天堂一区二区三区 | 久久综合色之久久综合 | 熟妇人妻中文av无码 | 5858s亚洲色大成网站www | 亚洲 高清 成人 动漫 | 狠狠噜狠狠狠狠丁香五月 | 高潮毛片无遮挡高清免费 | 女人和拘做爰正片视频 | 熟妇激情内射com | 少妇愉情理伦片bd | 国产热a欧美热a在线视频 | 亚洲日本一区二区三区在线 | 久久精品女人天堂av免费观看 | 色综合久久88色综合天天 | 中文字幕色婷婷在线视频 | 国产精品亚洲综合色区韩国 | 欧美老妇与禽交 | 精品亚洲韩国一区二区三区 | 亚洲欧洲中文日韩av乱码 | 青草青草久热国产精品 | 人人澡人人妻人人爽人人蜜桃 | 未满小14洗澡无码视频网站 | 俺去俺来也在线www色官网 | 正在播放老肥熟妇露脸 | 人人妻人人澡人人爽精品欧美 | 丰满少妇女裸体bbw | 无码乱肉视频免费大全合集 | 亚洲日韩一区二区 | 成人无码精品1区2区3区免费看 | 国产凸凹视频一区二区 | 日日躁夜夜躁狠狠躁 | 国产美女极度色诱视频www | 荫蒂添的好舒服视频囗交 | 国产精品久久久久9999小说 | 色综合久久久无码中文字幕 | 日本xxxx色视频在线观看免费 | 国内少妇偷人精品视频免费 | 成人av无码一区二区三区 | 伊人久久大香线蕉午夜 | 日韩av激情在线观看 | 四虎影视成人永久免费观看视频 | 日本丰满熟妇videos | 亚洲小说图区综合在线 | 欧美日韩综合一区二区三区 | 亚洲国产一区二区三区在线观看 | 色婷婷香蕉在线一区二区 | 日本一卡2卡3卡四卡精品网站 | 99精品久久毛片a片 | 久久久久免费看成人影片 | 97夜夜澡人人爽人人喊中国片 | 综合人妻久久一区二区精品 | av小次郎收藏 | 乱码av麻豆丝袜熟女系列 | 欧美肥老太牲交大战 | 久久精品国产日本波多野结衣 | 青青久在线视频免费观看 | www国产精品内射老师 | 欧美色就是色 | 人人爽人人澡人人人妻 | 激情内射亚州一区二区三区爱妻 | 国产av久久久久精东av | 国产口爆吞精在线视频 | 图片区 小说区 区 亚洲五月 | 亚洲精品国产第一综合99久久 | 亚洲小说春色综合另类 | 日韩精品无码免费一区二区三区 | 欧美成人午夜精品久久久 | 人妻aⅴ无码一区二区三区 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 欧美第一黄网免费网站 | 人人妻人人澡人人爽欧美一区九九 | 久久亚洲精品成人无码 | 领导边摸边吃奶边做爽在线观看 | 麻豆国产丝袜白领秘书在线观看 | 国产乱人伦av在线无码 | 午夜无码区在线观看 | 日韩 欧美 动漫 国产 制服 | 内射爽无广熟女亚洲 | 国产香蕉尹人综合在线观看 | 国产激情综合五月久久 | 少女韩国电视剧在线观看完整 | 国产明星裸体无码xxxx视频 | 少妇无套内谢久久久久 | 无码av最新清无码专区吞精 | 国产精品高潮呻吟av久久4虎 | 在线精品国产一区二区三区 | 成人aaa片一区国产精品 | 国产精品无码永久免费888 | 熟妇女人妻丰满少妇中文字幕 | 亚洲伊人久久精品影院 | 一个人看的www免费视频在线观看 | 国产精品人妻一区二区三区四 | 大地资源中文第3页 | 性欧美牲交xxxxx视频 | 成人试看120秒体验区 | 日本一本二本三区免费 | 六月丁香婷婷色狠狠久久 | 久精品国产欧美亚洲色aⅴ大片 | 99精品无人区乱码1区2区3区 | 国产亚洲精品久久久久久久久动漫 | 国产真实乱对白精彩久久 | 波多野结衣一区二区三区av免费 | 亚洲精品美女久久久久久久 | 亚洲毛片av日韩av无码 | 人人妻人人澡人人爽欧美精品 | 亚洲の无码国产の无码影院 | 国产激情精品一区二区三区 | 东京一本一道一二三区 | 国产精品理论片在线观看 | 女高中生第一次破苞av | 九九热爱视频精品 | 中文字幕中文有码在线 | 欧美性生交活xxxxxdddd | 午夜福利试看120秒体验区 | 成人欧美一区二区三区黑人免费 | 国产在线一区二区三区四区五区 | 狠狠色噜噜狠狠狠狠7777米奇 | 55夜色66夜色国产精品视频 | 色婷婷综合激情综在线播放 | 人妻体内射精一区二区三四 | 水蜜桃av无码 | ass日本丰满熟妇pics | 中文字幕无码人妻少妇免费 | 麻花豆传媒剧国产免费mv在线 | 娇妻被黑人粗大高潮白浆 | 欧美一区二区三区视频在线观看 | 国产精品a成v人在线播放 | 妺妺窝人体色www婷婷 | 激情国产av做激情国产爱 | 日韩精品成人一区二区三区 | 欧美成人高清在线播放 | 呦交小u女精品视频 | 精品偷拍一区二区三区在线看 | 中文久久乱码一区二区 | 国精品人妻无码一区二区三区蜜柚 | aⅴ亚洲 日韩 色 图网站 播放 | 自拍偷自拍亚洲精品被多人伦好爽 | 国产99久久精品一区二区 | 国产人妻久久精品二区三区老狼 | 亚洲日韩av一区二区三区四区 | 欧美丰满少妇xxxx性 | 欧美自拍另类欧美综合图片区 | 成人无码视频在线观看网站 | 日本乱人伦片中文三区 | 日韩av无码一区二区三区 | 综合人妻久久一区二区精品 | 99久久婷婷国产综合精品青草免费 | 精品无码成人片一区二区98 | 国产精品亚洲а∨无码播放麻豆 | 成年美女黄网站色大免费视频 | 999久久久国产精品消防器材 | 欧美老人巨大xxxx做受 | 网友自拍区视频精品 | 国产成人无码午夜视频在线观看 | 欧美性猛交xxxx富婆 | 捆绑白丝粉色jk震动捧喷白浆 | 国产精品无码一区二区三区不卡 | 久久精品99久久香蕉国产色戒 | 久久久精品人妻久久影视 | 婷婷丁香五月天综合东京热 | 丰满少妇人妻久久久久久 | 少妇人妻av毛片在线看 | 久久久中文久久久无码 | 中文字幕日韩精品一区二区三区 | 日日天干夜夜狠狠爱 | 搡女人真爽免费视频大全 | 国产熟妇另类久久久久 | 97无码免费人妻超级碰碰夜夜 | 国产精品国产自线拍免费软件 | 亚洲aⅴ无码成人网站国产app | 欧美性猛交内射兽交老熟妇 | 国产精品.xx视频.xxtv | 久久综合给久久狠狠97色 | 99er热精品视频 | 午夜福利试看120秒体验区 | 国产精品无码mv在线观看 | 美女扒开屁股让男人桶 | 牲欲强的熟妇农村老妇女 | 内射欧美老妇wbb | 午夜无码区在线观看 | 乱人伦中文视频在线观看 | а天堂中文在线官网 | 精品 日韩 国产 欧美 视频 | 76少妇精品导航 | 精品水蜜桃久久久久久久 | 亚洲欧美日韩国产精品一区二区 | 欧美日韩精品 | 色综合久久中文娱乐网 | 一本无码人妻在中文字幕免费 | 国产亚洲精品久久久久久大师 | 国产精品18久久久久久麻辣 | 亚洲成av人影院在线观看 | 成人免费视频一区二区 | 色综合久久网 | 国产精品久久久久影院嫩草 | 国产乱人伦av在线无码 | 荫蒂被男人添的好舒服爽免费视频 | 国产99久久精品一区二区 | 久久综合网欧美色妞网 | 日韩人妻少妇一区二区三区 | 人人妻人人澡人人爽精品欧美 | 强奷人妻日本中文字幕 | 国产两女互慰高潮视频在线观看 | 国产成人无码专区 | 天天躁夜夜躁狠狠是什么心态 | 男女超爽视频免费播放 | 久久久中文久久久无码 | 精品国产麻豆免费人成网站 | 久久精品人人做人人综合试看 | 久久精品一区二区三区四区 | 午夜精品久久久久久久 | 成人免费视频在线观看 | 麻豆国产人妻欲求不满 | 东北女人啪啪对白 | 精品一区二区不卡无码av | 77777熟女视频在线观看 а天堂中文在线官网 | 日韩欧美中文字幕公布 | 国产精品高潮呻吟av久久4虎 | 午夜丰满少妇性开放视频 | 人人澡人人透人人爽 | 久久久久久亚洲精品a片成人 | 无码帝国www无码专区色综合 | 曰韩少妇内射免费播放 | 国产无遮挡又黄又爽免费视频 | 国产一区二区三区影院 | 亚洲综合色区中文字幕 | 成人亚洲精品久久久久软件 | 无码人妻丰满熟妇区五十路百度 | 伊人久久大香线蕉av一区二区 | 色婷婷综合激情综在线播放 | 天海翼激烈高潮到腰振不止 | 无码国产色欲xxxxx视频 | 在线欧美精品一区二区三区 | 任你躁在线精品免费 | 自拍偷自拍亚洲精品10p | 国产精品99久久精品爆乳 | 国产精品自产拍在线观看 | 水蜜桃亚洲一二三四在线 | 亚洲精品一区三区三区在线观看 | 天天摸天天透天天添 | 1000部啪啪未满十八勿入下载 | 无码免费一区二区三区 | 久久精品视频在线看15 | 亚洲日本在线电影 | 中文亚洲成a人片在线观看 | 欧美阿v高清资源不卡在线播放 | 精品国产一区二区三区四区在线看 | 国产色视频一区二区三区 | 天天拍夜夜添久久精品 | 亚洲国产成人av在线观看 | 欧美 日韩 亚洲 在线 | 国产成人一区二区三区别 | 国产av人人夜夜澡人人爽麻豆 | 国产午夜亚洲精品不卡 | 日韩av无码中文无码电影 | 成人av无码一区二区三区 | 久久精品中文字幕大胸 | 在线观看免费人成视频 | 18禁止看的免费污网站 | а天堂中文在线官网 | 波多野结衣高清一区二区三区 | 亚洲另类伦春色综合小说 | 久久精品国产一区二区三区肥胖 | 蜜臀av无码人妻精品 | 欧洲欧美人成视频在线 | 久久久久成人精品免费播放动漫 | 国产免费观看黄av片 | 亚洲第一无码av无码专区 | 日日噜噜噜噜夜夜爽亚洲精品 | 久久综合香蕉国产蜜臀av | 久久综合九色综合欧美狠狠 | 国产亚洲欧美日韩亚洲中文色 | 水蜜桃亚洲一二三四在线 | 亚洲一区二区观看播放 | 国产女主播喷水视频在线观看 | 97久久超碰中文字幕 | 永久免费观看美女裸体的网站 | 亚洲精品久久久久avwww潮水 | 精品无码国产自产拍在线观看蜜 | 精品午夜福利在线观看 | 亚洲精品中文字幕乱码 | 人人爽人人爽人人片av亚洲 | 无码av中文字幕免费放 | 欧美 日韩 人妻 高清 中文 | 樱花草在线播放免费中文 | 好屌草这里只有精品 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 亚洲国产欧美日韩精品一区二区三区 | 日本va欧美va欧美va精品 | 人妻少妇精品无码专区二区 | 国产av一区二区精品久久凹凸 | 欧洲熟妇色 欧美 | 国产av久久久久精东av | 欧美性生交活xxxxxdddd | 伊人久久大香线蕉av一区二区 | 国产热a欧美热a在线视频 | 狠狠cao日日穞夜夜穞av | 无码毛片视频一区二区本码 | 久久久久久久人妻无码中文字幕爆 | 欧美激情内射喷水高潮 | 牲欲强的熟妇农村老妇女 | 麻豆蜜桃av蜜臀av色欲av | 成人aaa片一区国产精品 | 麻豆果冻传媒2021精品传媒一区下载 | 国产精品亚洲一区二区三区喷水 | 人妻天天爽夜夜爽一区二区 | 免费观看又污又黄的网站 | 国产亚洲精品久久久ai换 | 欧美人与禽zoz0性伦交 | 图片区 小说区 区 亚洲五月 | 午夜无码人妻av大片色欲 | 无遮挡国产高潮视频免费观看 | aⅴ亚洲 日韩 色 图网站 播放 | 老子影院午夜伦不卡 | 国产人妻久久精品二区三区老狼 | 中国女人内谢69xxxxxa片 | 亚洲精品鲁一鲁一区二区三区 | 亚洲天堂2017无码 | 国产超碰人人爽人人做人人添 | 国产精品无码永久免费888 | 日日鲁鲁鲁夜夜爽爽狠狠 | 国产乱人无码伦av在线a | 少妇激情av一区二区 | 亚洲综合伊人久久大杳蕉 | 日本xxxx色视频在线观看免费 | 小sao货水好多真紧h无码视频 | 熟妇人妻激情偷爽文 | 国产精品嫩草久久久久 | 色婷婷久久一区二区三区麻豆 | 在线观看免费人成视频 | 国产精品对白交换视频 | 日本欧美一区二区三区乱码 | 日本va欧美va欧美va精品 | 熟女少妇在线视频播放 | 亚洲小说图区综合在线 | 日产精品高潮呻吟av久久 | 东京热无码av男人的天堂 | 午夜精品一区二区三区在线观看 | 中文无码精品a∨在线观看不卡 | 人妻无码αv中文字幕久久琪琪布 | 色一情一乱一伦一视频免费看 | 国产深夜福利视频在线 | 性啪啪chinese东北女人 | 久久99久久99精品中文字幕 | 亚洲日韩乱码中文无码蜜桃臀网站 | 天堂在线观看www | 国产明星裸体无码xxxx视频 | 欧美成人午夜精品久久久 | 精品乱码久久久久久久 | 男女性色大片免费网站 | 国产精品99爱免费视频 | 国产熟妇另类久久久久 | 国产av人人夜夜澡人人爽麻豆 | 国产欧美精品一区二区三区 | 无码成人精品区在线观看 | 激情内射日本一区二区三区 | 国产精品亚洲lv粉色 | 亚洲成a人片在线观看日本 | 亚欧洲精品在线视频免费观看 | 色综合久久久无码中文字幕 | 无码一区二区三区在线 | 少妇久久久久久人妻无码 | 国产特级毛片aaaaaaa高清 | 99久久久无码国产精品免费 | 麻豆国产人妻欲求不满 | 黑森林福利视频导航 | 免费看少妇作爱视频 | 国产精品久久久久无码av色戒 | 天堂在线观看www | 亚洲色大成网站www | 最近的中文字幕在线看视频 | 欧美性黑人极品hd | 久久亚洲中文字幕精品一区 | 无码国产色欲xxxxx视频 | 中文亚洲成a人片在线观看 | 国产做国产爱免费视频 | 国产在热线精品视频 | 宝宝好涨水快流出来免费视频 | 东京一本一道一二三区 | 无码av免费一区二区三区试看 | 荫蒂添的好舒服视频囗交 | 成人精品视频一区二区 | 成人aaa片一区国产精品 | 无码人妻少妇伦在线电影 | 在线观看国产午夜福利片 | 精品人妻人人做人人爽夜夜爽 | 亚洲国产综合无码一区 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 色 综合 欧美 亚洲 国产 | 又紧又大又爽精品一区二区 | 国产特级毛片aaaaaaa高清 | 亚洲 激情 小说 另类 欧美 | 亚洲国产精品久久久久久 | 亚洲aⅴ无码成人网站国产app | 99在线 | 亚洲 | 亚洲国产av精品一区二区蜜芽 | 亚洲国产欧美日韩精品一区二区三区 | 国产 精品 自在自线 | 久久久久国色av免费观看性色 | 女人高潮内射99精品 | 性生交片免费无码看人 | 国色天香社区在线视频 | 欧美35页视频在线观看 | 国产热a欧美热a在线视频 | 国产在热线精品视频 | 97精品国产97久久久久久免费 | 久久久中文字幕日本无吗 | 国产av久久久久精东av | 免费观看又污又黄的网站 | 午夜福利试看120秒体验区 | 成人aaa片一区国产精品 | 人妻人人添人妻人人爱 | 人人澡人摸人人添 | 亚洲精品中文字幕久久久久 | 国产一区二区三区影院 | 国产精品欧美成人 | 国产av一区二区三区最新精品 | 又粗又大又硬毛片免费看 | 午夜不卡av免费 一本久久a久久精品vr综合 | 色综合久久久久综合一本到桃花网 | 国产无av码在线观看 | 乱码av麻豆丝袜熟女系列 | v一区无码内射国产 | 午夜福利一区二区三区在线观看 | 粉嫩少妇内射浓精videos | 久久久久人妻一区精品色欧美 | 中文久久乱码一区二区 | 国产在线aaa片一区二区99 | 亚洲小说图区综合在线 | 亚洲精品一区二区三区婷婷月 | 大地资源网第二页免费观看 | 欧美精品一区二区精品久久 | 国产av无码专区亚洲a∨毛片 | 特黄特色大片免费播放器图片 | 1000部啪啪未满十八勿入下载 | 国产人妻人伦精品 | 最新国产乱人伦偷精品免费网站 | 亚洲色大成网站www国产 | 欧美日韩亚洲国产精品 | 国产精品亚洲一区二区三区喷水 | 久久99久久99精品中文字幕 | 欧美性猛交xxxx富婆 | 久久综合久久自在自线精品自 | 久久综合色之久久综合 | 久久久久人妻一区精品色欧美 | 婷婷六月久久综合丁香 | 亚洲欧洲中文日韩av乱码 | 自拍偷自拍亚洲精品被多人伦好爽 | 久久精品无码一区二区三区 | 国产精品高潮呻吟av久久4虎 | 中文字幕精品av一区二区五区 | 伦伦影院午夜理论片 | 欧美freesex黑人又粗又大 | 一本久久a久久精品亚洲 | 国产乱人无码伦av在线a | 中文字幕人妻无码一夲道 | 国产av无码专区亚洲awww | 日本www一道久久久免费榴莲 | 大地资源中文第3页 | 国产97在线 | 亚洲 | 亚洲国产精品一区二区第一页 | 天天爽夜夜爽夜夜爽 | 日本精品人妻无码77777 天堂一区人妻无码 | 麻豆md0077饥渴少妇 | 无码纯肉视频在线观看 | 亚洲精品www久久久 | 两性色午夜免费视频 | 人妻无码αv中文字幕久久琪琪布 | 久久精品国产99精品亚洲 | 国产精品成人av在线观看 | 奇米影视7777久久精品人人爽 | 老子影院午夜伦不卡 | 日韩欧美中文字幕公布 | 欧美亚洲国产一区二区三区 | 国产手机在线αⅴ片无码观看 | 青草青草久热国产精品 | 少妇无码一区二区二三区 | 又黄又爽又色的视频 | 亚洲国产精华液网站w | 在线播放亚洲第一字幕 | 国产综合久久久久鬼色 | 99国产精品白浆在线观看免费 | 国产精品久久久一区二区三区 | 领导边摸边吃奶边做爽在线观看 | 波多野结衣高清一区二区三区 | 亚洲中文字幕无码中字 | 精品国产乱码久久久久乱码 | 日产国产精品亚洲系列 | 在线精品亚洲一区二区 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 久久精品国产日本波多野结衣 | 国产高清av在线播放 | 女人被男人躁得好爽免费视频 | 宝宝好涨水快流出来免费视频 | 18禁止看的免费污网站 | 亚洲国产av美女网站 | 久久精品国产亚洲精品 | 牛和人交xxxx欧美 | 小鲜肉自慰网站xnxx | 亚欧洲精品在线视频免费观看 | 国产精品久久久久影院嫩草 | 日日噜噜噜噜夜夜爽亚洲精品 | 亚洲熟妇色xxxxx亚洲 | 一本精品99久久精品77 | 麻豆果冻传媒2021精品传媒一区下载 | 中文字幕人妻无码一区二区三区 | 98国产精品综合一区二区三区 | 综合激情五月综合激情五月激情1 | 亚洲中文字幕在线无码一区二区 | 国产精品igao视频网 | 午夜成人1000部免费视频 | 精品国偷自产在线视频 | 久久久久久亚洲精品a片成人 | 国内精品久久毛片一区二区 | 永久免费观看美女裸体的网站 | 国产无av码在线观看 | 人人澡人人妻人人爽人人蜜桃 | www国产亚洲精品久久网站 | 中文字幕无码免费久久99 | 婷婷丁香六月激情综合啪 | 日本爽爽爽爽爽爽在线观看免 | 乱人伦中文视频在线观看 | 77777熟女视频在线观看 а天堂中文在线官网 | 亚洲精品国产第一综合99久久 | 爆乳一区二区三区无码 | 永久黄网站色视频免费直播 | 老熟女乱子伦 | 欧美亚洲国产一区二区三区 | 免费无码av一区二区 | 久久精品女人天堂av免费观看 | 国产三级久久久精品麻豆三级 | 色一情一乱一伦一视频免费看 | 精品水蜜桃久久久久久久 | 亚洲 a v无 码免 费 成 人 a v | 国产又爽又猛又粗的视频a片 | 久久精品人人做人人综合试看 | 亚洲中文字幕成人无码 | 国产超级va在线观看视频 | 3d动漫精品啪啪一区二区中 | 国产色在线 | 国产 | 三级4级全黄60分钟 | av在线亚洲欧洲日产一区二区 | 天天摸天天碰天天添 | 东北女人啪啪对白 | 亚洲欧洲日本综合aⅴ在线 | 99re在线播放 | 网友自拍区视频精品 | 麻豆人妻少妇精品无码专区 | 中文字幕精品av一区二区五区 | 人妻少妇精品久久 | 午夜性刺激在线视频免费 | 国产在线精品一区二区高清不卡 | 天天拍夜夜添久久精品 | 国产97在线 | 亚洲 | 在线观看国产一区二区三区 | 亚洲啪av永久无码精品放毛片 | 国产真实乱对白精彩久久 | 亚洲精品久久久久久一区二区 | 国产无遮挡又黄又爽免费视频 | a片在线免费观看 | 亚洲大尺度无码无码专区 | 67194成是人免费无码 | 77777熟女视频在线观看 а天堂中文在线官网 | 一本大道伊人av久久综合 | 97se亚洲精品一区 | 熟女体下毛毛黑森林 | 秋霞特色aa大片 | 精品偷自拍另类在线观看 | 在教室伦流澡到高潮hnp视频 | 亚洲gv猛男gv无码男同 | 国产亚洲精品久久久久久久 | 成人亚洲精品久久久久 | 女人高潮内射99精品 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 久久国语露脸国产精品电影 | 日日碰狠狠躁久久躁蜜桃 | 亚洲日韩中文字幕在线播放 | 女人色极品影院 | 久久久中文字幕日本无吗 | 精品人人妻人人澡人人爽人人 | 亚洲国产av精品一区二区蜜芽 | 亚洲国产欧美日韩精品一区二区三区 | 精品国产aⅴ无码一区二区 | 国产精品亚洲专区无码不卡 | 亚洲日本va午夜在线电影 | 亚洲成av人片天堂网无码】 | 日本护士xxxxhd少妇 | 99在线 | 亚洲 | 少妇一晚三次一区二区三区 | 老太婆性杂交欧美肥老太 | 亚洲 高清 成人 动漫 | 狂野欧美性猛xxxx乱大交 | 国产熟女一区二区三区四区五区 | 国产农村妇女高潮大叫 | 日本乱人伦片中文三区 | 小泽玛莉亚一区二区视频在线 | 少妇人妻偷人精品无码视频 | 国产小呦泬泬99精品 | 色欲综合久久中文字幕网 | 成在人线av无码免观看麻豆 | 一本色道婷婷久久欧美 | 久久精品国产日本波多野结衣 | 日本爽爽爽爽爽爽在线观看免 | 黑人大群体交免费视频 | 国产美女极度色诱视频www | 亚洲 另类 在线 欧美 制服 | 国产精品第一区揄拍无码 | 国产美女极度色诱视频www | 国产熟女一区二区三区四区五区 | 性生交大片免费看l | 无套内谢的新婚少妇国语播放 | 图片小说视频一区二区 | 免费网站看v片在线18禁无码 | 亚洲区小说区激情区图片区 | 妺妺窝人体色www在线小说 | 人妻尝试又大又粗久久 | 国产区女主播在线观看 | 牛和人交xxxx欧美 | 97夜夜澡人人双人人人喊 | 日韩 欧美 动漫 国产 制服 | 国产精品久久久久久久9999 | 欧美黑人巨大xxxxx | 国产成人综合在线女婷五月99播放 | 无码人妻精品一区二区三区下载 | 久久99国产综合精品 | 精品一二三区久久aaa片 | 婷婷五月综合激情中文字幕 | 欧美三级a做爰在线观看 | 免费无码午夜福利片69 | 极品嫩模高潮叫床 | 欧美丰满熟妇xxxx性ppx人交 | 欧美人与禽猛交狂配 | 夫妻免费无码v看片 | 国产精品久久久久久久影院 | 国产亚洲精品久久久久久大师 | 亚洲日韩av一区二区三区四区 | 久久国产精品萌白酱免费 | 国产深夜福利视频在线 | 日日躁夜夜躁狠狠躁 | 欧美zoozzooz性欧美 | 无码任你躁久久久久久久 | 国产亚洲欧美日韩亚洲中文色 | 久久99精品国产.久久久久 | 欧美乱妇无乱码大黄a片 | 精品厕所偷拍各类美女tp嘘嘘 | 最新国产麻豆aⅴ精品无码 | 无码国产激情在线观看 | 亚洲精品一区二区三区婷婷月 | 中文精品无码中文字幕无码专区 | 夜先锋av资源网站 | 久久97精品久久久久久久不卡 | 亚洲国产精华液网站w | 欧美一区二区三区视频在线观看 | 少妇人妻av毛片在线看 | 久久久久国色av免费观看性色 | 精品久久久久久人妻无码中文字幕 | 少妇性l交大片欧洲热妇乱xxx | 欧美高清在线精品一区 | 午夜男女很黄的视频 | 欧美第一黄网免费网站 | 极品尤物被啪到呻吟喷水 | 亚洲综合色区中文字幕 | 免费视频欧美无人区码 | 东京一本一道一二三区 | 人人妻人人澡人人爽精品欧美 | 又大又黄又粗又爽的免费视频 | 亚洲自偷自拍另类第1页 | 国产黑色丝袜在线播放 | 亚洲日韩av一区二区三区中文 | 捆绑白丝粉色jk震动捧喷白浆 | 免费乱码人妻系列无码专区 | 福利一区二区三区视频在线观看 | 久久国产精品精品国产色婷婷 | 成人无码精品一区二区三区 | 久久国语露脸国产精品电影 | 99久久精品午夜一区二区 | 日韩精品无码免费一区二区三区 | 99国产精品白浆在线观看免费 | 亚洲精品一区二区三区在线 | 国产性生交xxxxx无码 | 欧美变态另类xxxx | 76少妇精品导航 | 麻花豆传媒剧国产免费mv在线 | 性色欲情网站iwww九文堂 | 图片区 小说区 区 亚洲五月 | 熟妇激情内射com | 亚洲精品综合一区二区三区在线 | 激情爆乳一区二区三区 | 亚洲日韩av一区二区三区中文 | 亚洲午夜福利在线观看 | 欧美真人作爱免费视频 | 国产精品嫩草久久久久 | 一本久久a久久精品亚洲 | 成人无码精品一区二区三区 | 真人与拘做受免费视频 | 国产电影无码午夜在线播放 | 亚洲va中文字幕无码久久不卡 | 欧美三级a做爰在线观看 | 久久精品人人做人人综合 | 蜜臀av无码人妻精品 | 亚洲精品久久久久久一区二区 | 亚洲成a人一区二区三区 | 欧美午夜特黄aaaaaa片 | 国产乡下妇女做爰 | 精品厕所偷拍各类美女tp嘘嘘 | 中文字幕色婷婷在线视频 | 欧美国产亚洲日韩在线二区 | 国产午夜福利亚洲第一 | 精品一二三区久久aaa片 | 一二三四在线观看免费视频 | 日本精品久久久久中文字幕 | aa片在线观看视频在线播放 | 成年美女黄网站色大免费全看 | 国产精品久久久久无码av色戒 | 天堂无码人妻精品一区二区三区 | 国产精品多人p群无码 | 西西人体www44rt大胆高清 | 亚洲の无码国产の无码步美 | 2019nv天堂香蕉在线观看 | 黄网在线观看免费网站 | 国产av一区二区精品久久凹凸 | 大肉大捧一进一出好爽视频 | 午夜精品久久久久久久 | 国产精品久久久久无码av色戒 | 国产精品久久久av久久久 | 无码av免费一区二区三区试看 | 亚洲国产欧美在线成人 | 亚洲中文字幕av在天堂 | 老熟女乱子伦 | 377p欧洲日本亚洲大胆 | 国产97在线 | 亚洲 | 午夜性刺激在线视频免费 | 久久综合激激的五月天 | 中文字幕av无码一区二区三区电影 | 国产人妻精品一区二区三区不卡 | 精品无码一区二区三区的天堂 | 国产欧美精品一区二区三区 | 妺妺窝人体色www婷婷 | 色综合天天综合狠狠爱 | 俄罗斯老熟妇色xxxx | 自拍偷自拍亚洲精品10p | 麻豆精品国产精华精华液好用吗 | 日日摸夜夜摸狠狠摸婷婷 | 亚洲中文无码av永久不收费 | 国内少妇偷人精品视频 | 日韩精品成人一区二区三区 | 天天爽夜夜爽夜夜爽 | 少妇被粗大的猛进出69影院 | 国产亚洲精品久久久久久久 | 樱花草在线社区www | 久久伊人色av天堂九九小黄鸭 | 日日麻批免费40分钟无码 | 偷窥村妇洗澡毛毛多 | 无码一区二区三区在线 | 人人爽人人澡人人高潮 | 亚洲无人区一区二区三区 | 欧美精品国产综合久久 | 久久久久免费看成人影片 | 帮老师解开蕾丝奶罩吸乳网站 | 小泽玛莉亚一区二区视频在线 | 野外少妇愉情中文字幕 | 97夜夜澡人人爽人人喊中国片 | 思思久久99热只有频精品66 | 国产亚av手机在线观看 | 综合激情五月综合激情五月激情1 | 久久久亚洲欧洲日产国码αv | 国产色在线 | 国产 | 天天摸天天碰天天添 | 永久黄网站色视频免费直播 | 亚洲日本va午夜在线电影 | 久久精品丝袜高跟鞋 | 色偷偷人人澡人人爽人人模 | 亚洲中文字幕无码中文字在线 | 日本一卡二卡不卡视频查询 | 在线观看国产一区二区三区 | 玩弄人妻少妇500系列视频 | 国内丰满熟女出轨videos | 国产精品国产自线拍免费软件 | 国精品人妻无码一区二区三区蜜柚 | 色综合视频一区二区三区 | 久久久久国色av免费观看性色 | 久久99国产综合精品 | 久久午夜无码鲁丝片午夜精品 | 国产精品久免费的黄网站 | 国产真实乱对白精彩久久 | 亚洲 日韩 欧美 成人 在线观看 | 无码纯肉视频在线观看 | 国产成人精品视频ⅴa片软件竹菊 | 性做久久久久久久免费看 | 国产疯狂伦交大片 | 高清无码午夜福利视频 | 精品偷拍一区二区三区在线看 | 激情内射日本一区二区三区 | 国产一区二区不卡老阿姨 | 亚洲小说春色综合另类 | 鲁一鲁av2019在线 | 永久黄网站色视频免费直播 | 麻豆蜜桃av蜜臀av色欲av | 一本久久a久久精品亚洲 | 午夜精品一区二区三区在线观看 | 日韩av无码中文无码电影 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 亚洲人成网站免费播放 | 性做久久久久久久久 | 国产成人无码av片在线观看不卡 | 午夜不卡av免费 一本久久a久久精品vr综合 | 无码国内精品人妻少妇 | 国内揄拍国内精品少妇国语 | 国产亚洲精品久久久久久国模美 | 亚洲国产精品久久久天堂 | 1000部啪啪未满十八勿入下载 | 色一情一乱一伦一区二区三欧美 | 日本熟妇浓毛 | 全黄性性激高免费视频 | 婷婷综合久久中文字幕蜜桃三电影 | 中文字幕亚洲情99在线 | 日本va欧美va欧美va精品 | 天干天干啦夜天干天2017 | 丰满岳乱妇在线观看中字无码 | 欧洲熟妇色 欧美 | 成人无码精品一区二区三区 | 日产国产精品亚洲系列 | 高潮毛片无遮挡高清免费 | 成人无码视频在线观看网站 | 伊人久久大香线蕉午夜 | 国产免费久久久久久无码 | 久久综合香蕉国产蜜臀av | 夜夜高潮次次欢爽av女 | 欧美zoozzooz性欧美 | 天堂一区人妻无码 | 人妻与老人中文字幕 | 露脸叫床粗话东北少妇 | 国产精品久久国产三级国 | 亚洲精品一区二区三区在线观看 | 中文字幕无码人妻少妇免费 | 欧洲美熟女乱又伦 | 国产 浪潮av性色四虎 | 狠狠色噜噜狠狠狠7777奇米 | 欧美zoozzooz性欧美 | 欧美精品无码一区二区三区 | 欧美人与牲动交xxxx | 色综合久久中文娱乐网 | 久久人人爽人人爽人人片av高清 | 亚洲大尺度无码无码专区 | 无码午夜成人1000部免费视频 | 欧美阿v高清资源不卡在线播放 | 丰满少妇熟乱xxxxx视频 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 国内精品人妻无码久久久影院蜜桃 | 精品无码一区二区三区爱欲 | 亚洲啪av永久无码精品放毛片 | aⅴ亚洲 日韩 色 图网站 播放 | 日日橹狠狠爱欧美视频 | 精品久久久无码中文字幕 | 欧美自拍另类欧美综合图片区 | 久久zyz资源站无码中文动漫 | 中文字幕无码人妻少妇免费 | 在线成人www免费观看视频 | 亚洲人成无码网www | 成人av无码一区二区三区 | 国产在线精品一区二区三区直播 | 欧美变态另类xxxx | 亚洲日韩av一区二区三区四区 | 内射白嫩少妇超碰 | 99久久人妻精品免费一区 | 欧美老妇交乱视频在线观看 | 中文字幕亚洲情99在线 | 国产在线精品一区二区三区直播 | 国产精品无码一区二区桃花视频 | 蜜桃臀无码内射一区二区三区 | 成人无码视频在线观看网站 | 欧美人与禽zoz0性伦交 | 曰本女人与公拘交酡免费视频 | yw尤物av无码国产在线观看 | 国产精品久免费的黄网站 | 国产在热线精品视频 | 中文字幕亚洲情99在线 | 131美女爱做视频 | 超碰97人人射妻 | 亚洲熟妇色xxxxx欧美老妇 | 亚洲伊人久久精品影院 | 国产免费无码一区二区视频 | 无码人妻出轨黑人中文字幕 | 日本一区二区三区免费高清 | 亚洲热妇无码av在线播放 | 国产真实夫妇视频 | 免费播放一区二区三区 | 午夜熟女插插xx免费视频 | 青青青爽视频在线观看 | 日本高清一区免费中文视频 | 日韩人妻无码一区二区三区久久99 | 欧美兽交xxxx×视频 | 欧美精品在线观看 | 日本又色又爽又黄的a片18禁 | 国产精品成人av在线观看 | 久久国产劲爆∧v内射 | 国产av无码专区亚洲a∨毛片 | 国产精品香蕉在线观看 | 久久婷婷五月综合色国产香蕉 | 国产人妻大战黑人第1集 | 成熟妇人a片免费看网站 | 丝袜美腿亚洲一区二区 | 国产国语老龄妇女a片 | 国内精品久久久久久中文字幕 | 激情内射亚州一区二区三区爱妻 | 无码人妻丰满熟妇区毛片18 | 亚洲精品美女久久久久久久 | 丰满人妻翻云覆雨呻吟视频 | 领导边摸边吃奶边做爽在线观看 | 性色欲网站人妻丰满中文久久不卡 | 国产乱码精品一品二品 | 老熟妇乱子伦牲交视频 | 精品欧洲av无码一区二区三区 | 麻豆成人精品国产免费 | 免费网站看v片在线18禁无码 | 一本久久a久久精品亚洲 | 中文字幕无码乱人伦 | www国产亚洲精品久久网站 | 中文无码伦av中文字幕 | 亚洲精品中文字幕久久久久 | 欧美丰满熟妇xxxx | 又粗又大又硬毛片免费看 | 亚洲春色在线视频 | 国产成人无码区免费内射一片色欲 | 99久久久国产精品无码免费 | 亚洲欧美国产精品专区久久 | 久久久亚洲欧洲日产国码αv | 午夜精品一区二区三区在线观看 | 樱花草在线播放免费中文 | 久久综合给久久狠狠97色 | 无码国产色欲xxxxx视频 | 国产精品无码一区二区三区不卡 | 国产精品怡红院永久免费 | 色一情一乱一伦一视频免费看 | 无遮挡国产高潮视频免费观看 | 性生交片免费无码看人 | 欧美国产日产一区二区 | 日韩欧美中文字幕在线三区 | 国产精品香蕉在线观看 | 亚洲色大成网站www | 丰满岳乱妇在线观看中字无码 | 波多野结衣av一区二区全免费观看 | 无码纯肉视频在线观看 | 国模大胆一区二区三区 | 久久久久免费精品国产 | 欧美激情内射喷水高潮 | 亚洲精品一区三区三区在线观看 | 岛国片人妻三上悠亚 | 久久久中文久久久无码 | 综合激情五月综合激情五月激情1 | 精品国偷自产在线 | 国产午夜亚洲精品不卡下载 | 无码一区二区三区在线 | 欧美怡红院免费全部视频 | 欧美日本免费一区二区三区 | 日韩 欧美 动漫 国产 制服 | 国产一精品一av一免费 | 亚洲国产欧美国产综合一区 | 日韩精品无码一本二本三本色 | 无码人妻精品一区二区三区下载 | 67194成是人免费无码 | 最新国产乱人伦偷精品免费网站 | 亚洲精品午夜无码电影网 | 亚洲国产精品久久久久久 | 麻豆蜜桃av蜜臀av色欲av | 色综合久久久久综合一本到桃花网 | 日韩精品无码一区二区中文字幕 | 国产乱人伦av在线无码 | 国产无遮挡又黄又爽又色 | 熟女少妇在线视频播放 | 亚洲午夜福利在线观看 | 美女毛片一区二区三区四区 | 成 人 免费观看网站 | 欧洲精品码一区二区三区免费看 | 久久国语露脸国产精品电影 | 色偷偷人人澡人人爽人人模 | 久久国产自偷自偷免费一区调 | 色婷婷香蕉在线一区二区 | 日韩av无码一区二区三区 | 久久精品一区二区三区四区 | 日韩欧美群交p片內射中文 | 无码av岛国片在线播放 | 黑森林福利视频导航 | 日本护士xxxxhd少妇 | 国产女主播喷水视频在线观看 | 精品国产av色一区二区深夜久久 | 欧美午夜特黄aaaaaa片 | 色妞www精品免费视频 | 日产精品99久久久久久 | 又大又紧又粉嫩18p少妇 | 丰满人妻精品国产99aⅴ | 黑人巨大精品欧美黑寡妇 | 亚洲熟悉妇女xxx妇女av | aa片在线观看视频在线播放 | 国产又爽又黄又刺激的视频 | 人人妻在人人 | 日日摸夜夜摸狠狠摸婷婷 | 少妇人妻av毛片在线看 | 大肉大捧一进一出视频出来呀 | 国产香蕉97碰碰久久人人 | 亚洲日本一区二区三区在线 | 精品熟女少妇av免费观看 | 亚洲区欧美区综合区自拍区 | 宝宝好涨水快流出来免费视频 | 亚洲精品一区二区三区四区五区 | 亚洲а∨天堂久久精品2021 | 1000部啪啪未满十八勿入下载 | 久久人妻内射无码一区三区 | 2019午夜福利不卡片在线 | 亚洲欧美日韩国产精品一区二区 | 少妇激情av一区二区 | 婷婷丁香六月激情综合啪 | 人妻体内射精一区二区三四 | 乱人伦人妻中文字幕无码 | 欧美激情内射喷水高潮 | 人妻无码αv中文字幕久久琪琪布 | 亚洲成av人综合在线观看 | 色综合久久久无码中文字幕 | 婷婷五月综合激情中文字幕 | 成熟妇人a片免费看网站 | 亚洲经典千人经典日产 | 久久久久免费看成人影片 | 成在人线av无码免费 | 亚洲国产精品一区二区美利坚 | 亚洲小说图区综合在线 | 精品一区二区不卡无码av | 男女下面进入的视频免费午夜 | 色妞www精品免费视频 | 1000部啪啪未满十八勿入下载 | 牲欲强的熟妇农村老妇女 | 国产激情一区二区三区 | 少妇被黑人到高潮喷出白浆 | 国产97人人超碰caoprom | 国产在线精品一区二区三区直播 | 5858s亚洲色大成网站www | 天堂亚洲2017在线观看 | 色综合久久久无码网中文 | 国产内射爽爽大片视频社区在线 | 中文字幕人妻无码一区二区三区 | 色综合视频一区二区三区 | 成 人影片 免费观看 | 欧美激情内射喷水高潮 | 少妇性俱乐部纵欲狂欢电影 | 亚洲精品久久久久avwww潮水 | 成人毛片一区二区 | 中文字幕人妻无码一区二区三区 | 99久久久国产精品无码免费 | 欧美 日韩 亚洲 在线 | 国产无av码在线观看 | 爽爽影院免费观看 | 亚洲综合伊人久久大杳蕉 | 久久久久久久久蜜桃 | 国产精品美女久久久网av | 欧美熟妇另类久久久久久不卡 | 性色av无码免费一区二区三区 | 天堂亚洲2017在线观看 | 久久亚洲日韩精品一区二区三区 | 红桃av一区二区三区在线无码av | 免费观看又污又黄的网站 | 图片小说视频一区二区 | 无码帝国www无码专区色综合 | 熟妇女人妻丰满少妇中文字幕 | 水蜜桃色314在线观看 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 美女黄网站人色视频免费国产 | 无套内谢的新婚少妇国语播放 | 性生交片免费无码看人 | 内射后入在线观看一区 | 国产亚洲欧美在线专区 | 97色伦图片97综合影院 | 牲欲强的熟妇农村老妇女视频 | 国产又粗又硬又大爽黄老大爷视 | 99re在线播放 | 自拍偷自拍亚洲精品被多人伦好爽 | 极品嫩模高潮叫床 | 久久久精品456亚洲影院 | 日本www一道久久久免费榴莲 | 亚洲精品一区二区三区婷婷月 | 国产xxx69麻豆国语对白 | 国产肉丝袜在线观看 | 国产精品无码成人午夜电影 | 人人澡人人妻人人爽人人蜜桃 | 丰满少妇熟乱xxxxx视频 | 国产农村乱对白刺激视频 | 久久午夜无码鲁丝片 | 精品厕所偷拍各类美女tp嘘嘘 | 亚洲中文无码av永久不收费 | 国产亚洲日韩欧美另类第八页 | 亚洲狠狠色丁香婷婷综合 | 日本大香伊一区二区三区 | 18禁黄网站男男禁片免费观看 | 双乳奶水饱满少妇呻吟 | 色综合久久88色综合天天 | 天堂亚洲2017在线观看 | 精品国产一区二区三区四区 | 国产97人人超碰caoprom | 美女扒开屁股让男人桶 | 奇米影视888欧美在线观看 | 又湿又紧又大又爽a视频国产 | 免费无码一区二区三区蜜桃大 | 国产另类ts人妖一区二区 | 日韩精品成人一区二区三区 | 国内精品人妻无码久久久影院 | 色婷婷综合中文久久一本 | 国产精品久久久久久久影院 | 亚洲综合色区中文字幕 | 波多野结衣高清一区二区三区 | 熟妇人妻中文av无码 | 欧美自拍另类欧美综合图片区 | 成人免费视频一区二区 | 成人无码视频在线观看网站 | 97精品人妻一区二区三区香蕉 | 亚洲精品美女久久久久久久 | 永久黄网站色视频免费直播 | 欧美肥老太牲交大战 | 久久精品一区二区三区四区 | 亚洲欧美国产精品专区久久 | 午夜精品久久久内射近拍高清 | 无码国产色欲xxxxx视频 | 国产精品久久国产精品99 | 亚洲色欲色欲天天天www | 亚洲 欧美 激情 小说 另类 | 中文精品无码中文字幕无码专区 |