成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識庫 > 詳解通過SQL進行分布式死鎖的檢測與消除

詳解通過SQL進行分布式死鎖的檢測與消除

熱門標(biāo)簽:天音通信電話機器人 杭州400電話如何申請的 hbuilder地圖標(biāo)注 江西南昌百應(yīng)電話機器人 400電話申請怎么看 機器人電話機創(chuàng)意繪畫 400電話從哪里申請濱州 高德地圖標(biāo)注商家在哪 隨州營銷電話機器人怎么樣

概述

分布式數(shù)倉應(yīng)用場景中,我們經(jīng)常遇到數(shù)據(jù)庫系統(tǒng) hang 住的問題,所謂 hang 是指雖然數(shù)據(jù)庫系統(tǒng)還在運行,但部分或全部業(yè)務(wù)無法正常執(zhí)行。hang 問題的原因有很多,其中以分布式死鎖最為常見,本次主要分享在碰到死鎖時,如何快速地解決死鎖問題。

GaussDB(DWS) 作為分布式數(shù)倉,通過鎖機制來實行并發(fā)控制,因此也存在產(chǎn)生分布式死鎖的可能。雖然分布式死鎖無法避免,但幸運的是其提供了多種系統(tǒng)視圖,能夠保證在分布式死鎖發(fā)生之后,快速地對死鎖進行定位。

本文主要介紹了在 GaussDB(DWS) 中,如何通過 SQL 語句,對分布式死鎖進行檢測和恢復(fù)。本文介紹的方法大致分為 4 步:

1. 收集各節(jié)點的鎖信息。

2. 構(gòu)建等待關(guān)系。

3. 檢測循環(huán)等待。

4. 中止事務(wù)以消除死鎖。

本文介紹的方法使用簡單,門檻低,可以確保在分布式死鎖發(fā)生之后,快速解決問題,恢復(fù)業(yè)務(wù)。

分布式死鎖和單節(jié)點死鎖的比較單節(jié)點死鎖

單節(jié)點死鎖是指,死鎖中的所有鎖等待信息來自同一個節(jié)點,例如:

-- 事務(wù) transaction1
-- 所在節(jié)點:CN1

BEGIN;

TRUNCATE t1;
EXECUTE DIRECT ON(DN1) 'SELECT * FROM t2';

COMMIT;


-- 事務(wù) transaction2
-- 所在節(jié)點:CN1

BEGIN;

TRUNCATE t2;
EXECUTE DIRECT ON(DN2) 'SELECT * FROM t1';

COMMIT;

假設(shè)上述兩個事務(wù)的執(zhí)行順序如下:

1. [transaction1] TRUNCATE t1

2. [transaction2] TRUNCATE t2

3. [transaction1] EXECUTE DIRECT ON(DN1) 'SELECT * FROM t2'

4. [transaction2] EXECUTE DIRECT ON(DN2) 'SELECT * FROM t1'

該執(zhí)行順序會導(dǎo)致死鎖的產(chǎn)生。由于事務(wù) transaction1 和 transaction2 都在 CN1 上執(zhí)行,死鎖中的所有鎖等待信息都在 CN1 上,因此該死鎖為單節(jié)點死鎖。

GaussDB(DWS) 支持自動處理單節(jié)點死鎖。當(dāng)某個節(jié)點上的多個事務(wù)陷入循環(huán)等待時,數(shù)據(jù)庫系統(tǒng)會自動將其中一個事務(wù)中止,從而消除死鎖。

分布式死鎖

分布式死鎖是指,死鎖中的鎖等待信息來自不同節(jié)點。例如:

-- 事務(wù) transaction1
-- 所在節(jié)點:CN1

BEGIN;

TRUNCATE t1;
EXECUTE DIRECT ON(DN1) 'SELECT * FROM t2';

COMMIT;


-- 事務(wù) transaction2
-- 所在節(jié)點:CN2

BEGIN;

TRUNCATE t2;
EXECUTE DIRECT ON(DN2) 'SELECT * FROM t1';

COMMIT;

