校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

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

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

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

概述

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

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

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

1. 收集各節點的鎖信息。

2. 構建等待關系。

3. 檢測循環等待。

4. 中止事務以消除死鎖。

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

分布式死鎖和單節點死鎖的比較單節點死鎖

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

-- 事務 transaction1
-- 所在節點:CN1

BEGIN;

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

COMMIT;


-- 事務 transaction2
-- 所在節點:CN1

BEGIN;

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

COMMIT;

假設上述兩個事務的執行順序如下:

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'

該執行順序會導致死鎖的產生。由于事務 transaction1 和 transaction2 都在 CN1 上執行,死鎖中的所有鎖等待信息都在 CN1 上,因此該死鎖為單節點死鎖。

GaussDB(DWS) 支持自動處理單節點死鎖。當某個節點上的多個事務陷入循環等待時,數據庫系統會自動將其中一個事務中止,從而消除死鎖。

分布式死鎖

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

-- 事務 transaction1
-- 所在節點:CN1

BEGIN;

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

COMMIT;


-- 事務 transaction2
-- 所在節點:CN2

BEGIN;

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

COMMIT;

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

假設兩個事務的執行順序和上一節中的執行順序一致,還是會產生死鎖,死鎖中的鎖等待信息如下:

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

發生分布式死鎖時,陷入死鎖的事務全部都無法繼續執行下去,只有其中一個事務鎖等待超時,剩余事務才能繼續執行。默認情況下,鎖等待超時時間是 20 分鐘。

分布式死鎖的檢測與消除

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

收集各節點的鎖信息

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

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

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

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)

構建等待關系

收集到各節點的鎖信息之后,就可以開始構建等待關系了。

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

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

2. 事務 B 已經持有鎖,而事務 A 還未持有鎖。

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

通過對上一步收集到的鎖信息進行處理,就可以構建出事務的等待關系。

執行附件中的示例代碼 pgxc_locks_wait.sql,就可以獲得等待關系:

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)

等待關系判環

構建出事務的等待關系之后,就可以通過檢查等待關系是否成環,來判斷當前是否有分布式死鎖。

一般情況下,等待關系不會太多,通過觀察就可以判斷出當前有無分布式死鎖。通過觀察上一節中構建的等待信息,可以很容易地判斷出事務 transaction1 和 transaction2 發生了循環等待,即產生了死鎖。

消除死鎖

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

總結

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

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

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

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