本例與上一節(jié)中的例子相比,只有事務(wù) transaction2 的所在節(jié)點從 CN1 改為了 CN2。

假設(shè)兩個事務(wù)的執(zhí)行順序和上一節(jié)中的執(zhí)行順序一致,還是會產(chǎn)生死鎖,死鎖中的鎖等待信息如下:

這就是一個典型的分布式死鎖,單獨看 CN1 或 CN2 上的鎖等待信息,都看不出來有死鎖,但將多個節(jié)點的鎖等待信息放到一起看,就能找到有循環(huán)等待的現(xiàn)象。

發(fā)生分布式死鎖時,陷入死鎖的事務(wù)全部都無法繼續(xù)執(zhí)行下去,只有其中一個事務(wù)鎖等待超時,剩余事務(wù)才能繼續(xù)執(zhí)行。默認(rèn)情況下,鎖等待超時時間是 20 分鐘。

分布式死鎖的檢測與消除

當(dāng)我們觀察到數(shù)據(jù)庫系統(tǒng)出現(xiàn) hang 問題時,我們需要通過 SQL 語句檢測分布式死鎖,如果發(fā)現(xiàn)確實存在分布式死鎖,還需要對死鎖進行消除。接下來以之前的分布式死鎖為例,介紹分布式死鎖的檢測和消除的方法。

收集各節(jié)點的鎖信息

為了檢測分布式死鎖,首先需要獲得各節(jié)點的鎖信息。GaussDB(DWS) 中可以通過 PG_LOCKS 視圖查詢當(dāng)前節(jié)點的鎖信息,因此可以通過 EXECUTE DIRECT 語句在所有節(jié)點查詢 PG_LOCKS 視圖,并收集到當(dāng)前節(jié)點中。

注意此處有一個細節(jié),PG_LOCKS 視圖中,很多信息是以 OID 類型給出的,例如一個鎖加在一個表上,PG_LOCKS 視圖會給出表的 OID。由于同一個表在各節(jié)點中的 OID 不一定相同,因此不能通過 OID 來標(biāo)識一個表。在收集鎖信息時,需要先將表的 OID 轉(zhuǎn)換成 SCHEMA 名加表名。其它 OID 信息例如分區(qū) OID 等也同理,需要轉(zhuǎn)化為對應(yīng)的名字。

執(zhí)行附件中的示例代碼 pgxc_locks.sql,就可以收集到各節(jié)點的鎖信息:

locktype    |   nodename   | datname  | usename | nspname | relname | partname | page | tuple | virtualxid | transactionid | virtualtransaction |        mode         | granted | client_addr | application_name |       pid       |         xact_start         |        query_start         |        state        |     query_id      |                        query
---------------+--------------+----------+---------+---------+---------+----------+------+-------+------------+---------------+--------------------+---------------------+---------+-------------+------------------+-----------------+----------------------------+----------------------------+---------------------+-------------------+-----------------------------------------------------
 virtualxid    | cn_5002      | postgres | tyx_1   |         |         |          |      |       | 12/94      |               | 12/94              | ExclusiveLock       | t       |             | gsql             | 140110481323776 | 2020-12-25 17:18:54.238933 | 2020-12-25 17:19:37.715447 | active              |                 0 | EXECUTE DIRECT ON(dn_6003_6004) 'SELECT * FROM t1';
 virtualxid    | cn_5002      | postgres | tyx_1   |         |         |          |      |       | 9/298      |               | 9/298              | ExclusiveLock       | t       | ::1/128     | cn_5001          | 140110672164608 | 2020-12-25 17:18:40.478704 | 2020-12-25 17:18:40.479682 | idle in transaction |                 0 | TRUNCATE t1;
 virtualxid    | cn_5002      | postgres | tyx_1   |         |         |          |      |       | 6/161      |               | 6/161              | ExclusiveLock       | t       |             | WLMArbiter       | 140110762325760 | 2020-12-25 17:20:18.613815 | 2020-12-25 16:53:35.027585 | active              |                 0 | WLM arbiter sync info by CCN and CNs
 virtualxid    | cn_5002      | postgres | tyx_1   |         |         |          |      |       | 5/162      |               | 5/162              | ExclusiveLock       | t       |             | WorkloadMonitor  | 140110779119360 | 2020-12-25 17:20:27.16458  | 2020-12-25 16:53:35.027217 | active              |                 0 | WLM monitor update and verify local info
 virtualxid    | cn_5002      | postgres | tyx_1   |         |         |          |      |       | 3/325      |               | 3/325              | ExclusiveLock       | t       |             | workload         | 140110846744320 | 2020-12-25 17:20:25.372654 | 2020-12-25 16:53:35.02741  | active              | 72339069014641297 | WLM fetch collect info from data nodes
 advisory      | cn_5002      | postgres | tyx_1   |         |         |          |      |       |            |               | 12/94              | ShareLock           | t       |             | gsql             | 140110481323776 | 2020-12-25 17:18:54.238933 | 2020-12-25 17:19:37.715447 | active              |                 0 | EXECUTE DIRECT ON(dn_6003_6004) 'SELECT * FROM t1';
 relation      | cn_5002      | postgres | tyx_1   | public  | t1      |          |      |       |            |               | 9/298              | AccessExclusiveLock | t       | ::1/128     | cn_5001          | 140110672164608 | 2020-12-25 17:18:40.478704 | 2020-12-25 17:18:40.479682 | idle in transaction |                 0 | TRUNCATE t1;
 relation      | cn_5002      | postgres | tyx_1   | public  | t1      |          |      |       |            |               | 12/94              | AccessShareLock     | f       |             | gsql             | 140110481323776 | 2020-12-25 17:18:54.238933 | 2020-12-25 17:19:37.715447 | active              |                 0 | EXECUTE DIRECT ON(dn_6003_6004) 'SELECT * FROM t1';
 transactionid | cn_5002      | postgres | tyx_1   |         |         |          |      |       |            | 10269         | 12/94              | ExclusiveLock       | t       |             | gsql             | 140110481323776 | 2020-12-25 17:18:54.238933 | 2020-12-25 17:19:37.715447 | active              |                 0 | EXECUTE DIRECT ON(dn_6003_6004) 'SELECT * FROM t1';
 transactionid | cn_5002      | postgres | tyx_1   |         |         |          |      |       |            | 10266         | 9/298              | ExclusiveLock       | t       | ::1/128     | cn_5001          | 140110672164608 | 2020-12-25 17:18:40.478704 | 2020-12-25 17:18:40.479682 | idle in transaction |                 0 | TRUNCATE t1;
 relation      | cn_5002      | postgres | tyx_1   | public  | t2      |          |      |       |            |               | 12/94              | AccessExclusiveLock | t       |             | gsql             | 140110481323776 | 2020-12-25 17:18:54.238933 | 2020-12-25 17:19:37.715447 | active              |                 0 | EXECUTE DIRECT ON(dn_6003_6004) 'SELECT * FROM t1';
 virtualxid    | dn_6001_6002 | postgres | tyx_1   |         |         |          |      |       | 17/433     |               | 17/433             | ExclusiveLock       | t       | ::1/128     | cn_5001          | 140552375822080 | 2020-12-25 17:18:40.478704 | 2020-12-25 17:18:50.513948 | idle in transaction |                 0 | TRUNCATE t1;
 virtualxid    | dn_6001_6002 | postgres | tyx_1   |         |         |          |      |       | 23/692     |               | 23/692             | ExclusiveLock       | t       | ::1/128     | cn_5002          | 140552359040768 | 2020-12-25 17:18:54.238933 | 2020-12-25 17:18:56.830053 | idle in transaction |                 0 | TRUNCATE t2;
 virtualxid    | dn_6001_6002 | postgres | tyx_1   |         |         |          |      |       | 2/1607     |               | 2/1607             | ExclusiveLock       | t       |             | workload         | 140552945264384 |                            | 2020-12-25 16:53:35.041283 | active              |                 0 | WLM fetch collect info from data nodes
 transactionid | dn_6001_6002 | postgres | tyx_1   |         |         |          |      |       |            | 10266         | 17/433             | ExclusiveLock       | t       | ::1/128     | cn_5001          | 140552375822080 | 2020-12-25 17:18:40.478704 | 2020-12-25 17:18:50.513948 | idle in transaction |                 0 | TRUNCATE t1;
 relation      | dn_6001_6002 | postgres | tyx_1   |         |         |          |      |       |            |               | 23/692             | AccessExclusiveLock | t       | ::1/128     | cn_5002          | 140552359040768 | 2020-12-25 17:18:54.238933 | 2020-12-25 17:18:56.830053 | idle in transaction |                 0 | TRUNCATE t2;
 relation      | dn_6001_6002 | postgres | tyx_1   |         |         |          |      |       |            |               | 17/433             | AccessExclusiveLock | t       | ::1/128     | cn_5001          | 140552375822080 | 2020-12-25 17:18:40.478704 | 2020-12-25 17:18:50.513948 | idle in transaction |                 0 | TRUNCATE t1;
 relation      | dn_6001_6002 | postgres | tyx_1   | public  | t2      |          |      |       |            |               | 23/692             | ShareLock           | t       | ::1/128     | cn_5002          | 140552359040768 | 2020-12-25 17:18:54.238933 | 2020-12-25 17:18:56.830053 | idle in transaction |                 0 | TRUNCATE t2;
 relation      | dn_6001_6002 | postgres | tyx_1   | public  | t2      |          |      |       |            |               | 23/692             | AccessExclusiveLock | t       | ::1/128     | cn_5002          | 140552359040768 | 2020-12-25 17:18:54.238933 | 2020-12-25 17:18:56.830053 | idle in transaction |                 0 | TRUNCATE t2;