巨人網絡通訊聲明:本文標題《詳解通過SQL進行分布式死鎖的檢測與消除》,本文關鍵詞  詳解,通過,SQL,進行,分布式,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解通過SQL進行分布式死鎖的檢測與消除》相關的同類信息!
  • 本頁收集關于詳解通過SQL進行分布式死鎖的檢測與消除的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    91精选在线观看| 欧美午夜理伦三级在线观看| 综合在线观看色| 5858s免费视频成人| 亚洲国产成人av| 国产精品三级视频| 亚洲综合激情另类小说区| av资源站一区| 国产女人18毛片水真多成人如厕| 国产精品久久久久一区二区三区 | 欧美日韩综合一区| 一区二区三区中文免费| 色综合天天综合网天天看片| 中文字幕一区二区不卡| 99在线精品一区二区三区| 国产精品久久久久一区二区三区| 国产一区二区在线视频| 亚洲精品在线电影| 欧美成人精品福利| 成人免费毛片片v| 午夜精品国产更新| 日韩精品自拍偷拍| 不卡的电视剧免费网站有什么| 久久久久久一级片| 99久久久免费精品国产一区二区| 欧美国产禁国产网站cc| 欧美日韩国产首页| 91视频在线观看| 51精品国自产在线| 中文字幕av一区二区三区高| 成人开心网精品视频| 一区在线播放视频| 欧美在线一区二区三区| 天天影视网天天综合色在线播放| 欧洲一区二区三区在线| 日韩精品欧美成人高清一区二区| 91精品免费在线观看| 国内国产精品久久| 国产精品成人在线观看| 欧美日韩综合在线免费观看| 久久国产尿小便嘘嘘尿| 国产精品免费aⅴ片在线观看| 成人手机在线视频| 亚洲精品成人少妇| 欧美一区二区二区| 国产成人精品一区二区三区四区 | 91精品国产欧美一区二区18| 麻豆精品一二三| 欧美国产日本韩| 色狠狠色狠狠综合| 日本视频中文字幕一区二区三区| 欧美xxxxx牲另类人与| 国产91在线|亚洲| 一区二区三区四区亚洲| 91精品国产黑色紧身裤美女| 国产成人免费av在线| 一区二区三区四区不卡在线| 欧美日韩大陆在线| 国产在线乱码一区二区三区| 中文字幕一区不卡| 天天影视网天天综合色在线播放| 国产精品欧美一区喷水| 亚洲人精品一区| 亚洲人成在线观看一区二区| 一二三四社区欧美黄| 亚洲蜜臀av乱码久久精品| 亚洲一区中文日韩| 亚洲国产精品尤物yw在线观看| 国产精品国产自产拍高清av王其| 成人免费视频在线观看| 狠狠色伊人亚洲综合成人| 亚洲国产精品成人久久综合一区| 99久久综合国产精品| 日韩福利视频网| 国产精品视频在线看| 欧美日本一区二区三区四区| 国产成人亚洲综合a∨猫咪| 亚洲国产精品久久人人爱| 国产欧美一区二区三区在线看蜜臀 | 亚洲国产wwwccc36天堂| 久久影院视频免费| 在线免费观看一区| 国产成人免费av在线| 日韩极品在线观看| 综合欧美一区二区三区| 欧美变态凌虐bdsm| 欧洲av一区二区嗯嗯嗯啊| 国产乱子伦视频一区二区三区 | 久久精品噜噜噜成人av农村| 亚洲男女毛片无遮挡| 久久久久久麻豆| 欧美日韩免费高清一区色橹橹| 国产乱淫av一区二区三区| 日韩制服丝袜av| 亚洲精品国产无套在线观| 国产亚洲成aⅴ人片在线观看| 精品视频在线看| 91伊人久久大香线蕉| 国内精品伊人久久久久av影院| 一区二区三区电影在线播| 日本一区二区三区国色天香| 91精品国产一区二区人妖| 91国产成人在线| 97久久久精品综合88久久| 国产福利一区二区三区视频| 久久国产福利国产秒拍| 天天色综合天天| 一区二区三区高清不卡| 中文字幕在线不卡一区二区三区| 日韩午夜激情视频| 欧美挠脚心视频网站| 欧美性大战久久久| 一本一本大道香蕉久在线精品| 国产美女在线观看一区| 久久国产精品无码网站| 日本视频一区二区| 日韩国产欧美在线观看| 亚洲午夜激情av| 亚洲一区二区三区四区在线免费观看 | 婷婷中文字幕综合| 亚洲小说春色综合另类电影| 一区二区三区在线影院| 亚洲精品你懂的| 国产精品国产成人国产三级 | 久久免费电影网| 精品免费一区二区三区| 日韩欧美三级在线| 日韩欧美综合在线| 日韩一区二区免费在线观看| 欧美一区二区免费观在线| 91精品国产高清一区二区三区| 欧美色倩网站大全免费| 欧美日韩亚洲国产综合| 欧美日韩精品专区| 欧美一区二区成人| 日韩三区在线观看| 欧美精品一区二区三区蜜臀 | 91久久精品一区二区三区| 色综合久久久久| 日本韩国一区二区| 欧美视频一区二区三区四区| 欧美日韩国产天堂| 日韩一区二区中文字幕| 日韩欧美成人激情| 久久久www免费人成精品| 中文字幕第一区第二区| 亚洲色图欧洲色图| 亚洲综合色婷婷| 日韩国产高清在线| 精品制服美女久久| 国产成人综合视频| 91蝌蚪porny九色| 欧美亚洲免费在线一区| 91精品国产全国免费观看| 精品日韩欧美一区二区| 欧美国产一区二区| 一区二区三区中文字幕精品精品| 亚洲一级二级在线| 日本在线不卡一区| 国产一区二区91| 97久久超碰国产精品电影| 欧美日韩黄色一区二区| 欧美变态tickling挠脚心| 久久久国产一区二区三区四区小说 | 久久人人97超碰com| 国产精品久久久久久久蜜臀| 一区二区三区精品| 日本一区中文字幕| 国产精品一二三| 一本到一区二区三区| 4hu四虎永久在线影院成人| 久久久久国产精品厨房| 亚洲欧洲综合另类在线| 日韩精品成人一区二区三区| 国产在线视视频有精品| 成人av电影免费在线播放| 欧美亚洲高清一区| 精品久久久久久久人人人人传媒| 国产午夜精品一区二区| 一区二区三区精品视频在线| 九一九一国产精品| 一本色道久久综合精品竹菊| 欧美一区二区三区人| 欧美极品少妇xxxxⅹ高跟鞋| 亚洲一区二区在线免费看| 国产在线精品一区二区三区不卡| 国产suv精品一区二区883| 欧美日韩一区二区在线观看视频| 精品av久久707| 一区二区三区在线免费| 久久av老司机精品网站导航| 一本一道综合狠狠老| 精品国产乱码久久久久久影片| 国产欧美日韩卡一| 日本亚洲电影天堂| 97久久精品人人澡人人爽| 欧美本精品男人aⅴ天堂| 一区二区三区四区国产精品| 国产一区二区91| 欧美精品自拍偷拍|