省略若干行
(55 rows)

構(gòu)建等待關(guān)系

收集到各節(jié)點的鎖信息之后,就可以開始構(gòu)建等待關(guān)系了。

事務(wù) A 等待事務(wù) B,需要滿足 3 個條件:

1. 兩個事務(wù)加鎖的資源相同(同一個表、同一個分區(qū)、同一個頁面或同一個元組等)。特別注意,如果事務(wù) A 對 DN1 的 t1 表的加鎖,事務(wù) B 對 DN2 的 t1 表的加鎖,則我們認(rèn)為它們加鎖的資源不同,只有同一節(jié)點上的同一資源才被認(rèn)為是相同的資源。

2. 事務(wù) B 已經(jīng)持有鎖,而事務(wù) A 還未持有鎖。

3. 事務(wù) A 和事務(wù) B 申請的鎖的級別互斥。

通過對上一步收集到的鎖信息進行處理,就可以構(gòu)建出事務(wù)的等待關(guān)系。

執(zhí)行附件中的示例代碼 pgxc_locks_wait.sql,就可以獲得等待關(guān)系:

locktype | nodename | datname  | acquire_lock_pid |  hold_lock_pid  |                           acquire_lock_event                            |                    hold_lock_event
----------+----------+----------+------------------+-----------------+-------------------------------------------------------------------------+--------------------------------------------------------
 relation | cn_5001  | postgres |  140508814374656 | 140508792350464 | usename           : tyx_1                                              +| usename           : tyx_1                             +
          |          |          |                  |                 | nspname           : public                                             +| nspname           : public                            +
          |          |          |                  |                 | relname           : t2                                                 +| relname           : t2                                +
          |          |          |                  |                 | partname          :                                                    +| partname          :                                   +
          |          |          |                  |                 | page              :                                                    +| page              :                                   +
          |          |          |                  |                 | tuple             :                                                    +| tuple             :                                   +
          |          |          |                  |                 | virtualxid        :                                                    +| virtualxid        :                                   +
          |          |          |                  |                 | transactionid     :                                                    +| transactionid     :                                   +
          |          |          |                  |                 | virtualtransaction: 11/13                                              +| virtualtransaction: 12/1323                           +
          |          |          |                  |                 | mode              : AccessShareLock                                    +| mode              : AccessExclusiveLock               +
          |          |          |                  |                 | client_addr       :                                                    +| client_addr       : ::1/128                           +
          |          |          |                  |                 | application_name  : gsql                                               +| application_name  : cn_5002                           +
          |          |          |                  |                 | xact_start        : 2020-12-25 17:18:40.478704                         +| xact_start        : 2020-12-25 17:18:54.238933        +
          |          |          |                  |                 | query_start       : 2020-12-25 17:19:23.0923                           +| query_start       : 2020-12-25 17:18:54.239319        +
          |          |          |                  |                 | state             : active                                             +| state             : idle in transaction               +
          |          |          |                  |                 | query_id          : 0                                                  +| query_id          : 0                                 +
          |          |          |                  |                 | query             : EXECUTE DIRECT ON(dn_6001_6002) 'SELECT * FROM t2';+| query             : TRUNCATE t2;                      +
          |          |          |                  |                 | ------------------------------------------------------                  | ------------------------------------------------------
 relation | cn_5002  | postgres |  140110481323776 | 140110672164608 | usename           : tyx_1                                              +| usename           : tyx_1                             +
          |          |          |                  |                 | nspname           : public                                             +| nspname           : public                            +
          |          |          |                  |                 | relname           : t1                                                 +| relname           : t1                                +
          |          |          |                  |                 | partname          :                                                    +| partname          :                                   +
          |          |          |                  |                 | page              :                                                    +| page              :                                   +
          |          |          |                  |                 | tuple             :                                                    +| tuple             :                                   +
          |          |          |                  |                 | virtualxid        :                                                    +| virtualxid        :                                   +
          |          |          |                  |                 | transactionid     :                                                    +| transactionid     :                                   +
          |          |          |                  |                 | virtualtransaction: 12/94                                              +| virtualtransaction: 9/298                             +
          |          |          |                  |                 | mode              : AccessShareLock                                    +| mode              : AccessExclusiveLock               +
          |          |          |                  |                 | client_addr       :                                                    +| client_addr       : ::1/128                           +
          |          |          |                  |                 | application_name  : gsql                                               +| application_name  : cn_5001                           +
          |          |          |                  |                 | xact_start        : 2020-12-25 17:18:54.238933                         +| xact_start        : 2020-12-25 17:18:40.478704        +
          |          |          |                  |                 | query_start       : 2020-12-25 17:19:37.715447                         +| query_start       : 2020-12-25 17:18:40.479682        +
          |          |          |                  |                 | state             : active                                             +| state             : idle in transaction               +
          |          |          |                  |                 | query_id          : 0                                                  +| query_id          : 0                                 +
          |          |          |                  |                 | query             : EXECUTE DIRECT ON(dn_6003_6004) 'SELECT * FROM t1';+| query             : TRUNCATE t1;                      +
          |          |          |                  |                 | ------------------------------------------------------                  | ------------------------------------------------------
(2 rows)

等待關(guān)系判環(huán)

構(gòu)建出事務(wù)的等待關(guān)系之后,就可以通過檢查等待關(guān)系是否成環(huán),來判斷當(dāng)前是否有分布式死鎖。

一般情況下,等待關(guān)系不會太多,通過觀察就可以判斷出當(dāng)前有無分布式死鎖。通過觀察上一節(jié)中構(gòu)建的等待信息,可以很容易地判斷出事務(wù) transaction1 和 transaction2 發(fā)生了循環(huán)等待,即產(chǎn)生了死鎖。

消除死鎖

上一步最終可能會找到等待關(guān)系中的一個或多個環(huán),對于每個環(huán),需要中止環(huán)中的一個事務(wù),才能消除死鎖。至于應(yīng)該選擇環(huán)中的哪個事務(wù)進行中止,需要我們從事務(wù)的重要性、已執(zhí)行時間等多方面進行考慮,最終選擇一個對業(yè)務(wù)影響最小的事務(wù)進行中止。

總結(jié)

通過 SQL 語句,我們可以很方便地處理分布式死鎖。當(dāng)我們在實際業(yè)務(wù)中遇到數(shù)據(jù)庫系統(tǒng) hang 住的問題時,可以借助本文提供的方法,檢查 hang 問題是否是分布式死鎖引起的,如果問題確實是由分布式死鎖引起的,還可以通過中止某個陷入死鎖的事務(wù),來快速恢復(fù)業(yè)務(wù)。

以上就是詳解通過SQL進行分布式死鎖的檢測與消除的詳細內(nèi)容,更多關(guān)于通過SQL進行分布式死鎖的檢測與消除的資料請關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • java排查死鎖示例
  • Java檢測死鎖案例
  • 如何解決Java多線程死鎖問題
  • MySQL鎖等待與死鎖問題分析
  • postgresql表死鎖問題的排查方式
  • 死鎖詳解

標(biāo)簽:常德 石嘴山 葫蘆島 沈陽 鶴崗 昆明 保定 招商

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解通過SQL進行分布式死鎖的檢測與消除》,本文關(guān)鍵詞  詳解,通過,SQL,進行,分布式,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解通過SQL進行分布式死鎖的檢測與消除》相關(guān)的同類信息!
  • 本頁收集關(guān)于詳解通過SQL進行分布式死鎖的檢測與消除的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    亚洲理论电影网| 一起草最新网址| 久热精品在线观看视频| 免费看黄在线看| 国产精品扒开做爽爽爽的视频| 一区二区日韩av| 国产 日韩 欧美 成人| 亚洲bt天天射| 欧美黄色免费视频| 国产福利91精品一区二区三区| 中文字幕乱码无码人妻系列蜜桃| 久久久亚洲欧洲日产国码aⅴ| jiuse.com91视频| 成人免费av在线| 久久久水蜜桃av免费网站| 黄色在线看片| 欧美特级一级片| 激情视频在线观看免费| 人妻换人妻仑乱| 玖玖玖免费嫩草在线影院一区| 男女羞羞在线观看| 色视频免费在线| wwwjizzjizzcom| 日韩福利视频在线观看| 97人人精品| 网曝门事件国产精品二区| 欧美性生活久久| 精品国产一区二区三区久久久久久| 88久久精品| 91av视频在线观看| 国产精品影视在线观看| 国产69久久精品成人| 国内一区二区三区| 日本在线观看免费| 国产在视频一区二区三区吞精| 韩国精品一区二区三区六区色诱| 91av福利| 91麻豆精品成人一区二区| 亚洲综合三区| 毛片av在线| 国内精品国产三级国产aⅴ久| 91精彩刺激对白露脸偷拍| 国产国语刺激对白av不卡| 99综合久久| 久久精品第九区免费观看| 亚洲精品无码专区| 奇米影视狠888| 涩涩视频在线观看免费| 丝袜美腿诱惑一区二区三区| 日韩欧美大片在线观看| 青草青草久热精品视频在线网站| 91精品二区| 水蜜桃在线免费观看| 久久午夜无码鲁丝片午夜精品| av中文字幕播放| 一级片a一级片| 国产精品久久久久久久久免费樱桃| 中文字幕亚洲激情| 人妖欧美一区二区| 天堂av免费在线| 亚洲国产精品久久人人爱潘金莲| 一级一片免费看| 精品国产乱码久久久久久蜜坠欲下| 日本黄色的视频| 99成人国产精品视频| 涩涩视频在线观看下载| 中文字幕在线免费观看视频| 日本电影一区二区三区| 超碰97av在线| 欧美床上激情在线观看| 欧美日韩国产一区二区三区| 精品久久久久久最新网址| 久久精品久久久久久国产 免费| 欧美 亚洲 另类 激情 另类| 在线精品国产| 欧美美女一区二区在线观看| 欧美成人一级视频| 免费电影一区二区三区| 国产成人精品视频ⅴa片软件竹菊| 欧美人妻一区二区| 国产精品伦理一区二区三区| 黄色小网站在线观看| 香蕉视频官网在线观看日本一区二区| 国产精品500部| 成人h在线播放| 在线看免费毛片| 青春草国产成人精品久久| 羞羞电影在线观看www| www.国产欧美| 亚洲第一区第二区第三区| 色婷婷av一区二区三区gif| 欧美日韩精品免费在线观看视频| 9i精品福利一区二区三区| 神马久久影视大全| 亚洲精品久久久一区二区三区| 黄色一级视频网站| 国产黄色高清视频| 色悠悠在线视频| 国产精品久久久91| 国产精品女主播一区二区三区| 天堂资源在线中文| 999精品网| 精品久久久久久综合日本| 久久99热这里只有精品| 色婷婷av国产精品| 国产三区四区在线观看| 人人超在线公开视频| 成人美女视频在线观看| 人妻无码一区二区三区免费| 97久久综合区小说区图片区| 好吊妞这里只有精品| 永久免费看片视频教学| 欧美男人的天堂| 99re久久精品国产| 在线观看无遮挡| 精精国产xxxx视频在线播放| 亚洲综合在线五月| 亚洲人成电影在线观看网| 中文字幕一区二区三区最新| 在线播放亚洲精品| 欧美日韩亚洲视频一区| 六月丁香综合在线视频| 2020欧美日韩在线视频| 国产一二三区av| 91电影91视频| 欧美丰满少妇人妻精品| 91精品久久久久久9s密挑| 久久精品一区二区三区资源网| 中文字幕在线国产精品| 色一情一伦一子一伦一区| 丁香婷婷综合激情五月色| 亚洲永久精品唐人导航网址| 99视频在线观看一区三区| 最美情侣韩剧在线播放| 国产三级视频网站| 国内欧美视频一区二区| 免费在线观看你懂的| 国产精品高潮视频| 91极品视频在线| 毛茸茸多毛bbb毛多视频| 人妻 日韩精品 中文字幕| 加勒比色综合久久久久久久久| 成片免费观看视频| 美女翘臀白浆直流视频| 欧美日韩精品免费观看视频完整| 天天躁日日躁狠狠躁av麻豆男男| av免费网站在线观看| 亚洲男人天堂av在线| 一个人看的www片免费高清视频| 国产精品爱啪在线线免费观看| 91caoporm在线视频| 色婷婷久久99综合精品jk白丝| 国产色视频网站| 污污的视频在线观看| 国产又粗又猛又色| 国产一区国产精品| 蜜臀91精品国产高清在线观看| 久久精品在线播放| 亚洲乱码国产乱码精品精| 日本三级免费网站| 黄色大片a级| 热久久这里只有精品| 日本一区二区乱| 99久久久国产精品| 精品麻豆国产| 久久久久欧美| 国产中文伊人| 久久伊99综合婷婷久久伊| 91性高湖久久久久久久久_久久99| 麻豆一区产品精品蜜桃的特点| 日韩在线观看电影完整版高清免费悬疑悬疑| 爱情电影网av一区二区| 爱情岛论坛亚洲首页入口章节| 在线视频国产区| 伊人久久久久久久久久久| 国产欧美日韩久久| 无码毛片aaa在线| 91sp网站在线观看入口| 日日噜噜夜夜狠狠久久丁香五月| av中文字幕av| 国产精品都在这里| 日韩欧美亚洲视频| 毛片中文在线观看| 国产精品久久久久久久久久久久久久久久| 国产精品国产三级欧美二区| 免费av在线一区| 国产亚洲成人一区| 一区二区三区四区| 中文字幕亚洲一区二区av在线| 亚洲成a人片综合在线| 琪琪五月天综合婷婷| 蜜臀尤物一区二区三区直播| 欧美成人hd| 六月激情综合网| 国产精品一区二区在线观看| 中文字幕不卡每日更新1区2区| 精品人妻一区二区三区香蕉| 天堂网2014av| 欧日韩在线观看| 国产一区二区在线观看免费视频| 在线观看美女网站大全免费| 人人干人人视频| 日韩av黄色在线观看| 中文字幕中文乱码欧美一区二区| 国产无遮挡一区二区三区毛片日本| 一级黄色片视频| 午夜成人在线视频| 美女黄色网址| 国产精品中文字幕在线观看| 日韩av在线一区| 亚洲欧洲闷骚av少妇影院| 中文字幕日韩高清| 日韩精品福利片午夜免费观看| 情se视频网在线观看| 全亚洲最色的网站在线观看| 欧美成人自拍视频| 91久久久免费一区二区| 成人亚洲一区| 午夜影院福利社| 国产资源在线免费观看| 精品一区二区三区在线| 精品一区二区在线观看视频| 日本免费不卡| 一二三四区精品视频| 最新日本中文字幕| 久久久999国产精品| 国产精品777777| 欧美性猛交xxxx免费看久久久| 国产日产高清欧美一区二区三区| 午夜国产精品一区| 国产精品性做久久久久久| 国产精品亚洲成在人线| 欧美日韩aaaaa| 亚洲va欧美va在线观看| 日日狠狠久久偷偷综合色| 深夜视频在线免费| 激情另类小说区图片区视频区| 石原莉奈在线亚洲二区| 国产日韩高清一区二区三区在线| 国产精品一区二区性色av| 精品少妇一区二区三区密爱| 亚洲一二三区av| 日产欧产美韩系列久久99| 一区二区在线播放视频| 亚洲色图校园春色| 日本一级片在线播放| 蜜臀91精品国产高清在线观看| 激情久久久久久久| 午夜精品视频在线| 精品一区二区三区免费视频| jizzjizzwww| 人与动性xxxxx免费视频| 国产精品免费人成网站| 伊人影院在线观看视频| 情事1991在线| 中文字幕+乱码+中文| 国产精品一区二区三区精品| 久久青青草原| 成年人二级毛片| 国产女同性恋一区二区| 884aa四虎免费影库4h| 国产精品久久久久久久久久免费看| 亚洲一区二区三区精品中文字幕| 国产乱理伦片a级在线观看| 国产白浆在线免费观看| 国产91对白刺激露脸在线观看| 国产小视频免费在线观看| 亚洲欧洲美洲综合色网| 中文字幕欧美日韩va免费视频| 国产精品一区二区免费视频| 日本久久综合网| 免费一区二区| 精品无码一区二区三区在线| 波多野结衣在线aⅴ中文字幕不卡| 欧美日本一区二区| 青青草国产免费自拍| 成人精品三级| 亚洲大香人伊一本线| 欧美成人有码| 成人免费91在线看| 很很鲁在线视频播放影院| 92国产精品久久久久首页| 日本一区二区高清| 午夜天堂影视香蕉久久| 亚洲 中文字幕 日韩 无码| 国产91久久精品一区二区| 麻豆传媒免费在线观看| 亚洲精品国产一区二区三区四区在线| 久久av一区二区三区| 久久久久久久久久久久久久国产| 久久久免费av| 日韩aaaa| 97超碰人人看| 尤物国产精品| 国产欧美第一页| 美女高潮黄又色高清视频免费| 99日韩精品| 成人涩涩小片视频日本| 亚洲加勒比久久88色综合| 欧美性xxxx| 久久久久人妻一区精品色欧美| 51精品在线| 波多野结衣福利| 欧美一区日本一区韩国一区| 精品国产一区二区三区四区在线观看| 久久精品视频2| xf在线a精品一区二区视频网站| 黄色av片三级三级三级免费看| 美女翘臀白浆直流视频| 色在线免费观看| 9lporm自拍视频区在线| 亚洲午夜精品一区二区三区他趣| 最近中文字幕mv免费高清电影| 国产真实乱子伦精品视频| 成人教育av在线| 久草在线视频资源| 秋霞午夜鲁丝一区二区老狼| 夜色资源站国产www在线视频| 精品久久久久久中文字幕2017| 欧美 日韩 综合| 日韩在线视频免费看| 成人亚洲性情网站www在线观看| 91综合在线| 精品福利网址导航| 日韩在线激情| 网曝门事件国产精品二区| 欧美videofree性高清杂交| 欧美日韩中文字幕在线播放|