国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

MYSQL METADATA LOCK(MDL LOCK) 理論及加鎖類型測(cè)試

 更新時(shí)間:2021年09月01日 17:26:12   作者:gaopengtttt  
這篇文章主要介紹了MYSQL METADATA LOCK(MDL LOCK)的內(nèi)容,有理論知識(shí)和加鎖類型測(cè)試的以下代碼,感興趣的朋友請(qǐng)參考下午文

MYSQL METADATA LOCK(MDL LOCK)學(xué)習(xí) 理論知識(shí)和加鎖類型測(cè)試

前言:

源碼版本:5.7.14
注意MDL和DML術(shù)語的不同

 一、初步了解

MYSQL中MDL鎖一直是一個(gè)比較讓人比較頭疼的問題,我們談起鎖一般更加傾向于INNODB下層的gap lock、next key lock、row lock等,
因?yàn)樗芎美斫猓埠芎糜^察,而對(duì)于MDL LOCK卻了解得很少,因?yàn)樗鼘?shí)在不好觀察,只有出現(xiàn)問題查看show processlist勉強(qiáng)可以看到
簡(jiǎn)單的所謂的Waiting for table metadata lock之類的狀態(tài),其實(shí)MDL LOCK是MYSQL上層一個(gè)非常復(fù)雜的子系統(tǒng),有自己的死鎖檢測(cè)機(jī)制
(無向圖?)而大家一般口中的是不是鎖表了其實(shí)就是指的它,可見的它的關(guān)鍵性和嚴(yán)重性,筆者也是根據(jù)自己的需求學(xué)習(xí)了一些(冰山一角),
而沒有能力閱讀全部的代碼,但是筆者通過增加一個(gè)TICKET的打印函數(shù)讓語句的MDL LOCK加鎖流程全部打印出來方便學(xué)習(xí)研究,下面從
一些基礎(chǔ)說起然后告訴大家修改了哪些東西,最后對(duì)每種MDL TYPE進(jìn)行測(cè)試和分析,如果大家對(duì)基本概念和增加打印函數(shù)不感興趣可
直接參考第五部分加鎖測(cè)試,但是如果不了解基礎(chǔ)知識(shí)可能看起來有點(diǎn)困難。 
   剛好最近遇到一次MDL LOCK出現(xiàn)死鎖的情況會(huì)在下篇文章中給出案例,這里只看理論

----處于層次:MYSQL SERVER層次,實(shí)際上早在open_table函數(shù)中MDL LOCK就開始獲取了,可以說他是最早獲取的LOCK結(jié)構(gòu)
----最早獲取階段: THD::enter_stage: 'Opening tables'

調(diào)用棧幀:

#0 open_table_get_mdl_lock (thd=0x7fffd0000df0, ot_ctx=0x7fffec06fb00,
    table_list=0x7fffd00067d8, flags=0, mdl_ticket=0x7fffec06f950)
    at /root/mysql5.7.14/percona-server-5.7.14-7/sql/sql_base.cc:2789
#1 0x0000000001516e17 in open_table (thd=0x7fffd0000df0,
    table_list=0x7fffd00067d8, ot_ctx=0x7fffec06fb00)
    at /root/mysql5.7.14/percona-server-5.7.14-7/sql/sql_base.cc:3237

----死鎖檢測(cè)出錯(cuò)碼:

{ "ER_LOCK_DEADLOCK", 1213, "Deadlock found when trying to get lock; try restarting transaction" },
ERROR 1213 (40001): Deadlock found when trying to get lock; try restarting transaction

MDL LOCK的死鎖拋錯(cuò)和INNODB死鎖一模一樣不同的只是SHOW ENGINE INNODB 沒有死鎖信息。
----涉及代碼:mdl.h mdl.cc

二、基礎(chǔ)重要的數(shù)據(jù)結(jié)構(gòu)(類)和概念

1、MDL TYPE

MDL_INTENTION_EXCLUSIVE(IX)
MDL_SHARED(S)
MDL_SHARED_HIGH_PRIO(SH)
MDL_SHARED_READ(SR)
MDL_SHARED_WRITE(SW)
MDL_SHARED_WRITE_LOW_PRIO(SWL)
MDL_SHARED_UPGRADABLE(SU)
MDL_SHARED_READ_ONLY(SRO)
MDL_SHARED_NO_WRITE(SNW)
MDL_SHARED_NO_READ_WRITE(SNRW)
MDL_EXCLUSIVE(X)

后面會(huì)對(duì)每種TYPE進(jìn)行詳細(xì)的測(cè)試,最后也會(huì)給出源碼中解釋

2、MDL NAMESPACE

在MDL中MDL_KEY按照NAMESPACE+DB+OBJECT_NAME的方式進(jìn)行表示,所謂的namespace也不叫重要
下面是NAMESPACE的分類

- GLOBAL is used for the global read lock.
     - TABLESPACE is for tablespaces.
     - SCHEMA is for schemas (aka databases).
     - TABLE is for tables and views.
     - FUNCTION is for stored functions.
     - PROCEDURE is for stored procedures.
     - TRIGGER is for triggers.
     - EVENT is for event scheduler events.
     - COMMIT is for enabling the global read lock to block commits.
     - USER_LEVEL_LOCK is for user-level locks.
     - LOCKING_SERVICE is for the name plugin RW-lock service

3、實(shí)現(xiàn)分類

scope lock:一般對(duì)應(yīng)全局MDL LOCK flush table with read lock namespace space:GLOBAL type:S
object lock:如其名字,對(duì)象級(jí)別的MDL LOCK,比如TABLE
下面是源碼中的注釋:

 /**
    Helper struct which defines how different types of locks are handled
    for a specific MDL_lock. In practice we use only two strategies: "scoped"
    lock strategy for locks in GLOBAL, COMMIT, TABLESPACE and SCHEMA namespaces
    and "object" lock strategy for all other namespaces.
  */

4、MDL兼容矩陣

scope lock:    

| Type of active   |
  Request |   scoped lock    |
   type   | IS(*)  IX   S  X |
 ---------+------------------+
 IS       |  +      +   +  + |
 IX       |  +      +   -  - |
 S        |  +      -   +  - |
 X        |  +      -   -  - |

object lock:  

Request  |  Granted requests for lock            |
        type    | S  SH  SR  SW  SWLP  SU  SRO  SNW  SNRW  X  |
      ----------+---------------------------------------------+
      S         | +   +   +   +    +    +   +    +    +    -  |
      SH        | +   +   +   +    +    +   +    +    +    -  |
      SR        | +   +   +   +    +    +   +    +    -    -  |
      SW        | +   +   +   +    +    +   -    -    -    -  |
      SWLP      | +   +   +   +    +    +   -    -    -    -  |
      SU        | +   +   +   +    +    -   +    -    -    -  |
      SRO       | +   +   +   -    -    +   +    +    -    -  |
      SNW       | +   +   +   -    -    -   +    -    -    -  |
      SNRW      | +   +   -   -    -    -   -    -    -    -  |
      X         | -   -   -   -    -    -   -    -    -    -  |

5、MDL duration及MDL持續(xù)到什么時(shí)候

看源碼注釋:

MDL_STATEMENT:Locks with statement duration are automatically released at the end
              of statement or transaction.
MDL_TRANSACTION: Locks with transaction duration are automatically released at the end
                of transaction
MDL_EXPLICIT:Locks with explicit duration survive the end of statement and transaction.
             They have to be released explicitly by calling MDL_context::release_lock().

6、MDL LOCK FAST PATH(unobtrusive) OR SLOW PATH(obtrusive)

使用兩種不同的方式目的在于優(yōu)化MDL lock的實(shí)現(xiàn),下面是源碼的注釋

A) "unobtrusive" lock types
            1) Each type from this set should be compatible with all other
               types from the set (including itself).
            2) These types should be common for DML operations
          Our goal is to optimize acquisition and release of locks of this
          type by avoiding complex checks and manipulations on m_waiting/
          m_granted bitmaps/lists. We replace them with a check of and
          increment/decrement of integer counters.
          We call the latter type of acquisition/release "fast path".
          Use of "fast path" reduces the size of critical section associated
          with MDL_lock::m_rwlock lock in the common case and thus increases
          scalability.
          The amount by which acquisition/release of specific type
          "unobtrusive" lock increases/decreases packed counter in
          MDL_lock::m_fast_path_state is returned by this function.
B) "obtrusive" lock types
            1) Granted or pending lock of those type is incompatible with
               some other types of locks or with itself.
            2) Not common for DML operations
          These locks have to be always acquired involving manipulations on
          m_waiting/m_granted bitmaps/lists, i.e. we have to use "slow path"
          for them. Moreover in the presence of active/pending locks from
          "obtrusive" set we have to acquire using "slow path" even locks of
          "unobtrusive" type.

7、MDL_request類

也就是通過語句解析后需要獲得的MDL LOCK的需求,然后通過這個(gè)類對(duì)象在MDL子系統(tǒng) 中進(jìn)行MDL LOCK申請(qǐng),大概包含如下一些屬性

/** Type of metadata lock. */
  enum enum_mdl_type type; //需求的類型
  /** Duration for requested lock. */
  enum enum_mdl_duration duration; //持續(xù)時(shí)間
  /**
    Pointers for participating in the list of lock requests for this context.
  */
  MDL_request *next_in_list; //雙向鏈表實(shí)現(xiàn)
  MDL_request **prev_in_list;
  /**
    Pointer to the lock ticket object for this lock request.
    Valid only if this lock request is satisfied.
  */
  MDL_ticket *ticket; //注意這里如果申請(qǐng)成功(沒有等待),會(huì)指向一個(gè)實(shí)際的TICKET,否則為NULL
  /** A lock is requested based on a fully qualified name and type. */
  MDL_key key;//注意這里是一個(gè)MDL_KEY類型,主要的就是前面說的NAMESPACE+DB+OBJECT_NAME

7、MDL_key類

就是實(shí)際的NAMESPACE+DB+OBJECT_NAME,整個(gè)放到一個(gè)char數(shù)組里面,他會(huì)是MDL_LOCKMDL_REQUEST中出現(xiàn)
private:

  uint16 m_length;
  uint16 m_db_name_length;
  char m_ptr[MAX_MDLKEY_LENGTH];//放到了這里

8、MDL_ticket

如同門票一樣,如果獲取了MDL LOCK必然給MDL_request返回一張門票,如果等待則不會(huì)源碼MDL_context::acquire_lock
   可以觀察到。當(dāng)然這也是我主要觀察的一個(gè)類

/**
    Pointers for participating in the list of lock requests for this context.
    Context private.正如解釋這里是context中鏈表鏈表的形成,是線程私有的
  */
  MDL_ticket *next_in_context;
  MDL_ticket **prev_in_context;
  /**
    Pointers for participating in the list of satisfied/pending requests
    for the lock. Externally accessible.正如解釋這里是MDL_LOCK中鏈表鏈表的形成,是全局的
  */
  MDL_ticket *next_in_lock;
  MDL_ticket **prev_in_lock;
/**
    Context of the owner of the metadata lock ticket. Externally accessible.
    很明顯這里指向了這個(gè)ticket的擁有者也就是MDL_context,它是線程的屬性
  */
  MDL_context *m_ctx;


  /**
    Pointer to the lock object for this lock ticket. Externally accessible.
    很明顯這里是一個(gè)指向MDL_LOCK的一個(gè)指針
  */
  MDL_lock *m_lock;


  /**
    Indicates that ticket corresponds to lock acquired using "fast path"
    algorithm. Particularly this means that it was not included into
    MDL_lock::m_granted bitmap/list and instead is accounted for by
    MDL_lock::m_fast_path_locks_granted_counter
    這里就代表了是否是FAST PATH從注釋來看fast path方式不會(huì)在MDL LOCK中
    占用granted位圖和鏈表取而代之代之的是一個(gè)統(tǒng)計(jì)器m_fast_path_locks_granted_counter
    這樣一來開銷肯定更小
  */
  bool m_is_fast_path;


  /**
    Indicates that ticket corresponds to lock request which required
    storage engine notification during its acquisition and requires
    storage engine notification after its release.
  */
  bool m_hton_notified;

9、MDL_lock

每一個(gè)MDL_key都會(huì)對(duì)應(yīng)一個(gè)MDL_lock,其中包含了所謂的GRANTED鏈表和WAIT鏈表,考慮它的復(fù)雜性,可以直接參考源碼注釋也非常詳細(xì),這里給出我所描述的幾個(gè)屬性。

/** The key of the object (data) being protected. */
  MDL_key key;
/** List of granted tickets for this lock. */
  Ticket_list m_granted;
/** Tickets for contexts waiting to acquire a lock. */
  Ticket_list m_waiting;

10、MDL_context

這是整個(gè)MYSQL 線程和MDL lock子系統(tǒng)進(jìn)行交互的一個(gè)所謂的上下文結(jié)構(gòu)其中包含了很多方法和屬性,我比較關(guān)注的屬性如下:

/**
    If our request for a lock is scheduled, or aborted by the deadlock
    detector, the result is recorded in this class.
  */
  MDL_wait m_wait;
/**
    Lists of all MDL tickets acquired by this connection.
    這是一個(gè)不同MDL lock持續(xù)時(shí)間的一個(gè)鏈表數(shù)組。實(shí)際就是
    MDL_STATEMENT一個(gè)鏈表
    MDL_TRANSACTION一個(gè)鏈表
    MDL_EXPLICIT一個(gè)鏈表
  */
Ticket_list m_tickets[MDL_DURATION_END];
//這是一個(gè)父類指針指向子類對(duì)象,虛函數(shù)重寫的典型,實(shí)際他就指向了一個(gè)線程
/*
class THD :public MDL_context_owner,
           public Query_arena,
           public Open_tables_state
*/
MDL_context_owner *m_owner;

11、MDL_wait

這個(gè)類主要是當(dāng)前ticket獲取狀態(tài) enum_wait_status m_wait_status;

包含: 

  • EMPTY   初始化
  •  GRANTED 獲取成功
  • VICTIM  死鎖
  • TIMEOUT 超時(shí)
  • KILLED  KILLED

12、等待標(biāo)記

PSI_stage_info MDL_key::m_namespace_to_wait_state_name[NAMESPACE_END]=
{
  {0, "Waiting for global read lock", 0},
  {0, "Waiting for tablespace metadata lock", 0},
  {0, "Waiting for schema metadata lock", 0},
  {0, "Waiting for table metadata lock", 0},
  {0, "Waiting for stored function metadata lock", 0},
  {0, "Waiting for stored procedure metadata lock", 0},
  {0, "Waiting for trigger metadata lock", 0},
  {0, "Waiting for event metadata lock", 0},
  {0, "Waiting for commit lock", 0},
  {0, "User lock", 0}, /* Be compatible with old status. */
  {0, "Waiting for locking service lock", 0},
  {0, "Waiting for backup lock", 0},
  {0, "Waiting for binlog lock", 0}
};

三、增加MDL LOCK打印函數(shù)

研究MDL LOCK鎖最好的方式當(dāng)然是能夠獲取MDL 加鎖、升級(jí)、降級(jí)的流程,因?yàn)樵创a太龐大了,不可能面面俱到
雖然5.7加入了下面方式查看

  • UPDATE performance_schema.setup_consumers SET ENABLED = 'YES' WHERE NAME ='global_instrumentation';
  • UPDATE performance_schema.setup_instruments SET ENABLED = 'YES' WHERE NAME ='wait/lock/metadata/sql/mdl';
  • select * from performance_schema.metadata_locks

但是進(jìn)行MDL LOCK的查看,如果要觀察一個(gè)語句到底獲取了哪些MDL LOCK還是顯得無力所以筆者在mdl.cc中加入了一個(gè)函數(shù)原型如下

  • /*p_ticket in parameter*/
  • int my_print_ticket(const MDL_ticket* p_ticket)

并且在mdl_ticket類中增加了這個(gè)函數(shù)原型為友元函數(shù),否則私有成員獲取不到,而給出的公有方法比較繁雜
friend int my_print_ticket(const MDL_ticket* p_ticket);

主要獲取MDL LOCK的如下信息打印到mysql err日志中:
線程id 通過p_ticket->m_ctx->get_thd(); 獲取
mdl lock database name 通過p_ticket->m_lock->key.db_name()獲取
mdl lock object name 通過p_ticket->m_lock->key.name()獲取
mdl lock namespace 通過p_ticket->m_lock->key.mdl_namespace()獲取
mdl lock fast path 通過p_ticket->m_is_fast_path獲取判斷是則輸出否則不輸出
mdl lock type 通過p_ticket->m_type獲取
mdl lock duration 通過p_ticket->m_duration獲取

輸出信息如下:

2017-08-03T07:34:21.720583Z 3 [Note] (>MDL PRINT) Thread id is 3:
2017-08-03T07:34:21.720601Z 3 [Note] (->MDL PRINT) DB_name is:test
2017-08-03T07:34:21.720619Z 3 [Note] (-->MDL PRINT) OBJ_name is:test
2017-08-03T07:34:21.720637Z 3 [Note] (--->MDL PRINT) Namespace is:TABLE
2017-08-03T07:34:21.720655Z 3 [Note] (---->MDL PRINT) Fast path is:(Y)
2017-08-03T07:34:21.720673Z 3 [Note] (----->MDL PRINT) Mdl type is:MDL_SHARED_WRITE(SW)
2017-08-03T07:34:21.720692Z 3 [Note] (------>MDL PRINT) Mdl  duration is:MDL_TRANSACTION

實(shí)際上和metadata_locks中的信息差不多,這是我這里的Thread id show processlist出來的id,但是我可以獲得
鎖獲取的歷史信息,我這里同時(shí)沒有 LOCK_STATUS: GRANTED,但是可以在MDL_context::acquire_lock 邏輯上可以判斷出來

mysql>   select * from performance_schema.metadata_locks\G
*************************** 1. row ***************************
          OBJECT_TYPE: TABLE
        OBJECT_SCHEMA: test
          OBJECT_NAME: test
OBJECT_INSTANCE_BEGIN: 140734412907760
            LOCK_TYPE: SHARED_WRITE
        LOCK_DURATION: TRANSACTION
          LOCK_STATUS: GRANTED
               SOURCE: sql_parse.cc:6314
      OWNER_THREAD_ID: 39
       OWNER_EVENT_ID: 241

四、在合適的位置增加打印函數(shù)進(jìn)行觀察

既然我們要研究MDL LOCK的加鎖\升級(jí)\降級(jí)、那么我們就必要找到他們的函數(shù)入口,然后在合適的位置增加打印函數(shù)進(jìn)行觀察,下面標(biāo)示出打印位置,刪除了大部分的源代碼,需要參考請(qǐng)自行

查看源碼:

1、加鎖:MDL_context::acquire_lock

bool
MDL_context::acquire_lock(MDL_request *mdl_request, ulong lock_wait_timeout)
{
  if (mdl_request->ticket) //獲取成功獲得ticket
  {
    /*
      We have managed to acquire lock without waiting.
      MDL_lock, MDL_context and MDL_request were updated
      accordingly, so we can simply return success.
    */
    //REQUESET獲取TICKET成功 此處打印
    return FALSE;
  }
  /*
    Our attempt to acquire lock without waiting has failed.
    As a result of this attempt we got MDL_ticket with m_lock
    member pointing to the corresponding MDL_lock object which
    has MDL_lock::m_rwlock write-locked.
  */
  //獲取不成功加入MDL_lock 等待隊(duì)列
  lock= ticket->m_lock;

  lock->m_waiting.add_ticket(ticket);

  will_wait_for(ticket); //死鎖檢測(cè)

  /* There is a shared or exclusive lock on the object. */
  DEBUG_SYNC(get_thd(), "mdl_acquire_lock_wait");

  find_deadlock();
  
  //此處打印TICKET進(jìn)入了等待流程
 
  if (lock->needs_notification(ticket) || lock->needs_connection_check())
  {
   }
  done_waiting_for();//等待完成對(duì)死鎖檢測(cè)等待圖進(jìn)行調(diào)整去掉本等待邊edge(無向圖)

  //當(dāng)然到這里也是通過等待后獲得成功了狀態(tài)為GRANTED
  DBUG_ASSERT(wait_status == MDL_wait::GRANTED);

  m_tickets[mdl_request->duration].push_front(ticket);

  mdl_request->ticket= ticket;

  mysql_mdl_set_status(ticket->m_psi, MDL_ticket::GRANTED);
  //此處打印通過等待REQUEST獲得了TICKET
  return FALSE;
}

2、降級(jí)

void MDL_ticket::downgrade_lock(enum_mdl_type new_type)

void MDL_ticket::downgrade_lock(enum_mdl_type new_type)
{
  
  /* Only allow downgrade from EXCLUSIVE and SHARED_NO_WRITE. */
  DBUG_ASSERT(m_type == MDL_EXCLUSIVE ||
              m_type == MDL_SHARED_NO_WRITE);

//此處打印出降級(jí)前的TICKET

  if (m_hton_notified)
  {
    mysql_mdl_set_status(m_psi, MDL_ticket::POST_RELEASE_NOTIFY);
    m_ctx->get_owner()->notify_hton_post_release_exclusive(&m_lock->key);
    m_hton_notified= false;
    mysql_mdl_set_status(m_psi, MDL_ticket::GRANTED);
  }
//函數(shù)結(jié)尾答應(yīng)出降級(jí)后的TICKET
}

3、升級(jí)

MDL_context::upgrade_shared_lock(MDL_ticket *mdl_ticket,enum_mdl_type new_type, ulong lock_wait_timeout)

bool
MDL_context::upgrade_shared_lock(MDL_ticket *mdl_ticket,
                                 enum_mdl_type new_type,
                                 ulong lock_wait_timeout)
{
  MDL_REQUEST_INIT_BY_KEY(&mdl_new_lock_request,
                          &mdl_ticket->m_lock->key, new_type,
                          MDL_TRANSACTION);//構(gòu)造一個(gè)request

 //此處打印出來的TICKET類型
  
  if (acquire_lock(&mdl_new_lock_request, lock_wait_timeout)) //嘗試使用新的LOCK_TYPE進(jìn)行加鎖
    DBUG_RETURN(TRUE);
  
  is_new_ticket= ! has_lock(mdl_svp, mdl_new_lock_request.ticket);

  lock= mdl_ticket->m_lock;

  //下面進(jìn)行一系列對(duì)MDL_LOCK的維護(hù)并且對(duì)所謂的合并操作
  /* Code below assumes that we were upgrading to "obtrusive" type of lock. */
  DBUG_ASSERT(lock->is_obtrusive_lock(new_type));

  /* Merge the acquired and the original lock. @todo: move to a method. */
  mysql_prlock_wrlock(&lock->m_rwlock);

  if (is_new_ticket)
  {
    m_tickets[MDL_TRANSACTION].remove(mdl_new_lock_request.ticket);
    MDL_ticket::destroy(mdl_new_lock_request.ticket);
  }
 //此處打印出來的升級(jí)后TICKET類型
  DBUG_RETURN(FALSE);
}

當(dāng)然我現(xiàn)在只是在這些地方進(jìn)行了打印,以后如果需要在其他地方答應(yīng)加上函數(shù)就可以了。

五、各種MDL LOCK TYPE加鎖測(cè)試

1、MDL_INTENTION_EXCLUSIVE(IX)

這個(gè)鎖會(huì)在很多操作的時(shí)候都會(huì)出現(xiàn)比如做任何一個(gè)DML/DDL 操作都會(huì)觸發(fā),實(shí)際上
DELTE/UPDATE/INSERT/FOR UPDATE等DML操作會(huì)在GLOBAL 上加IX鎖 然后才會(huì)在本對(duì)象上加鎖
而DDL 語句至少會(huì)在GLOBAL 上加IX鎖,對(duì)象所屬 SCHEMA上加IX鎖,本對(duì)象加鎖

下面是 DELETE 觸發(fā)的 GLOABL IX MDL LOCK

2017-08-03T18:22:38.092100Z 3 [Note] Test2:open_tables_for_query()
2017-08-03T18:22:38.092205Z 3 [Note] (acquire_lock)THIS MDL LOCK acquire ok!
2017-08-03T18:22:38.092242Z 3 [Note] (>MDL PRINT) Thread id is 3:
2017-08-03T18:22:38.092276Z 3 [Note] (--->MDL PRINT) Namespace is:GLOBAL
2017-08-03T18:22:38.092310Z 3 [Note] (---->MDL PRINT) Fast path is:(Y)
2017-08-03T18:22:38.092344Z 3 [Note] (----->MDL PRINT) Mdl type is:MDL_INTENTION_EXCLUSIVE(IX)
2017-08-03T18:22:38.092380Z 3 [Note] (------>MDL PRINT) Mdl  duration is:MDL_STATEMENT
2017-08-03T18:22:38.092551Z 3 [Note] (------->MDL PRINT) Mdl  status is:EMPTY

下面是 ALETER 語句觸發(fā)的GLOABL  IX MDL LOCK以及SCHEMA級(jí)別的MDL LOCK

2017-08-03T18:46:05.894871Z 3 [Note] (acquire_lock)THIS MDL LOCK acquire ok!
2017-08-03T18:46:05.894915Z 3 [Note] (>MDL PRINT) Thread id is 3:
2017-08-03T18:46:05.894948Z 3 [Note] (--->MDL PRINT) Namespace is:GLOBAL
2017-08-03T18:46:05.894980Z 3 [Note] (---->MDL PRINT) Fast path is:(Y)
2017-08-03T18:46:05.895012Z 3 [Note] (----->MDL PRINT) Mdl type is:MDL_INTENTION_EXCLUSIVE(IX)
2017-08-03T18:46:05.895044Z 3 [Note] (------>MDL PRINT) Mdl  duration is:MDL_STATEMENT
2017-08-03T18:46:05.895076Z 3 [Note] (------->MDL PRINT) Mdl  status is:EMPTY

2017-08-03T18:46:05.895116Z 3 [Note] (acquire_lock)THIS MDL LOCK acquire ok!
2017-08-03T18:46:05.895147Z 3 [Note] (>MDL PRINT) Thread id is 3:
2017-08-03T18:46:05.895206Z 3 [Note] (->MDL PRINT) DB_name is:test
2017-08-03T18:46:05.895243Z 3 [Note] (-->MDL PRINT) OBJ_name is:
2017-08-03T18:46:05.895276Z 3 [Note] (--->MDL PRINT) Namespace is:SCHEMA
2017-08-03T18:46:05.895325Z 3 [Note] (---->MDL PRINT) Fast path is:(Y)
2017-08-03T18:46:05.895357Z 3 [Note] (----->MDL PRINT) Mdl type is:MDL_INTENTION_EXCLUSIVE(IX)
2017-08-03T18:46:05.895390Z 3 [Note] (------>MDL PRINT) Mdl  duration is:MDL_TRANSACTION
2017-08-03T18:46:05.895421Z 3 [Note] (------->MDL PRINT) Mdl  status is:EMPTY

所以這個(gè)MDL LOCK 無所不在,而只有是否兼容問題,如果不兼容則堵塞。SCOPED 的IX類型一般都是兼容的除非遇到
S類型

2、MDL_SHARED(S)

這把鎖一般用在flush tables with read lock中

mysql> flush tables with read lock;
Query OK, 0 rows affected (0.01 sec)

2017-08-03T18:19:11.603911Z 3 [Note] (acquire_lock)THIS MDL LOCK acquire ok!
2017-08-03T18:19:11.603947Z 3 [Note] (>MDL PRINT) Thread id is 3:
2017-08-03T18:19:11.603971Z 3 [Note] (--->MDL PRINT) Namespace is:GLOBAL
2017-08-03T18:19:11.603994Z 3 [Note] (----->MDL PRINT) Mdl type is:MDL_SHARED(S)
2017-08-03T18:19:11.604045Z 3 [Note] (------>MDL PRINT) Mdl  duration is:MDL_EXPLICIT
2017-08-03T18:19:11.604073Z 3 [Note] (------->MDL PRINT) Mdl  status is:EMPTY
2017-08-03T18:19:11.604133Z 3 [Note] (acquire_lock)THIS MDL LOCK acquire ok!
2017-08-03T18:19:11.604156Z 3 [Note] (>MDL PRINT) Thread id is 3:
2017-08-03T18:19:11.604194Z 3 [Note] (--->MDL PRINT) Namespace is:COMMIT
2017-08-03T18:19:11.604217Z 3 [Note] (----->MDL PRINT) Mdl type is:MDL_SHARED(S)
2017-08-03T18:19:11.604240Z 3 [Note] (------>MDL PRINT) Mdl  duration is:MDL_EXPLICIT
2017-08-03T18:19:11.604310Z 3 [Note] (------->MDL PRINT) Mdl  status is:EMPTY

我們注意到其namspace為GLOBAL和COMMIT顯然他們是SCOPED LOCK,他們的TYPE為S,那么很顯然根據(jù)兼容性原則
SCOPED 的MDL IX和MDL S 不兼容, flush tables with read lock; 就會(huì)堵塞所有DELTE/UPDATE/INSERT/FOR UPDATE等DML和DDL操作(因?yàn)檫@些操作都需要GLOBAL MDL IX鎖)

3、MDL_SHARED_HIGH_PRIO(SH)

這個(gè)鎖基本上大家也是經(jīng)常用到只是沒感覺到而已,比如我們一般desc操作

兼容性:   

Request  |  Granted requests for lock                  |
        type    | S  SH  SR  SW  SWLP  SU  SRO  SNW  SNRW  X  |
      ----------+---------------------------------------------+
      SH        | +   +   +   +    +    +   +    +    +    -  |
mysql> desc test.testsort10;

2017-08-03T19:06:05.843277Z 4 [Note] (acquire_lock)THIS MDL LOCK acquire ok!
2017-08-03T19:06:05.843324Z 4 [Note] (>MDL PRINT) Thread id is 4:
2017-08-03T19:06:05.843359Z 4 [Note] (->MDL PRINT) DB_name is:test
2017-08-03T19:06:05.843392Z 4 [Note] (-->MDL PRINT) OBJ_name is:testsort10
2017-08-03T19:06:05.843425Z 4 [Note] (--->MDL PRINT) Namespace is:TABLE
2017-08-03T19:06:05.843456Z 4 [Note] (---->MDL PRINT) Fast path is:(Y)
2017-08-03T19:06:05.843506Z 4 [Note] (----->MDL PRINT) Mdl type is:MDL_SHARED_HIGH_PRIO(SH)
2017-08-03T19:06:05.843538Z 4 [Note] (------>MDL PRINT) Mdl  duration is:MDL_TRANSACTION
2017-08-03T19:06:05.843570Z 4 [Note] (------->MDL PRINT) Mdl  status is:EMPTY

這中類型的優(yōu)先級(jí)比較高,但是其和X不兼容。也很好理解比如在rename 階段肯定不能進(jìn)行desc操作。

4、MDL_SHARED_READ(SR)

這把鎖一般用在非當(dāng)前讀取的select中

兼容性:

       Request  |  Granted requests for lock                  |
        type    | S  SH  SR  SW  SWLP  SU  SRO  SNW  SNRW  X  |
      ----------+---------------------------------------------+
      SR        | +   +   +   +    +          +      +        +    -    -  |
mysql> select * from test.testsort10 limit 1;

2017-08-03T19:13:52.338764Z 4 [Note] (acquire_lock)THIS MDL LOCK acquire ok!
2017-08-03T19:13:52.338813Z 4 [Note] (>MDL PRINT) Thread id is 4:
2017-08-03T19:13:52.338847Z 4 [Note] (->MDL PRINT) DB_name is:test
2017-08-03T19:13:52.338883Z 4 [Note] (-->MDL PRINT) OBJ_name is:testsort10
2017-08-03T19:13:52.338917Z 4 [Note] (--->MDL PRINT) Namespace is:TABLE
2017-08-03T19:13:52.338950Z 4 [Note] (---->MDL PRINT) Fast path is:(Y)
2017-08-03T19:13:52.339025Z 4 [Note] (----->MDL PRINT) Mdl type is:MDL_SHARED_READ(SR)
2017-08-03T19:13:52.339062Z 4 [Note] (------>MDL PRINT) Mdl  duration is:MDL_TRANSACTION
2017-08-03T19:13:52.339097Z 4 [Note] (------->MDL PRINT) Mdl  status is:EMPTY

這里還是要提及一下平時(shí)我們偶爾會(huì)出現(xiàn)select也堵住的情況(比如DDL的某個(gè)階段需要對(duì)象MDL X鎖)。我們不得不抱怨
MYSQL居然會(huì)堵塞select其實(shí)這里也就是object mdl lock X 和SR 不兼容的問題(參考前面的兼容矩陣)。

5、MDL_SHARED_WRITE(SW)

這把鎖一般用于DELTE/UPDATE/INSERT/FOR UPDATE等操作對(duì)table的加鎖(當(dāng)前讀),不包含DDL操作,但是要注意DML操作實(shí)際上會(huì)有一個(gè)GLOBAL的IX的鎖,前面已經(jīng)提及過了,這把鎖只是對(duì)象上的

兼容性:

       Request  |  Granted requests for lock                  |
        type    | S  SH  SR  SW  SWLP  SU  SRO  SNW  SNRW  X  |
      ----------+---------------------------------------------+
      SW        | +   +   +   +    +    +   -    -    -    -  |
mysql> select * from test.testsort10 limit 1 for update;

2017-08-03T19:25:41.218428Z 4 [Note] (acquire_lock)THIS MDL LOCK acquire ok!
2017-08-03T19:25:41.218461Z 4 [Note] (>MDL PRINT) Thread id is 4:
2017-08-03T19:25:41.218493Z 4 [Note] (->MDL PRINT) DB_name is:test
2017-08-03T19:25:41.218525Z 4 [Note] (-->MDL PRINT) OBJ_name is:testsort10
2017-08-03T19:25:41.218557Z 4 [Note] (--->MDL PRINT) Namespace is:TABLE
2017-08-03T19:25:41.218588Z 4 [Note] (---->MDL PRINT) Fast path is:(Y)
2017-08-03T19:25:41.218620Z 4 [Note] (----->MDL PRINT) Mdl type is:MDL_SHARED_WRITE(SW)
2017-08-03T19:25:41.218677Z 4 [Note] (------>MDL PRINT) Mdl  duration is:MDL_TRANSACTION
2017-08-03T19:25:41.218874Z 4 [Note] (------->MDL PRINT) Mdl  status is:EMPTY

6、MDL_SHARED_WRITE_LOW_PRIO(SWL)

這把鎖很少用到源碼注釋只有

Used by DML statements modifying
tables and using the LOW_PRIORITY clause

兼容性:

       Request  |  Granted requests for lock                  |
        type    | S  SH  SR  SW  SWLP  SU  SRO  SNW  SNRW  X  |
      ----------+---------------------------------------------+
      SWLP      | +   +   +   +    +    +   -    -    -    -  |
mysql> update  LOW_PRIORITY  test.testsort10 set id1=1000 where id1= 96282;


2017-08-03T19:32:47.433507Z 4 [Note] (acquire_lock)THIS MDL LOCK acquire ok!
2017-08-03T19:32:47.433521Z 4 [Note] (>MDL PRINT) Thread id is 4:
2017-08-03T19:32:47.433533Z 4 [Note] (->MDL PRINT) DB_name is:test
2017-08-03T19:32:47.433547Z 4 [Note] (-->MDL PRINT) OBJ_name is:testsort10
2017-08-03T19:32:47.433560Z 4 [Note] (--->MDL PRINT) Namespace is:TABLE
2017-08-03T19:32:47.433572Z 4 [Note] (---->MDL PRINT) Fast path is:(Y)
2017-08-03T19:32:47.433594Z 4 [Note] (----->MDL PRINT) Mdl type is:MDL_SHARED_WRITE_LOW_PRIO(SWL)
2017-08-03T19:32:47.433607Z 4 [Note] (------>MDL PRINT) Mdl  duration is:MDL_TRANSACTION
2017-08-03T19:32:47.433620Z 4 [Note] (------->MDL PRINT) Mdl  status is:EMPTY

7、MDL_SHARED_UPGRADABLE(SU)

這把鎖一般在ALTER TABLE語句中用到,他可以升級(jí)為SNW, SNRW,X,同時(shí)至少X鎖也可以降級(jí)為SU
實(shí)際上在INNODB ONLINE DDL中非常依賴于他,DML(SW)和SELECT(SR)都不會(huì)堵塞

兼容性:

       Request  |  Granted requests for lock                  |
        type    | S  SH  SR  SW  SWLP  SU  SRO  SNW  SNRW  X  |
      ----------+---------------------------------------------+
      SU        | +   +   +   +    +    -   +    -    -    -  |


我們有必要研究一下他的兼容性,可以看到 OBJECT LOCK中(SELECT)SR (DML)SW都是允許的,而在SCOPED LOCK中
雖然DML DDL都會(huì)在GLOBAL 上鎖但是其類型都是IX所以這個(gè)SU鎖不堵塞DML/SELECT 讀寫操作進(jìn)入
INNODB引擎層,它是ONLINE DDL的根基,如果不兼容你都進(jìn)入不了INNODB引擎層,更談不上什么ONLINE
DDL,注意我這里說的是ALGORITHM=INPLACE 并且不設(shè)置LOCK

(For DDL operations with LOCK=DEFAULT, or with the LOCK clause omitted, MySQL uses the lowest level
of locking that is available for that kind of operation, allowing concurrent queries, DML, or both wherever
possible. This is the setting to use when making pre-planned, pre-tested changes that you know will not
cause any availability problems based on the workload for that table
When an operation on the primary key uses ALGORITHM=INPLACE, even though the data is still copied, it
is more efficient than using ALGORITHM=COPY because:
? No undo logging or associated redo logging is required for ALGORITHM=INPLACE. These operations add
overhead to DDL statements that use ALGORITHM=COPY.
? The secondary index entries are pre-sorted, and so can be loaded in order.
? The change buffer is not used, because there are no random-access inserts into the secondary indexes.
)

如下面的語句

mysql>  alter table testsort12 add column it int not null;
Query OK, 0 rows affected (6.27 sec)
Records: 0  Duplicates: 0  Warnings: 0

簡(jiǎn)單的分析一下:

2017-08-03T19:46:54.781453Z 3 [Note] (acquire_lock)THIS MDL LOCK acquire ok!
2017-08-03T19:46:54.781487Z 3 [Note] (>MDL PRINT) Thread id is 3:
2017-08-03T19:46:54.781948Z 3 [Note] (->MDL PRINT) DB_name is:test
2017-08-03T19:46:54.781990Z 3 [Note] (-->MDL PRINT) OBJ_name is:testsort12
2017-08-03T19:46:54.782026Z 3 [Note] (--->MDL PRINT) Namespace is:TABLE
2017-08-03T19:46:54.782060Z 3 [Note] (----->MDL PRINT) Mdl type is:MDL_SHARED_UPGRADABLE(SU)
2017-08-03T19:46:54.782096Z 3 [Note] (------>MDL PRINT) Mdl  duration is:MDL_TRANSACTION
2017-08-03T19:46:54.782175Z 3 [Note] (------->MDL PRINT) Mdl  status is:EMPTY
2017-08-03T19:46:54.803898Z 3 [Note] (upgrade_shared_lock)THIS MDL LOCK will upgrade
2017-08-03T19:46:54.804201Z 3 [Note] (upgrade_shared_lock)THIS MDL LOCK  upgrade TO
2017-08-03T19:46:54.804240Z 3 [Note] (>MDL PRINT) Thread id is 3:
2017-08-03T19:46:54.804254Z 3 [Note] (->MDL PRINT) DB_name is:test
2017-08-03T19:46:54.804267Z 3 [Note] (-->MDL PRINT) OBJ_name is:testsort12
2017-08-03T19:46:54.804280Z 3 [Note] (--->MDL PRINT) Namespace is:TABLE
2017-08-03T19:46:54.804293Z 3 [Note] (----->MDL PRINT) Mdl type :MDL_EXCLUSIVE(X)
2017-08-03T19:46:54.804306Z 3 [Note] (------>MDL PRINT) Mdl  duration is:MDL_TRANSACTION
2017-08-03T19:46:54.804319Z 3 [Note] (------->MDL PRINT) Mdl  status is:EMPTY
2017-08-03T19:46:54.855563Z 3 [Note] (downgrade_lock)THIS MDL LOCK will downgrade
2017-08-03T19:46:54.855693Z 3 [Note] (downgrade_lock) to this MDL lock
2017-08-03T19:46:54.855706Z 3 [Note] (>MDL PRINT) Thread id is 3:
2017-08-03T19:46:54.855717Z 3 [Note] (->MDL PRINT) DB_name is:test
2017-08-03T19:46:54.856053Z 3 [Note] (-->MDL PRINT) OBJ_name is:testsort12
2017-08-03T19:46:54.856069Z 3 [Note] (--->MDL PRINT) Namespace is:TABLE
2017-08-03T19:46:54.856082Z 3 [Note] (----->MDL PRINT) Mdl type is:MDL_SHARED_UPGRADABLE(SU)
2017-08-03T19:46:54.856094Z 3 [Note] (------>MDL PRINT) Mdl  duration is:MDL_TRANSACTION
2017-08-03T19:46:54.856214Z 3 [Note] (------->MDL PRINT) Mdl  status is:EMPTY
2017-08-03T19:47:00.260166Z 3 [Note] (upgrade_shared_lock)THIS MDL LOCK will upgrade
2017-08-03T19:47:00.304057Z 3 [Note] (upgrade_shared_lock)THIS MDL LOCK  upgrade TO
2017-08-03T19:47:00.304090Z 3 [Note] (>MDL PRINT) Thread id is 3:
2017-08-03T19:47:00.304105Z 3 [Note] (->MDL PRINT) DB_name is:test
2017-08-03T19:47:00.304119Z 3 [Note] (-->MDL PRINT) OBJ_name is:testsort12
2017-08-03T19:47:00.304132Z 3 [Note] (--->MDL PRINT) Namespace is:TABLE
2017-08-03T19:47:00.304181Z 3 [Note] (----->MDL PRINT) Mdl type is:MDL_EXCLUSIVE(X)
2017-08-03T19:47:00.304196Z 3 [Note] (------>MDL PRINT) Mdl  duration is:MDL_TRANSACTION
2017-08-03T19:47:00.304211Z 3 [Note] (------->MDL PRINT) Mdl  status is:EMPTY
2017-08-03T19:47:01.032329Z 3 [Note] (acquire_lock)THIS MDL LOCK acquire ok!

首先獲得testsort12表上的

2017-08-03T19:46:54.781487 獲得 MDL_SHARED_UPGRADABLE(SU)
2017-08-03T19:46:54.804293 升級(jí) MDL_EXCLUSIVE(X)
2017-08-03T19:46:54.855563 降級(jí) MDL_SHARED_UPGRADABLE(SU)
2017-08-03T19:47:00.304057 升級(jí) MDL_EXCLUSIVE(X)

因?yàn)椴还苋绾芜@個(gè)alter操作還是比較費(fèi)時(shí)的,從時(shí)間我們看到2017-08-03T19:46:54降級(jí)完成到2017-08-03T19:47:00這段時(shí)間
實(shí)際上是最耗時(shí)的實(shí)際上這里就是實(shí)際的COPY操作,但是這個(gè)過程實(shí)際在MDL SU模式下所以不會(huì)堵塞DML/SELECT操作。
這里再給大家提個(gè)醒所謂的ONLINE DDL只是在COPY階段不堵塞DML/SELECT操作,還是盡量在數(shù)據(jù)庫(kù)壓力小的時(shí)候,
比如如果有DML沒有提交或者SELECT沒有做完這個(gè)時(shí)候SW SR必然堵塞X,而X能夠堵塞一切且為高優(yōu)先級(jí)。這樣導(dǎo)致
的現(xiàn)象就是由于DML未提交堵塞DDL操作而DDL操作堵塞一切操作,基本對(duì)于這個(gè)TABLE的表全部堵塞。

而對(duì)于ALGORITHM=COPY 其他部分差不多,但是在COPY階段用的是SNW鎖,接下來我就先來看看SNW鎖

8、MDL_SHARED_NO_WRITE(SNW)

SU可以升級(jí)為SNW而SNW可以升級(jí)為X,如前面所提及用于ALGORITHM=COPY 中,保護(hù)數(shù)據(jù)的一致性。

兼容性:

       Request  |  Granted requests for lock                   
        type    | S  SH  SR  SW  SWLP  SU  SRO  SNW  SNRW  X  |
      ----------+---------------------------------------------+
      SNW       | +   +   +   -    -    -   +    -    -    -  |


可以看到SR可以但是SW不行,當(dāng)然也就堵塞了DML(SW)而SELECT(SR)不會(huì)堵塞,下面我只是給出了關(guān)鍵部分
mysql>  alter table testsort12 add column ik int not null, ALGORITHM=COPY  ;

2017-08-03T20:07:58.413215Z 3 [Note] (upgrade_shared_lock)THIS MDL LOCK  upgrade TO
2017-08-03T20:07:58.413241Z 3 [Note] (>MDL PRINT) Thread id is 3:
2017-08-03T20:07:58.413257Z 3 [Note] (->MDL PRINT) DB_name is:test
2017-08-03T20:07:58.413273Z 3 [Note] (-->MDL PRINT) OBJ_name is:testsort12
2017-08-03T20:07:58.413292Z 3 [Note] (--->MDL PRINT) Namespace is:TABLE
2017-08-03T20:07:58.413308Z 3 [Note] (----->MDL PRINT) Mdl type is:MDL_SHARED_NO_WRITE(SNW)
2017-08-03T20:07:58.413325Z 3 [Note] (------>MDL PRINT) Mdl  duration is:MDL_TRANSACTION
2017-08-03T20:07:58.413341Z 3 [Note] (------->MDL PRINT) Mdl  status is:EMPTY
2017-08-03T20:08:25.392006Z 3 [Note] (upgrade_shared_lock)THIS MDL LOCK  upgrade TO
2017-08-03T20:08:25.392024Z 3 [Note] (>MDL PRINT) Thread id is 3:
2017-08-03T20:08:25.392086Z 3 [Note] (->MDL PRINT) DB_name is:test
2017-08-03T20:08:25.392159Z 3 [Note] (-->MDL PRINT) OBJ_name is:testsort12
2017-08-03T20:08:25.392199Z 3 [Note] (--->MDL PRINT) Namespace is:TABLE
2017-08-03T20:08:25.392214Z 3 [Note] (----->MDL PRINT) Mdl type is:MDL_EXCLUSIVE(X)
2017-08-03T20:08:25.392228Z 3 [Note] (------>MDL PRINT) Mdl  duration is:MDL_TRANSACTION
2017-08-03T20:08:25.392242Z 3 [Note] (------->MDL PRINT) Mdl  status is:EMPTY

2017-08-03T20:07:58.413308 獲得了MDL_SHARED_NO_WRITE(SNW)
2017-08-03T20:08:25.392006 升級(jí)為MDL_EXCLUSIVE(X)

這2017-08-03T20:07:58.413308到2017-08-03T20:08:25.392006就是實(shí)際COPY的時(shí)間,可見整個(gè)COPY期間只能DML
而不能SELECT,也是ALGORITHM=COPY和ALGORITHM=INPLACE一個(gè)關(guān)鍵區(qū)別。

9、MDL_SHARED_READ_ONLY(SRO)

用于LOCK TABLES READ 語句

兼容性如下

      Request  |  Granted requests for lock                  |
        type    | S  SH  SR  SW  SWLP  SU  SRO  SNW  SNRW  X  |
      ----------+---------------------------------------------+
      SRO       | +   +   +   -    -    +   +    +    -    -  |


堵塞DML(SW)但是SELECT(SR)還是可以的。

mysql> lock table testsort12 read;
Query OK, 0 rows affected (0.01 sec)
2017-08-03T21:08:27.267947Z 3 [Note] (acquire_lock)THIS MDL LOCK acquire ok!
2017-08-03T21:08:27.267979Z 3 [Note] (>MDL PRINT) Thread id is 3:
2017-08-03T21:08:27.268009Z 3 [Note] (->MDL PRINT) DB_name is:test
2017-08-03T21:08:27.268040Z 3 [Note] (-->MDL PRINT) OBJ_name is:testsort12
2017-08-03T21:08:27.268070Z 3 [Note] (--->MDL PRINT) Namespace is:TABLE
2017-08-03T21:08:27.268113Z 3 [Note] (----->MDL PRINT) Mdl type is:MDL_SHARED_READ_ONLY(SRO)
2017-08-03T21:08:27.268145Z 3 [Note] (------>MDL PRINT) Mdl  duration is:MDL_TRANSACTION
2017-08-03T21:08:27.268175Z 3 [Note] (------->MDL PRINT) Mdl  status is:EMPTY 

10、MDL_SHARED_NO_READ_WRITE(SNRW)

用于LOCK TABLES WRITE語句

兼容性:

       Request  |  Granted requests for lock                  |
        type    | S  SH  SR  SW  SWLP  SU  SRO  SNW  SNRW  X  |
      ----------+---------------------------------------------+
      SNRW      | +   +   -   -    -    -   -    -    -    -  |


可以看到DML(SW)和SELECT(SR)都被堵塞只有SH還可以,還可以DESC(SH) 。

mysql> lock table testsort12 write;
Query OK, 0 rows affected (0.00 sec)
2017-08-03T21:13:07.113347Z 3 [Note] (acquire_lock)THIS MDL LOCK acquire ok!
2017-08-03T21:13:07.113407Z 3 [Note] (>MDL PRINT) Thread id is 3:
2017-08-03T21:13:07.113435Z 3 [Note] (--->MDL PRINT) Namespace is:GLOBAL
2017-08-03T21:13:07.113458Z 3 [Note] (---->MDL PRINT) Fast path is:(Y)
2017-08-03T21:13:07.113482Z 3 [Note] (----->MDL PRINT) Mdl type is:MDL_INTENTION_EXCLUSIVE(IX)
2017-08-03T21:13:07.113505Z 3 [Note] (------>MDL PRINT) Mdl  duration is:MDL_STATEMENT
2017-08-03T21:13:07.113604Z 3 [Note] (------->MDL PRINT) Mdl  status is:EMPTY
2017-08-03T21:13:07.113637Z 3 [Note] (acquire_lock)THIS MDL LOCK acquire ok!
2017-08-03T21:13:07.113660Z 3 [Note] (>MDL PRINT) Thread id is 3:
2017-08-03T21:13:07.113681Z 3 [Note] (->MDL PRINT) DB_name is:test
2017-08-03T21:13:07.113703Z 3 [Note] (-->MDL PRINT) OBJ_name is:
2017-08-03T21:13:07.113725Z 3 [Note] (--->MDL PRINT) Namespace is:SCHEMA
2017-08-03T21:13:07.113746Z 3 [Note] (---->MDL PRINT) Fast path is:(Y)
2017-08-03T21:13:07.113768Z 3 [Note] (----->MDL PRINT) Mdl type is:MDL_INTENTION_EXCLUSIVE(IX)
2017-08-03T21:13:07.113791Z 3 [Note] (------>MDL PRINT) Mdl  duration is:MDL_TRANSACTION
2017-08-03T21:13:07.113813Z 3 [Note] (------->MDL PRINT) Mdl  status is:EMPTY
2017-08-03T21:13:07.113842Z 3 [Note] (acquire_lock)THIS MDL LOCK acquire ok!
2017-08-03T21:13:07.113865Z 3 [Note] (>MDL PRINT) Thread id is 3:
2017-08-03T21:13:07.113887Z 3 [Note] (->MDL PRINT) DB_name is:test
2017-08-03T21:13:07.113922Z 3 [Note] (-->MDL PRINT) OBJ_name is:testsort12
2017-08-03T21:13:07.113945Z 3 [Note] (--->MDL PRINT) Namespace is:TABLE
2017-08-03T21:13:07.113975Z 3 [Note] (----->MDL PRINT) Mdl type is:MDL_SHARED_NO_READ_WRITE(SNRW)
2017-08-03T21:13:07.113998Z 3 [Note] (------>MDL PRINT) Mdl  duration is:MDL_TRANSACTION
2017-08-03T21:13:07.114021Z 3 [Note] (------->MDL PRINT) Mdl  status is:EMPTY

除此之外lock table 還需要GLOBAL和SCHEMA上的IX鎖,換句話說flush tables with read lock; 會(huì)堵塞lock table testsort12 write;但是lock table testsort12 read 卻不會(huì)堵塞。

11、MDL_EXCLUSIVE(X)

用于各種DDL操作,注釋為CREATE/DROP/RENAME TABLE操作,實(shí)際上基本全部的DDL都會(huì)涉及到這個(gè)鎖,如上面分析的
add column操作,但是持續(xù)時(shí)間一般比較短暫。

兼容性:

       Request  |  Granted requests for lock                  |
        type    | S  SH  SR  SW  SWLP  SU  SRO  SNW  SNRW  X  |
      ----------+---------------------------------------------+
      X         | -   -   -   -    -    -   -    -    -    -  |


沒有上面意外堵塞一切,也被一切所堵塞
比如剛才的add column操作

2017-08-03T19:46:54.804240Z 3 [Note] (>MDL PRINT) Thread id is 3:
2017-08-03T19:46:54.804254Z 3 [Note] (->MDL PRINT) DB_name is:test
2017-08-03T19:46:54.804267Z 3 [Note] (-->MDL PRINT) OBJ_name is:testsort12
2017-08-03T19:46:54.804280Z 3 [Note] (--->MDL PRINT) Namespace is:TABLE
2017-08-03T19:46:54.804293Z 3 [Note] (----->MDL PRINT) Mdl type is:MDL_EXCLUSIVE(X)
2017-08-03T19:46:54.804306Z 3 [Note] (------>MDL PRINT) Mdl  duration is:MDL_TRANSACTION
2017-08-03T19:46:54.804319Z 3 [Note] (------->MDL PRINT) Mdl  status is:EMPTY

六、源碼注釋部分

enum enum_mdl_type {
  /*
    An intention exclusive metadata lock. Used only for scoped locks.
    Owner of this type of lock can acquire upgradable exclusive locks on
    individual objects.
    Compatible with other IX locks, but is incompatible with scoped S and
    X locks.
  */
  MDL_INTENTION_EXCLUSIVE= 0,
  /*
    A shared metadata lock.
    To be used in cases when we are interested in object metadata only
    and there is no intention to access object data (e.g. for stored
    routines or during preparing prepared statements).
    We also mis-use this type of lock for open HANDLERs, since lock
    acquired by this statement has to be compatible with lock acquired
    by LOCK TABLES ... WRITE statement, i.e. SNRW (We can't get by by
    acquiring S lock at HANDLER ... OPEN time and upgrading it to SR
    lock for HANDLER ... READ as it doesn't solve problem with need
    to abort DML statements which wait on table level lock while having
    open HANDLER in the same connection).
    To avoid deadlock which may occur when SNRW lock is being upgraded to
    X lock for table on which there is an active S lock which is owned by
    thread which waits in its turn for table-level lock owned by thread
    performing upgrade we have to use thr_abort_locks_for_thread()
    facility in such situation.
    This problem does not arise for locks on stored routines as we don't
    use SNRW locks for them. It also does not arise when S locks are used
    during PREPARE calls as table-level locks are not acquired in this
    case.
  */
  MDL_SHARED,
  /*
    A high priority shared metadata lock.
    Used for cases when there is no intention to access object data (i.e.
    data in the table).
    "High priority" means that, unlike other shared locks, it is granted
    ignoring pending requests for exclusive locks. Intended for use in
    cases when we only need to access metadata and not data, e.g. when
    filling an INFORMATION_SCHEMA table.
    Since SH lock is compatible with SNRW lock, the connection that
    holds SH lock lock should not try to acquire any kind of table-level
    or row-level lock, as this can lead to a deadlock. Moreover, after
    acquiring SH lock, the connection should not wait for any other
    resource, as it might cause starvation for X locks and a potential
    deadlock during upgrade of SNW or SNRW to X lock (e.g. if the
    upgrading connection holds the resource that is being waited for).
  */
  MDL_SHARED_HIGH_PRIO,
  /*
    A shared metadata lock for cases when there is an intention to read data
    from table.
    A connection holding this kind of lock can read table metadata and read
    table data (after acquiring appropriate table and row-level locks).
    This means that one can only acquire TL_READ, TL_READ_NO_INSERT, and
    similar table-level locks on table if one holds SR MDL lock on it.
    To be used for tables in SELECTs, subqueries, and LOCK TABLE ... READ
    statements.
  */
  MDL_SHARED_READ,
  /*
    A shared metadata lock for cases when there is an intention to modify
    (and not just read) data in the table.
    A connection holding SW lock can read table metadata and modify or read
    table data (after acquiring appropriate table and row-level locks).
    To be used for tables to be modified by INSERT, UPDATE, DELETE
    statements, but not LOCK TABLE ... WRITE or DDL). Also taken by
    SELECT ... FOR UPDATE.
  */
  MDL_SHARED_WRITE,
  /*
    A version of MDL_SHARED_WRITE lock which has lower priority than
    MDL_SHARED_READ_ONLY locks. Used by DML statements modifying
    tables and using the LOW_PRIORITY clause.
  */
  MDL_SHARED_WRITE_LOW_PRIO,
  /*
    An upgradable shared metadata lock which allows concurrent updates and
    reads of table data.
    A connection holding this kind of lock can read table metadata and read
    table data. It should not modify data as this lock is compatible with
    SRO locks.
    Can be upgraded to SNW, SNRW and X locks. Once SU lock is upgraded to X
    or SNRW lock data modification can happen freely.
    To be used for the first phase of ALTER TABLE.
  */
  MDL_SHARED_UPGRADABLE,
  /*
    A shared metadata lock for cases when we need to read data from table
    and block all concurrent modifications to it (for both data and metadata).
    Used by LOCK TABLES READ statement.
  */
  MDL_SHARED_READ_ONLY,
  /*
    An upgradable shared metadata lock which blocks all attempts to update
    table data, allowing reads.
    A connection holding this kind of lock can read table metadata and read
    table data.
    Can be upgraded to X metadata lock.
    Note, that since this type of lock is not compatible with SNRW or SW
    lock types, acquiring appropriate engine-level locks for reading
    (TL_READ* for MyISAM, shared row locks in InnoDB) should be
    contention-free.
    To be used for the first phase of ALTER TABLE, when copying data between
    tables, to allow concurrent SELECTs from the table, but not UPDATEs.
  */
  MDL_SHARED_NO_WRITE,
  /*
    An upgradable shared metadata lock which allows other connections
    to access table metadata, but not data.
    It blocks all attempts to read or update table data, while allowing
    INFORMATION_SCHEMA and SHOW queries.
    A connection holding this kind of lock can read table metadata modify and
    read table data.
    Can be upgraded to X metadata lock.
    To be used for LOCK TABLES WRITE statement.
    Not compatible with any other lock type except S and SH.
  */
  MDL_SHARED_NO_READ_WRITE,
  /*
    An exclusive metadata lock.
    A connection holding this lock can modify both table's metadata and data.
    No other type of metadata lock can be granted while this lock is held.
    To be used for CREATE/DROP/RENAME TABLE statements and for execution of
    certain phases of other DDL statements.
  */
  MDL_EXCLUSIVE,
  /* This should be the last !!! */
  MDL_TYPE_END};


/** Duration of metadata lock. */

enum enum_mdl_duration {
  /**
    Locks with statement duration are automatically released at the end
    of statement or transaction.
  */
  MDL_STATEMENT= 0,
  /**
    Locks with transaction duration are automatically released at the end
    of transaction.
  */
  MDL_TRANSACTION,
  /**
    Locks with explicit duration survive the end of statement and transaction.
    They have to be released explicitly by calling MDL_context::release_lock().
  */
  MDL_EXPLICIT,
  /* This should be the last ! */
  MDL_DURATION_END };

/**
    Object namespaces.
    Sic: when adding a new member to this enum make sure to
    update m_namespace_to_wait_state_name array in mdl.

    Different types of objects exist in different namespaces
     - GLOBAL is used for the global read lock.
     - TABLESPACE is for tablespaces.
     - SCHEMA is for schemas (aka databases).
     - TABLE is for tables and views.
     - FUNCTION is for stored functions.
     - PROCEDURE is for stored procedures.
     - TRIGGER is for triggers.
     - EVENT is for event scheduler events.
     - COMMIT is for enabling the global read lock to block commits.
     - USER_LEVEL_LOCK is for user-level locks.
     - LOCKING_SERVICE is for the name plugin RW-lock service
    Note that although there isn't metadata locking on triggers,
    it's necessary to have a separate namespace for them since
    MDL_key is also used outside of the MDL subsystem.
    Also note that requests waiting for user-level locks get special
    treatment - waiting is aborted if connection to client is lost.
  */
  enum enum_mdl_namespace { GLOBAL=0,
                            TABLESPACE,
                            SCHEMA,
                            TABLE,
                            FUNCTION,
                            PROCEDURE,
                            TRIGGER,
                            EVENT,
                            COMMIT,
                            USER_LEVEL_LOCK,
                            LOCKING_SERVICE,
                            BACKUP,
                            BINLOG,
                            /* This should be the last ! */
                            NAMESPACE_END };

以上就是MYSQL METADATA LOCK(MDL LOCK) 理論及加鎖類型測(cè)試的詳細(xì)內(nèi)容,更多關(guān)于MYSQL METADATA LOCK(MDL LOCK)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評(píng)論

熟妇一区二区三区高清版| 欧美特级特黄a大片免费| 亚洲成人免费看电影| 熟女国产一区亚洲中文字幕| 天天做天天干天天舔| 青青青视频自偷自拍38碰| 岛国黄色大片在线观看| 成人免费毛片aaaa| 成人H精品动漫在线无码播放| 天天操天天爽天天干| 国产午夜激情福利小视频在线| 最近中文字幕国产在线| 国产精品视频欧美一区二区| 91精品国产麻豆国产| 久久久久久久精品成人热| 中文字幕在线视频一区二区三区| 日本人妻少妇18—xx| 风流唐伯虎电视剧在线观看| 97欧洲一区二区精品免费| 99久久成人日韩欧美精品| 天天日天天做天天日天天做| 无码中文字幕波多野不卡| 伊人情人综合成人久久网小说| 丝袜亚洲另类欧美变态| 成人在线欧美日韩国产| 久久精品久久精品亚洲人| 国产精品一二三不卡带免费视频| 老有所依在线观看完整版| 久久热这里这里只有精品| 大香蕉大香蕉在线看| 国产福利小视频二区| 视频一区二区综合精品| 好吊操视频这里只有精品| 亚洲高清一区二区三区视频在线| 亚洲在线一区二区欧美| 中文字幕免费在线免费| 中国黄色av一级片| 久久综合老鸭窝色综合久久 | 精品高跟鞋丝袜一区二区| 国产成人综合一区2区| 骚逼被大屌狂草视频免费看| 欧美日韩亚洲国产无线码| 老熟妇xxxhd老熟女| 亚洲成人av一区在线| 亚洲视频在线观看高清| 国产精品大陆在线2019不卡| 欧美国产亚洲中英文字幕| 国产精品中文av在线播放| 老师啊太大了啊啊啊尻视频| 欧美精品亚洲精品日韩在线| 一区二区三区的久久的蜜桃的视频 | 蜜桃视频入口久久久| 人妻激情图片视频小说| 国产精品精品精品999| 沙月文乃人妻侵犯中文字幕在线| 免费岛国喷水视频在线观看 | 午夜在线观看一区视频| 亚洲欧美福利在线观看| 经典av尤物一区二区| 国产精品国产三级麻豆| 888欧美视频在线| 日韩成人性色生活片| 国产91精品拍在线观看| 91国产在线视频免费观看| 亚洲午夜伦理视频在线| 日本精品美女在线观看| 黄色视频成年人免费观看| 国产麻豆乱子伦午夜视频观看| 亚洲成人av一区在线| 老司机福利精品免费视频一区二区| 99re国产在线精品| 亚洲精品一线二线在线观看| 精品一区二区三区三区色爱| 欧美精品黑人性xxxx| 性欧美日本大妈母与子| 免费在线黄色观看网站| 欧美男同性恋69视频| 欧美性受xx黑人性猛交| 亚洲欧美色一区二区| 亚洲午夜高清在线观看| 黄色在线观看免费观看在线| 天天干天天爱天天色| av视屏免费在线播放| 免费啪啪啪在线观看视频| 成人av中文字幕一区| 国产精品自拍在线视频| av天堂加勒比在线| 亚洲成人激情视频免费观看了| 亚洲 清纯 国产com| 97少妇精品在线观看| 黄网十四区丁香社区激情五月天 | 亚洲成人情色电影在线观看| 免费观看成年人视频在线观看| 午夜国产免费福利av| 国产精品久久久久网| 大学生A级毛片免费视频| okirakuhuhu在线观看| 久久一区二区三区人妻欧美| 青青青青青青青在线播放视频| 色花堂在线av中文字幕九九| 国产露脸对白在线观看| 国产夫妻视频在线观看免费 | 国产在线观看黄色视频| 亚洲国产中文字幕啊啊啊不行了| 亚洲区美熟妇久久久久| 国产精品自偷自拍啪啪啪| 欧美在线精品一区二区三区视频| 最新中文字幕乱码在线| 亚洲天堂av最新网址| 亚洲av黄色在线网站| 青青青青视频在线播放| 日本高清在线不卡一区二区| 美女大bxxxx内射| 欧美在线精品一区二区三区视频 | 孕妇奶水仑乱A级毛片免费看| 神马午夜在线观看视频| 黄色的网站在线免费看| 被大鸡吧操的好舒服视频免费| 午夜久久久久久久精品熟女| 人妻丰满熟妇综合网| 久久久久久9999久久久久| 色狠狠av线不卡香蕉一区二区| 欧洲精品第一页欧洲精品亚洲| 日韩av大胆在线观看| 一区二区三区国产精选在线播放| 亚洲护士一区二区三区| 97少妇精品在线观看| 亚洲av人人澡人人爽人人爱| 一区二区视频在线观看免费观看| 国产福利小视频大全| 日韩美女福利视频网| 4个黑人操素人视频网站精品91| 免费观看污视频网站| 国产精品亚洲在线观看| 精品一区二区三区午夜| 人人妻人人爽人人澡人人精品| 亚洲欧美一区二区三区爱爱动图| 极品丝袜一区二区三区| 亚洲粉嫩av一区二区三区| av中文在线天堂精品| 亚洲国产美女一区二区三区软件| 天天操夜夜操天天操天天操| 黄色片黄色片wyaa| 日本在线不卡免费视频| 极品性荡少妇一区二区色欲| 2021最新热播中文字幕| 成熟熟女国产精品一区| 极品性荡少妇一区二区色欲| 中文字幕人妻被公上司喝醉在线| 欧美日韩高清午夜蜜桃大香蕉| 99精品视频在线观看免费播放 | 亚洲日本一区二区三区 | 91国产在线免费播放| 日韩伦理短片在线观看| 国产变态另类在线观看| 亚洲日本一区二区三区| 超碰在线中文字幕一区二区| 午夜久久香蕉电影网| 亚洲中文字幕人妻一区| 97少妇精品在线观看| 区一区二区三国产中文字幕| 中文亚洲欧美日韩无线码| 国产视频精品资源网站| 999热精品视频在线| av大全在线播放免费| 在线观看的黄色免费网站| 亚洲 色图 偷拍 欧美| 99av国产精品欲麻豆| 亚洲欧美成人综合在线观看| 美女大bxxxx内射| 乱亲女秽乱长久久久| 国产精品久久久黄网站| 日本少妇的秘密免费视频| 日韩熟女av天堂系列| 黑人解禁人妻叶爱071| 白白操白白色在线免费视频| 亚洲嫩模一区二区三区| 高潮视频在线快速观看国家快速 | 亚洲成人国产综合一区| 青草久久视频在线观看| 亚洲欧美久久久久久久久| 9色在线视频免费观看| 亚洲精品乱码久久久本| 青青青青青青草国产| 久久久久久久一区二区三| 中文人妻AV久久人妻水| 精品国产在线手机在线| 精品国产污污免费网站入口自| 中文字幕 人妻精品| 动漫美女的小穴视频| 成人亚洲精品国产精品| 亚洲无线观看国产高清在线| 18禁污污污app下载| 亚洲美女自偷自拍11页| 亚洲av第国产精品| 国产精品国产三级国产精东| 国产janese在线播放| 97人妻色免费视频| 99精品免费久久久久久久久a| 天天色天天操天天舔| 偷青青国产精品青青在线观看| 一区二区久久成人网| 日韩欧美国产一区ab| 亚洲精品乱码久久久久久密桃明 | av网址国产在线观看| 天天摸天天干天天操科普| 丝袜国产专区在线观看| 亚洲最大黄了色网站| 91香蕉成人app下载| 激情图片日韩欧美人妻| 成人免费毛片aaaa| 午夜青青草原网在线观看| 精品国产亚洲av一淫| 精内国产乱码久久久久久| 免费成人va在线观看| 超碰在线观看免费在线观看| 色综合天天综合网国产成人| chinese国产盗摄一区二区| 999九九久久久精品| av森泽佳奈在线观看 | 国产V亚洲V天堂无码欠欠| 国产亚洲欧美视频网站| 国产九色91在线视频| 国产精品国产精品一区二区| 国产成人无码精品久久久电影| 99热久久这里只有精品| 老鸭窝日韩精品视频观看| 又大又湿又爽又紧A视频| 亚洲欧美综合在线探花| 亚洲的电影一区二区三区| 被大鸡吧操的好舒服视频免费 | gay gay男男瑟瑟在线网站| 亚洲福利午夜久久久精品电影网 | jiuse91九色视频| 美女av色播在线播放| 99精品亚洲av无码国产另类| 男人在床上插女人视频| 久久久久久97三级| 青青青视频自偷自拍38碰| 久久美欧人妻少妇一区二区三区| 成年人该看的视频黄免费| 最近的中文字幕在线mv视频| 免费观看成年人视频在线观看| 人人爽亚洲av人人爽av| 亚洲精品一线二线在线观看| 亚洲免费在线视频网站| 国产va精品免费观看| 玖玖一区二区在线观看| 欧美成人小视频在线免费看| 日本脱亚入欧是指什么| 欧美交性又色又爽又黄麻豆| 国产精品国产三级国产精东| 水蜜桃国产一区二区三区| 日本三极片中文字幕| 日本在线不卡免费视频| 免费十精品十国产网站| 福利午夜视频在线合集| 色噜噜噜噜18禁止观看| 欧美一区二区三区乱码在线播放| 亚洲免费福利一区二区三区| 三级av中文字幕在线观看| 青青青青在线视频免费观看| 一区二区三区美女毛片| 日本一二三区不卡无| 国产福利小视频二区| 天码人妻一区二区三区在线看| 欧美交性又色又爽又黄麻豆| 风流唐伯虎电视剧在线观看 | 日本一道二三区视频久久| 国产午夜亚洲精品不卡在线观看 | 青青青青青免费视频| 精品美女久久久久久| 91大神福利视频网| 亚洲蜜臀av一区二区三区九色| 直接观看免费黄网站| 蜜桃色婷婷久久久福利在线| 91精品国产91久久自产久强| 亚洲精品无码久久久久不卡| 亚洲伊人av天堂有码在线| 日本熟妇丰满厨房55| 老熟妇xxxhd老熟女| 黄网十四区丁香社区激情五月天| 欧美日本aⅴ免费视频| 大鸡八强奸视频在线观看| 成年美女黄网站18禁久久| 熟女人妻在线观看视频| 欧美性受xx黑人性猛交| 午夜影院在线观看视频羞羞羞| 中文字幕高清免费在线人妻| 91香蕉成人app下载| 国产品国产三级国产普通话三级| 日本少妇人妻xxxxx18| 一区二区三区四区五区性感视频 | 亚洲一区二区三区精品视频在线 | 国产精品亚洲在线观看| 40道精品招牌菜特色| 国产精品自拍在线视频| 自拍偷拍日韩欧美亚洲| 国产+亚洲+欧美+另类| 日本av在线一区二区三区| 久久h视频在线观看| 精品乱子伦一区二区三区免费播| 国语对白xxxx乱大交| 美女操逼免费短视频下载链接| 天天操天天污天天射| 91中文字幕最新合集| 中文字幕第三十八页久久| 亚洲成人精品女人久久久| 日韩午夜福利精品试看| 粉嫩小穴流水视频在线观看| 亚洲va欧美va人人爽3p| 国产又粗又黄又硬又爽| 年轻的人妻被夫上司侵犯| 精品老妇女久久9g国产| 男人天堂最新地址av| 亚洲中文字字幕乱码| 大香蕉福利在线观看| 午夜影院在线观看视频羞羞羞| 在线制服丝袜中文字幕| 大鸡巴插入美女黑黑的阴毛| 大香蕉福利在线观看| 伊人综合aⅴ在线网| sejizz在线视频| 亚洲熟妇无码一区二区三区| 人人人妻人人澡人人| 亚洲精品 日韩电影| 婷婷久久久久深爱网| huangse网站在线观看| 91国产资源在线视频| 天堂av在线播放免费| 国产乱弄免费视频观看| 在线观看的黄色免费网站| 亚洲高清国产一区二区三区| 国产成人精品av网站| 久久久精品欧洲亚洲av| 97人妻总资源视频| 综合一区二区三区蜜臀| 18禁美女羞羞免费网站| 免费十精品十国产网站| 精品老妇女久久9g国产| 啪啪啪啪啪啪啪啪av| 任我爽精品视频在线播放| 青娱乐在线免费视频盛宴| 家庭女教师中文字幕在线播放| 视频啪啪啪免费观看| 亚洲高清国产一区二区三区| 91免费福利网91麻豆国产精品| 四虎永久在线精品免费区二区| 六月婷婷激情一区二区三区| av视屏免费在线播放| 欧美 亚洲 另类综合| 成年午夜影片国产片| 美女 午夜 在线视频| 亚洲的电影一区二区三区| 亚洲中文字字幕乱码| 成熟熟女国产精品一区| 初美沙希中文字幕在线| 国产极品精品免费视频| 欧美成人小视频在线免费看| 日本熟妇丰满厨房55| 亚洲人妻av毛片在线| 中文字幕在线观看极品视频| 丁香花免费在线观看中文字幕| 欧美在线一二三视频| 在线免费观看国产精品黄色| 岛国黄色大片在线观看| 阿v天堂2014 一区亚洲| 日韩人妻丝袜中文字幕| 在线观看日韩激情视频| 亚洲粉嫩av一区二区三区| av天堂资源最新版在线看| 人妻av无码专区久久绿巨人| 日韩av免费观看一区| 日本性感美女视频网站| 欧美日韩v中文在线| 天天日天天天天天天天天天天| 国产日韩精品免费在线| 国产黄色高清资源在线免费观看| 三上悠亚和黑人665番号| www久久久久久久久久久| 老司机午夜精品视频资源| 亚洲一区二区三区五区| 亚洲人妻国产精品综合| avjpm亚洲伊人久久| 国产精品国色综合久久| 3D动漫精品啪啪一区二区下载| 亚洲综合自拍视频一区| 91九色国产熟女一区二区| 国产一区成人在线观看视频 | 国产之丝袜脚在线一区二区三区| 91av中文视频在线| 日本最新一二三区不卡在线| 激情啪啪啪啪一区二区三区| 大鸡巴操b视频在线| 中文字幕综合一区二区| 92福利视频午夜1000看| 免费av岛国天堂网站| 天天干天天操天天玩天天射 | 日本一道二三区视频久久| 在线免费观看国产精品黄色| av线天堂在线观看| 国产精品成久久久久三级蜜臀av | 天天操夜夜骑日日摸| 超碰在线观看免费在线观看| 二区中出在线观看老师| 亚洲天天干 夜夜操| 美女视频福利免费看| 91亚洲国产成人精品性色| 天天干狠狠干天天操 | 亚洲av香蕉一区区二区三区犇| 国产成人自拍视频播放| 日本性感美女写真视频| 国产一线二线三线的区别在哪 | 国产av欧美精品高潮网站| 亚洲国产中文字幕啊啊啊不行了| 91亚洲国产成人精品性色| 免费岛国喷水视频在线观看| 91精品资源免费观看| 女生自摸在线观看一区二区三区| 国产女人叫床高潮大片视频| 午夜青青草原网在线观看| 亚洲免费成人a v| 视频久久久久久久人妻| 老鸭窝在线观看一区| 久久久超爽一二三av| 国产成人精品福利短视频| 五月婷婷在线观看视频免费| 国产无遮挡裸体免费直播视频| 操人妻嗷嗷叫视频一区二区| 三级av中文字幕在线观看| 精品久久久久久久久久久99| 521精品视频在线观看| 国产福利小视频免费观看| 在线观看黄色成年人网站| 激情啪啪啪啪一区二区三区 | av天堂中文字幕最新| 久久机热/这里只有| 在线免费观看靠比视频的网站| 亚洲精品乱码久久久本| 国产一区二区视频观看| 老师啊太大了啊啊啊尻视频| rct470中文字幕在线| 亚洲av男人的天堂你懂的| 中文字幕在线观看极品视频| 亚洲欧美一卡二卡三卡| 在线视频免费观看网| 亚洲成a人片777777| av日韩在线观看大全| 欧美日韩v中文在线| 在线观看成人国产电影| 青青青视频自偷自拍38碰| 女生自摸在线观看一区二区三区| 亚洲精品一区二区三区老狼| 99精品视频之69精品视频| 日韩欧美一级精品在线观看| 天天摸天天日天天操| 无码国产精品一区二区高潮久久4| 国产欧美日韩第三页| 1区2区3区4区视频在线观看| 99人妻视频免费在线| 热久久只有这里有精品| 无码中文字幕波多野不卡| www骚国产精品视频| 亚洲国产精品久久久久久6| 亚洲精品三级av在线免费观看| 岛国毛片视频免费在线观看| 日本啪啪啪啪啪啪啪| 久久久久久性虐视频| 国产午夜激情福利小视频在线| 激情色图一区二区三区| 亚洲av第国产精品| 精产国品久久一二三产区区别| 欧美日韩v中文在线| 激情伦理欧美日韩中文字幕| 激情图片日韩欧美人妻| 老司机福利精品视频在线| 91精品啪在线免费| av手机在线免费观看日韩av| 日本熟妇色熟妇在线观看| 欧美亚洲自偷自拍 在线| 夜夜操,天天操,狠狠操| 三上悠亚和黑人665番号| 欧美成人综合色在线噜噜| 日韩av有码一区二区三区4| 91九色porny国产在线| 欧美一区二区三区高清不卡tv| 日本一区精品视频在线观看| 97年大学生大白天操逼| 欧美一区二区三区激情啪啪啪| 午夜蜜桃一区二区三区| www,久久久,com| 五月色婷婷综合开心网4438| 传媒在线播放国产精品一区| 亚洲成人av一区在线| 人妻激情图片视频小说| 天天日天天日天天射天天干| 婷婷六月天中文字幕| av新中文天堂在线网址| 18禁美女黄网站色大片下载| 夜夜嗨av蜜臀av| 日韩美女综合中文字幕pp| 国产又粗又硬又猛的毛片视频| 视频 一区二区在线观看| 水蜜桃国产一区二区三区| 99热这里只有国产精品6| 夜色17s精品人妻熟女| 亚洲午夜高清在线观看| 91国产在线免费播放| 在线视频免费观看网| 在线成人日韩av电影| 美女av色播在线播放| 中字幕人妻熟女人妻a62v网| 成人av在线资源网站| 国产之丝袜脚在线一区二区三区| 欧美亚洲免费视频观看| 粉嫩欧美美人妻小视频| 晚上一个人看操B片| 99热久久这里只有精品| 五十路av熟女松本翔子| 99热99这里精品6国产| 影音先锋女人av噜噜色| 红杏久久av人妻一区| 在线播放国产黄色av| 懂色av之国产精品| 国产一区成人在线观看视频| 亚洲激情唯美亚洲激情图片| 天天日夜夜干天天操| 国产黄网站在线观看播放| 黄色大片免费观看网站| 亚洲中文字字幕乱码| 端庄人妻堕落挣扎沉沦| 日本三极片视频网站观看| 国产精品自拍偷拍a| 国产亚洲成人免费在线观看| 国产一区二区视频观看| 国产 在线 免费 精品| 日韩视频一区二区免费观看| 国产在线观看免费人成短视频| japanese五十路熟女熟妇| av久久精品北条麻妃av观看| av破解版在线观看| 精产国品久久一二三产区区别| 偷拍自拍国产在线视频| 中出中文字幕在线观看| 亚洲免费国产在线日韩| 欧洲日韩亚洲一区二区三区 | 大骚逼91抽插出水视频| 97成人免费在线观看网站| 天堂av在线官网中文| 久久机热/这里只有| 一区二区三区另类在线 | 天天做天天爽夜夜做少妇| 国产成人精品福利短视频| 日本五十路熟新垣里子| 中文字幕在线第一页成人| 欧美成人黄片一区二区三区 | 老司机深夜免费福利视频在线观看| 黑人乱偷人妻中文字幕| 2021最新热播中文字幕| 亚洲视频乱码在线观看| 天码人妻一区二区三区在线看| 精品区一区二区三区四区人妻| 孕妇奶水仑乱A级毛片免费看| 亚洲一区二区久久久人妻| 91在线免费观看成人| 久青青草视频手机在线免费观看| 日韩中文字幕精品淫| 天天射夜夜操狠狠干| 色秀欧美视频第一页| 沙月文乃人妻侵犯中文字幕在线| av大全在线播放免费| 亚洲一级av大片免费观看| 五十路息与子猛烈交尾视频| 2022国产综合在线干| 天天操天天操天天碰| yellow在线播放av啊啊啊| 欧美亚洲少妇福利视频| 超碰97人人澡人人| 国产精彩对白一区二区三区| 一区二区在线观看少妇| 精品av国产一区二区三区四区| 91中文字幕最新合集| 中文字幕无码日韩专区免费| 偷拍自拍视频图片免费| 日本少妇人妻xxxxx18| rct470中文字幕在线| 男人操女人逼逼视频网站| 天天插天天色天天日| 国产精品精品精品999| 动漫美女的小穴视频| 天堂中文字幕翔田av | 亚洲av成人免费网站| 亚洲午夜伦理视频在线 | 超碰97人人做人人爱| 久久久久久cao我的性感人妻| 激情图片日韩欧美人妻| 99re6热在线精品| 一区二区三区av高清免费| 亚洲综合自拍视频一区| 夏目彩春在线中文字幕| 99久久成人日韩欧美精品| 92福利视频午夜1000看| 自拍偷拍 国产资源| 在线观看视频网站麻豆| 无码国产精品一区二区高潮久久4 日韩欧美一级精品在线观看 | 久久久久久cao我的性感人妻| 国产麻豆剧传媒精品国产av蜜桃| 日视频免费在线观看| 精内国产乱码久久久久久| 扒开让我视频在线观看| 欧美精品免费aaaaaa| 成人H精品动漫在线无码播放| 久草极品美女视频在线观看| 日韩中文字幕福利av| 91精品国产91青青碰| 精品国产成人亚洲午夜| 欧美精品免费aaaaaa| www日韩a级s片av| 成人sm视频在线观看| 大香蕉福利在线观看| 丝袜美腿欧美另类 中文字幕| 玩弄人妻熟妇性色av少妇| 最近的中文字幕在线mv视频| 中英文字幕av一区| 中文字幕成人日韩欧美| 日本av高清免费网站| 欧美男人大鸡吧插女人视频| 自拍偷拍日韩欧美一区二区| 亚洲免费视频欧洲免费视频 | 视频在线免费观看你懂得| 九九热99视频在线观看97| 9l人妻人人爽人人爽| 五十路av熟女松本翔子| 香港一级特黄大片在线播放| 超级av免费观看一区二区三区| 日本在线一区二区不卡视频| 亚洲av在线观看尤物| 大黑人性xxxxbbbb| 亚洲乱码中文字幕在线| 社区自拍揄拍尻屁你懂的| 亚洲一区二区激情在线| 最近中文字幕国产在线| 9色精品视频在线观看| 91人妻精品久久久久久久网站| 亚洲av日韩高清hd| 成人国产激情自拍三区| 亚洲av无码成人精品区辽| 少妇露脸深喉口爆吞精| 亚洲丝袜老师诱惑在线观看| 国产黄色高清资源在线免费观看| 天天干天天日天天干天天操| 黄色成人在线中文字幕| 日噜噜噜夜夜噜噜噜天天噜噜噜| 97超碰免费在线视频| 无套猛戳丰满少妇人妻| 男人和女人激情视频| 极品丝袜一区二区三区| 亚洲美女自偷自拍11页| 成人资源在线观看免费官网| 免费人成黄页网站在线观看国产| 成人福利视频免费在线| 日本午夜爽爽爽爽爽视频在线观看| 日韩欧美高清免费在线| 都市家庭人妻激情自拍视频| 亚洲午夜在线视频福利| 免费观看理论片完整版| 超鹏97历史在线观看| 青青青视频手机在线观看| 热久久只有这里有精品| 亚洲人妻国产精品综合| 婷婷久久久综合中文字幕| 超碰中文字幕免费观看| 18禁无翼鸟成人在线| 大陆胖女人与丈夫操b国语高清 | 岛国青草视频在线观看| 91国内视频在线观看| 福利午夜视频在线合集| 性欧美激情久久久久久久| 和邻居少妇愉情中文字幕| 亚洲欧美综合另类13p| 亚洲欧美清纯唯美另类| 偷拍自拍亚洲美腿丝袜| 亚洲1区2区3区精华液| 天天草天天色天天干| 日韩午夜福利精品试看| 日本女大学生的黄色小视频| 91免费福利网91麻豆国产精品| 午夜dv内射一区区| 大胸性感美女羞爽操逼毛片| 亚洲欧美国产综合777| 亚洲av无码成人精品区辽| 国产精品污污污久久| 真实国模和老外性视频| 免费男阳茎伸入女阳道视频| 一区二区三区麻豆福利视频| 国产夫妻视频在线观看免费| 国产精品久久久黄网站| 综合一区二区三区蜜臀| 97超碰国语国产97超碰| 久久久久久久精品成人热| 男人在床上插女人视频| 91自产国产精品视频| 91香蕉成人app下载| 国产又粗又猛又爽又黄的视频在线| 美女小视频网站在线| 亚洲福利精品视频在线免费观看| 馒头大胆亚洲一区二区| 日韩近亲视频在线观看| 国产大学生援交正在播放| 3344免费偷拍视频| 非洲黑人一级特黄片| 搡老熟女一区二区在线观看| 91精品国产麻豆国产| 午夜极品美女福利视频| 久草视频在线一区二区三区资源站| 一二三区在线观看视频| 亚洲国产欧美一区二区三区…| 97国产精品97久久| 日本黄色特一级视频| 国产综合精品久久久久蜜臀| 黄色大片男人操女人逼| 在线观看一区二区三级| 亚洲精品ww久久久久久| 大胸性感美女羞爽操逼毛片| 五十路熟女av天堂| 伊人综合免费在线视频| 亚洲嫩模一区二区三区| 国产亚洲国产av网站在线| 中文字幕免费福利视频6| 91成人在线观看免费视频| 色哟哟国产精品入口| 深田咏美亚洲一区二区| 亚洲精品精品国产综合| 免费黄色成人午夜在线网站| 亚洲一区自拍高清免费视频| 亚洲图片偷拍自拍区| 3337p日本欧洲大胆色噜噜| 国产成人综合一区2区| 成年人的在线免费视频| 中国视频一区二区三区| 97超碰国语国产97超碰| 国产欧美精品一区二区高清| 欧美少妇性一区二区三区| 懂色av蜜桃a v| 国产视频一区二区午夜| 天天日夜夜干天天操| 在线免费观看欧美小视频| 国产亚洲视频在线二区| 新婚人妻聚会被中出| 国产女人被做到高潮免费视频 | 国产1区,2区,3区| 青青青青青免费视频| 91av精品视频在线| 日韩欧美在线观看不卡一区二区| 国产一区二区火爆视频 | chinese国产盗摄一区二区| 1024久久国产精品| 97青青青手机在线视频| 青青青国产片免费观看视频| 日韩欧美一级精品在线观看| 国产aⅴ一线在线观看| 麻豆精品成人免费视频| 日本a级视频老女人| 亚洲中文字幕校园春色| 97精品人妻一区二区三区精品| av在线免费资源站| 天天操天天射天天操天天天| 午夜精品一区二区三区福利视频| 国产不卡av在线免费| 97香蕉碰碰人妻国产樱花| 日韩av熟妇在线观看| 青青色国产视频在线| 黄色大片免费观看网站| 免费看国产又粗又猛又爽又黄视频| 骚货自慰被发现爆操| 99婷婷在线观看视频| 五十路丰满人妻熟妇| 亚洲国产精品美女在线观看| 男大肉棒猛烈插女免费视频 | 可以在线观看的av中文字幕| 亚洲精品无码色午夜福利理论片| 国产久久久精品毛片| 毛片av在线免费看| 99re6热在线精品| 婷婷综合亚洲爱久久| 欧美另类重口味极品在线观看| 绝色少妇高潮3在线观看| 日本少妇高清视频xxxxx| 亚洲国产在人线放午夜| 亚洲 中文字幕在线 日韩| 五十路老熟女码av| 国产黄色片在线收看| 在线观看免费视频网| 亚洲精品成人网久久久久久小说 | 一区二区三区美女毛片| 日本少妇人妻xxxxxhd| 黄色在线观看免费观看在线| 人妻少妇一区二区三区蜜桃| 免费人成黄页网站在线观看国产| 欧洲亚洲欧美日韩综合| 国产麻豆91在线视频| 播放日本一区二区三区电影| 亚洲va国产va欧美精品88| av老司机精品在线观看| 91精品免费久久久久久| 大鸡巴插入美女黑黑的阴毛| 亚洲 中文 自拍 无码| 少妇人妻真实精品视频| 日本脱亚入欧是指什么| 午夜久久久久久久99| 日本精品视频不卡一二三| 久久久人妻一区二区| 播放日本一区二区三区电影| 5528327男人天堂| 亚洲欧洲av天堂综合| 国产欧美精品一区二区高清| 日本五十路熟新垣里子| 欧美日本国产自视大全| 丝袜长腿第一页在线| 天天色天天操天天透| 超碰97人人做人人爱| 亚洲va欧美va人人爽3p| 亚洲精品成人网久久久久久小说| 国产成人精品av网站| 红桃av成人在线观看| 中文字幕 亚洲av| 欧美精品国产综合久久| 又粗又硬又猛又黄免费30| 欧美日韩情色在线观看| 狠狠的往里顶撞h百合| 五十路熟女人妻一区二区9933| 中文字幕,亚洲人妻| 丁香花免费在线观看中文字幕| 自拍偷拍亚洲精品第2页| 日日夜夜大香蕉伊人| 亚洲免费在线视频网站| 无码中文字幕波多野不卡| 男女之间激情网午夜在线| 国产精品系列在线观看一区二区| 久久久久五月天丁香社区| 偷青青国产精品青青在线观看 | 91精品国产观看免费| 亚洲欧美福利在线观看| 日韩三级电影华丽的外出| 国产真实灌醉下药美女av福利| 2019av在线视频| 国产精选一区在线播放| 不卡日韩av在线观看| 日韩激情文学在线视频| 班长撕开乳罩揉我胸好爽| 午夜的视频在线观看| 97精品视频在线观看| 亚洲欧美另类自拍偷拍色图| 顶级尤物粉嫩小尤物网站| 国产午夜激情福利小视频在线| 啪啪啪啪啪啪啪啪啪啪黄色| 动漫黑丝美女的鸡巴| 成人免费毛片aaaa| 日韩亚洲高清在线观看| 婷婷五月亚洲综合在线| 初美沙希中文字幕在线| 天天操天天爽天天干| 一区二区三区日韩久久| 国产麻豆国语对白露脸剧情| 中国黄片视频一区91| 精品一区二区亚洲欧美| caoporm超碰国产| 亚洲推理片免费看网站| 成人网18免费视频版国产| 偷拍自拍福利视频在线观看| 欧美国品一二三产区区别| 国产女人露脸高潮对白视频| 91国内精品自线在拍白富美| 伊人精品福利综合导航| 色伦色伦777国产精品| 国产在线观看免费人成短视频| 中文字幕av第1页中文字幕| 久久久久五月天丁香社区| 国产成人一区二区三区电影网站 | 免费观看国产综合视频| 在线观看操大逼视频| 91九色porny蝌蚪国产成人| 男人天堂av天天操| 欧美viboss性丰满| 欧美黄色录像免费看的| 国产揄拍高清国内精品对白 | 久久久久五月天丁香社区| 狠狠鲁狠狠操天天晚上干干| 欧美va不卡视频在线观看| 男人在床上插女人视频| 57pao国产一区二区| 欧美一区二区三区四区性视频| 青青青国产片免费观看视频| gogo国模私拍视频| 天天干天天搞天天摸| 天天躁夜夜躁日日躁a麻豆| 国产污污污污网站在线| 午夜的视频在线观看| 成年人啪啪视频在线观看| 91社福利《在线观看| 亚洲精品久久视频婷婷| 国产高清女主播在线| 最新国产精品拍在线观看| 丁香花免费在线观看中文字幕| 伊人开心婷婷国产av| 亚洲精品无码色午夜福利理论片| 青青在线视频性感少妇和隔壁黑丝| 女警官打开双腿沦为性奴| 欧美乱妇无乱码一区二区| 亚洲无码一区在线影院| 精品国产乱码一区二区三区乱| 不戴胸罩引我诱的隔壁的人妻| 亚洲av无女神免非久久| 成人18禁网站在线播放| 97精品视频在线观看| 免费高清自慰一区二区三区网站| 亚洲av可乐操首页| 韩国亚洲欧美超一级在线播放视频| 欧美成人精品在线观看| 亚洲天堂av最新网址| 亚洲在线免费h观看网站| 91精品国产综合久久久蜜| 日韩中文字幕在线播放第二页| jiujiure精品视频在线| 一区二区三区四区五区性感视频| 男人和女人激情视频| 一级黄片久久久久久久久| 国产一区二区久久久裸臀| 国产一区av澳门在线观看| 啊慢点鸡巴太大了啊舒服视频| 97a片免费在线观看| 2025年人妻中文字幕乱码在线| 天天躁日日躁狠狠躁av麻豆| 久久一区二区三区人妻欧美| 老师啊太大了啊啊啊尻视频| 国产av自拍偷拍盛宴| 视频一区二区在线免费播放| 超pen在线观看视频公开97| 丁香花免费在线观看中文字幕| 中文字幕一区二区三区蜜月| 亚洲精品久久视频婷婷| 最新97国产在线视频| 亚洲欧美另类手机在线| 国产真实乱子伦a视频| 亚洲一级美女啪啪啪| av日韩在线免费播放| 日本免费视频午夜福利视频| 国产精品国产三级国产精东| 成人性爱在线看四区| 中字幕人妻熟女人妻a62v网| 久久久精品999精品日本 | 中文字幕乱码人妻电影| 男人插女人视频网站| 色花堂在线av中文字幕九九| 3337p日本欧洲大胆色噜噜| 偷拍自拍亚洲美腿丝袜| 精品国产成人亚洲午夜| 欧美亚洲一二三区蜜臀| 久久香蕉国产免费天天| av久久精品北条麻妃av观看| 一区二区三区激情在线| 好了av中文字幕在线| 亚洲免费福利一区二区三区| 欧美一区二区中文字幕电影| 日韩精品二区一区久久| 人妻少妇中文有码精品| 日本性感美女三级视频| 亚洲精品福利网站图片| 极品丝袜一区二区三区| 51国产偷自视频在线播放| 日韩av有码一区二区三区4| 啊啊好慢点插舔我逼啊啊啊视频| 伊人网中文字幕在线视频| 日本少妇的秘密免费视频| 日本一区精品视频在线观看| 免费在线观看污污视频网站| 性感美女高潮视频久久久| 97国产在线观看高清| 欧美激情精品在线观看| www日韩a级s片av| 北条麻妃肉色丝袜视频| 日日日日日日日日夜夜夜夜夜夜| 78色精品一区二区三区| 福利国产视频在线观看| 亚洲欧美久久久久久久久| 又粗又硬又猛又黄免费30| 亚洲第一伊人天堂网| 国产激情av网站在线观看| 国产午夜无码福利在线看| 综合一区二区三区蜜臀| 欧美亚洲免费视频观看| 在线观看视频 你懂的| 精品一区二区三区在线观看| 日曰摸日日碰夜夜爽歪歪| 成人H精品动漫在线无码播放| 久久久久久97三级| 蜜桃色婷婷久久久福利在线| 91九色porny蝌蚪国产成人| 日本av熟女在线视频| 黄色的网站在线免费看| 亚洲av色图18p| 超级福利视频在线观看| av破解版在线观看| 老熟妇凹凸淫老妇女av在线观看| 欧美怡红院视频在线观看| 97国产在线观看高清| 欧洲日韩亚洲一区二区三区| 人妻熟女中文字幕aⅴ在线| 视频 国产 精品 熟女 | 91精品综合久久久久3d动漫| 78色精品一区二区三区| 国产在线拍揄自揄视频网站| 57pao国产一区二区| 中文字幕免费在线免费| 日韩中文字幕精品淫| 国产精品成人xxxx| 国产视频精品资源网站| 中文字幕日韩人妻在线三区| 中国视频一区二区三区| 中文字幕欧美日韩射射一| 国产日韩av一区二区在线| 特大黑人巨大xxxx| 日本少妇人妻xxxxxhd| 日本av熟女在线视频| 亚洲另类伦春色综合小| 人人超碰国字幕观看97| huangse网站在线观看| 午夜av一区二区三区| 免费费一级特黄真人片 | 97人妻夜夜爽二区欧美极品| 午夜久久久久久久精品熟女| 2022中文字幕在线| 91九色porny国产蝌蚪视频| 78色精品一区二区三区| av黄色成人在线观看| 日本性感美女写真视频| 成人免费公开视频无毒| 九九视频在线精品播放| 亚洲 人妻 激情 中文| 青青青国产免费视频| 天天干狠狠干天天操 | 国产中文字幕四区在线观看| 中国产一级黄片免费视频播放| 999久久久久999| 19一区二区三区在线播放| 中文字幕高清资源站| 老司机福利精品视频在线| 最后99天全集在线观看| 亚洲精品国产久久久久久| 日韩av大胆在线观看| 国产 在线 免费 精品| 欧美精产国品一二三产品价格 | 91免费观看在线网站| 91she九色精品国产| 男人天堂色男人av| 黄色片年轻人在线观看| 亚洲偷自拍高清视频| 国产亚洲欧美视频网站| 无忧传媒在线观看视频| 我想看操逼黄色大片| 日韩欧美亚洲熟女人妻| 91 亚洲视频在线观看| 精品视频中文字幕在线播放| 欧美香蕉人妻精品一区二区| 国产精品久久综合久久| 久久丁香婷婷六月天| 色综合久久无码中文字幕波多| 大鸡吧插入女阴道黄色片| 色哟哟在线网站入口| 天天干夜夜操啊啊啊| 美女骚逼日出水来了| 亚洲av成人免费网站| 91桃色成人网络在线观看| 在线制服丝袜中文字幕| 成年人黄视频在线观看| 亚洲粉嫩av一区二区三区| 亚洲少妇高潮免费观看| 日本一本午夜在线播放| 91久久精品色伊人6882| 国产老熟女伦老熟妇ⅹ| 亚洲伊人色一综合网| 国产自拍黄片在线观看| 日本裸体熟妇区二区欧美| 午夜极品美女福利视频| 91天堂天天日天天操| 家庭女教师中文字幕在线播放| 久久久久久国产精品| 在线播放一区二区三区Av无码| 91色网站免费在线观看| 中文字幕一区的人妻欧美日韩| 国产综合高清在线观看| 在线免费观看欧美小视频| 中国黄色av一级片| 老熟妇凹凸淫老妇女av在线观看| 日韩在线视频观看有码在线| 国产成人综合一区2区| 91精品激情五月婷婷在线| 日辽宁老肥女在线观看视频| 天天躁日日躁狠狠躁躁欧美av | 欧美专区日韩专区国产专区| 欧美伊人久久大香线蕉综合| 免费啪啪啪在线观看视频| 特级欧美插插插插插bbbbb| 午夜国产免费福利av| 精品成人午夜免费看| 中文字幕最新久久久| 93人妻人人揉人人澡人人| 淫秽激情视频免费观看| 激情人妻校园春色亚洲欧美| 亚洲一区二区三区在线高清| 啊啊好大好爽啊啊操我啊啊视频 | 青青青视频手机在线观看| 男生舔女生逼逼视频| 一区二区三区日韩久久| 91九色porny蝌蚪国产成人| 亚洲av日韩精品久久久| 小穴多水久久精品免费看| 成年人的在线免费视频| 天堂女人av一区二区| 888欧美视频在线| 涩爱综合久久五月蜜臀| 亚洲av可乐操首页| 激情伦理欧美日韩中文字幕| 蜜桃视频在线欧美一区| 国产美女精品福利在线| 中文字幕高清免费在线人妻 | 色婷婷综合激情五月免费观看| 一区国内二区日韩三区欧美| 国产女人被做到高潮免费视频| yy96视频在线观看| 亚洲 国产 成人 在线| 亚洲人妻30pwc| 成人性爱在线看四区| 亚洲欧美另类自拍偷拍色图| 精品区一区二区三区四区人妻| 亚洲熟妇无码一区二区三区| 亚洲va国产va欧美va在线| 性感美女高潮视频久久久| 玖玖一区二区在线观看| 色呦呦视频在线观看视频| 成年人该看的视频黄免费| 人妻久久久精品69系列| 性欧美日本大妈母与子| 极品粉嫩小泬白浆20p主播| 新97超碰在线观看| 爆乳骚货内射骚货内射在线 | 国产亚州色婷婷久久99精品| 美女少妇亚洲精选av| 亚洲中文精品字幕在线观看 | 国产在线观看免费人成短视频| 国产片免费观看在线观看| 91av精品视频在线| 春色激情网欧美成人| 天天干天天爱天天色| 亚洲最大黄 嗯色 操 啊| 国产精品福利小视频a| 国产欧美精品一区二区高清 | 91桃色成人网络在线观看| 大陆精品一区二区三区久久| 免费福利av在线一区二区三区| 中文字幕视频一区二区在线观看 | 93视频一区二区三区| 欧美成人综合视频一区二区| 久久国产精品精品美女| 国产亚洲欧美另类在线观看| 国产精品视频一区在线播放| 黄色黄色黄片78在线| 综合一区二区三区蜜臀| 5528327男人天堂| 日韩午夜福利精品试看| 国产亚洲精品视频合集| 99精品国自产在线人| 久久久久久久精品成人热| 国产又粗又硬又大视频| 在线观看免费视频色97| 日本午夜福利免费视频| 国产a级毛久久久久精品| 性欧美日本大妈母与子| 真实国产乱子伦一区二区| 自拍偷区二区三区麻豆| 日本性感美女视频网站| 一区二区三区欧美日韩高清播放| 久久麻豆亚洲精品av| 99精品亚洲av无码国产另类| 亚洲av在线观看尤物| 天天日天天爽天天干| 熟女俱乐部一二三区| 3D动漫精品啪啪一区二区下载| 中国黄片视频一区91| 日本在线不卡免费视频| 亚洲一区自拍高清免费视频| 在线视频免费观看网| 欧美亚洲少妇福利视频| 国产精彩对白一区二区三区| 少妇人妻真实精品视频| 自拍 日韩 欧美激情| aⅴ精产国品一二三产品| 91极品大一女神正在播放| 日曰摸日日碰夜夜爽歪歪| 日日摸夜夜添夜夜添毛片性色av| 成人动漫大肉棒插进去视频| 国产精品3p和黑人大战| 天天躁夜夜躁日日躁a麻豆| 亚洲精品国产久久久久久| 亚洲精品国产久久久久久| av乱码一区二区三区| 99久久中文字幕一本人| 欧美黑人巨大性xxxxx猛交| 久久久久国产成人精品亚洲午夜| 女同互舔一区二区三区| 人人妻人人澡人人爽人人dvl| 欧美一区二区三区高清不卡tv | 久草免费人妻视频在线| 337p日本大胆欧美人| 夜色福利视频在线观看| 国产精品成人xxxx| 亚洲第一黄色在线观看| 亚洲欧美自拍另类图片| 天天做天天干天天舔| 亚洲中文字幕国产日韩| 福利视频一区二区三区筱慧| 国产黑丝高跟鞋视频在线播放| 午夜精品福利一区二区三区p | 久久久久久久99精品| 国产美女一区在线观看| 一区二区三区国产精选在线播放| 色狠狠av线不卡香蕉一区二区| 99热这里只有国产精品6| 偷拍自拍视频图片免费| 免费男阳茎伸入女阳道视频| 美味人妻2在线播放| 亚洲国产成人无码麻豆艾秋| 国产视频精品资源网站| av天堂资源最新版在线看| 青青青国产免费视频| ka0ri在线视频| 日本熟妇喷水xxx| 18禁污污污app下载| 喷水视频在线观看这里只有精品| 美女被肏内射视频网站| 99精品免费久久久久久久久a| 中文字幕国产专区欧美激情| 日日操综合成人av| 九色porny九色9l自拍视频| 成人免费毛片aaaa| 人妻少妇亚洲一区二区| 亚洲av琪琪男人的天堂| 麻豆性色视频在线观看| 白嫩白嫩美女极品国产在线观看| 天天日天天日天天射天天干| 久久久久久9999久久久久| 都市家庭人妻激情自拍视频| 91免费黄片可看视频| 九色精品视频在线播放| 国产片免费观看在线观看| 91桃色成人网络在线观看| 欲满人妻中文字幕在线| 亚洲av色图18p| 激情伦理欧美日韩中文字幕| 中国老熟女偷拍第一页| 国产不卡av在线免费| 日韩欧美亚洲熟女人妻| 成人免费公开视频无毒| 蜜臀av久久久久久久| 亚洲天天干 夜夜操| 欧美综合婷婷欧美综合| 色偷偷伊人大杳蕉综合网 | 嫩草aⅴ一区二区三区| 18禁美女羞羞免费网站| 国产精品sm调教视频| 久久久久国产成人精品亚洲午夜| 精品人妻一二三区久久| 黑人变态深video特大巨大| 亚洲国产40页第21页| 国产精品自拍视频大全| 日本在线一区二区不卡视频| 精品亚洲在线免费观看| 成人30分钟免费视频| 天天操天天操天天碰| 欧美一区二区三区四区性视频| 亚洲福利精品福利精品福利| 99国内精品永久免费视频| 欧美另类一区二区视频| 色伦色伦777国产精品| 亚洲无码一区在线影院| 天天日夜夜操天天摸| 天天射夜夜操狠狠干| 超碰97人人澡人人| 中字幕人妻熟女人妻a62v网| 天天操天天干天天插| 亚洲精品高清自拍av| 传媒在线播放国产精品一区| 天天日天天日天天擦| 成人高潮aa毛片免费| 班长撕开乳罩揉我胸好爽| 精品久久久久久久久久中文蒉| 欧美一区二区三区激情啪啪啪| 天天日天天日天天射天天干| 粉嫩av蜜乳av蜜臀| 午夜久久香蕉电影网| 日本啪啪啪啪啪啪啪| 视频一区二区在线免费播放| sspd152中文字幕在线| 任我爽精品视频在线播放| 色狠狠av线不卡香蕉一区二区| 亚洲av琪琪男人的天堂| 日本精品美女在线观看| 制丝袜业一区二区三区| 国产一区二区欧美三区| 天天日天天干天天干天天日| 亚洲男人的天堂a在线| 美女被肏内射视频网站| 国产精品久久久久久久女人18| 日本一区二区三区免费小视频| 巨乳人妻日下部加奈被邻居中出| 老司机免费视频网站在线看| 亚洲无码一区在线影院| 天天通天天透天天插| 亚洲 欧美 自拍 偷拍 在线| 中文字幕一区二区三区人妻大片| 91大屁股国产一区二区| 亚洲欧美久久久久久久久| 97超碰人人搞人人| 国产一区av澳门在线观看| 免费人成黄页网站在线观看国产| 日韩视频一区二区免费观看| 大香蕉玖玖一区2区| 亚洲成a人片777777| 福利视频网久久91| 国产黑丝高跟鞋视频在线播放| 亚洲精品 日韩电影| 成人免费做爰高潮视频| 91福利视频免费在线观看| 姐姐的朋友2在线观看中文字幕| 非洲黑人一级特黄片| 五十路熟女人妻一区二| 久草视频福利在线首页| 五十路熟女人妻一区二区9933| 国产使劲操在线播放| 亚洲人成精品久久久久久久| 国产精品久久9999| 青青青青青青青在线播放视频| 99久久99一区二区三区| 天天躁日日躁狠狠躁av麻豆| 国产精品久久久久网| 成人av中文字幕一区| 亚洲国产在线精品国偷产拍| 黑人变态深video特大巨大| huangse网站在线观看| 日韩美av高清在线| 中文字幕乱码人妻电影| 男人的天堂av日韩亚洲| 蜜桃精品久久久一区二区| 97青青青手机在线视频| 91破解版永久免费| 国产又大又黄免费观看| 五十路熟女人妻一区二| 国产片免费观看在线观看| 超鹏97历史在线观看| 国产三级片久久久久久久| 国产一区av澳门在线观看| 欧美一区二区三区在线资源| 日本男女操逼视频免费看| 人妻丰满熟妇综合网| 大香蕉大香蕉在线有码 av| av在线观看网址av| 超污视频在线观看污污污| 成人H精品动漫在线无码播放| 在线观看视频 你懂的| 精品91自产拍在线观看一区| 亚洲av自拍天堂网| 成人综合亚洲欧美一区| 国产中文字幕四区在线观看| 亚洲 中文字幕在线 日韩| 久久久超爽一二三av| av老司机精品在线观看| 1024久久国产精品| 中文字幕在线欧美精品| 91色网站免费在线观看| 亚洲无线观看国产高清在线| 亚洲成人免费看电影| 国产在线观看黄色视频| 极品丝袜一区二区三区| 91桃色成人网络在线观看| 欧美一区二区三区四区性视频| 制服丝袜在线人妻中文字幕| 免费69视频在线看| 51国产偷自视频在线播放| 亚洲免费福利一区二区三区| 国产一级麻豆精品免费| 97欧洲一区二区精品免费| 538精品在线观看视频| av手机在线观播放网站| 亚洲精品福利网站图片| 欧美va不卡视频在线观看| 五十路熟女人妻一区二| 日韩av有码中文字幕| 不卡精品视频在线观看| 久久丁香花五月天色婷婷| 国产精品人久久久久久| 人妻无码中文字幕专区| aⅴ精产国品一二三产品| 亚洲精品亚洲人成在线导航| 在线视频国产欧美日韩| 2021最新热播中文字幕| 首之国产AV医生和护士小芳| 91麻豆精品91久久久久同性| 亚洲高清国产一区二区三区| 亚洲精品 日韩电影| 国产综合视频在线看片| 久久久极品久久蜜桃| av天堂中文免费在线| 熟女妇女老妇一二三区| 激情五月婷婷综合色啪| 国产精品欧美日韩区二区 | 搡老熟女一区二区在线观看| 99热久久这里只有精品8| 青青青青视频在线播放| 亚洲国产成人最新资源| 日本女大学生的黄色小视频| 国产卡一卡二卡三乱码手机| 国产精品久久久久久久精品视频 | 久草免费人妻视频在线| 成人性黑人一级av| 久久精品国产亚洲精品166m| 亚洲精品乱码久久久久久密桃明| 色婷婷久久久久swag精品| 国产精品国色综合久久 | 国产精品成人xxxx| 中国黄色av一级片| 免费男阳茎伸入女阳道视频| 香蕉av影视在线观看| 伊人日日日草夜夜草| 欧美3p在线观看一区二区三区| 天天想要天天操天天干| 日本丰满熟妇BBXBBXHD| 色噜噜噜噜18禁止观看| 青青青青青青青在线播放视频| 日韩不卡中文在线视频网站| 国产变态另类在线观看| 国产av福利网址大全| 免费无码人妻日韩精品一区二区 | 日韩欧美在线观看不卡一区二区| 日韩一个色综合导航| 黑人变态深video特大巨大| 大香蕉伊人中文字幕| 动漫av网站18禁| 69精品视频一区二区在线观看| 欧美精品一区二区三区xxxx| 国产精彩对白一区二区三区| 五十路熟女人妻一区二| 在线观看国产免费麻豆| 免费在线观看污污视频网站| 在线观看免费av网址大全| 日韩人妻在线视频免费| 欧美亚洲国产成人免费在线 | free性日本少妇| 黄色三级网站免费下载| 91免费福利网91麻豆国产精品 | 馒头大胆亚洲一区二区| 99热99这里精品6国产| 成人24小时免费视频| 亚洲成a人片777777| 中文字幕AV在线免费看 | 好男人视频在线免费观看网站| 香蕉片在线观看av| 亚洲免费视频欧洲免费视频 | 青娱乐最新视频在线| 日本熟妇丰满厨房55| 夜夜操,天天操,狠狠操| 亚洲熟妇久久无码精品| 100%美女蜜桃视频| 999久久久久999| 亚洲乱码中文字幕在线| 人人妻人人爽人人澡人人精品| 人人妻人人人操人人人爽| 男女啪啪啪啪啪的网站| 中文字幕AV在线免费看 | 久草视频 久草视频2| 欧美精品资源在线观看| 国产一区av澳门在线观看| 在线观看国产网站资源| av在线免费中文字幕| 大香蕉大香蕉大香蕉大香蕉大香蕉| 成年人啪啪视频在线观看| 人妻久久无码中文成人| 成人乱码一区二区三区av| 欧美日本国产自视大全| 北条麻妃肉色丝袜视频| 91片黄在线观看喷潮| 亚洲av日韩高清hd| 日韩欧美制服诱惑一区在线| 晚上一个人看操B片| 护士小嫩嫩又紧又爽20p| 日本精品美女在线观看| 午夜美女福利小视频| 日本免费午夜视频网站| 成人高清在线观看视频| av老司机亚洲一区二区| 国产精品一区二区av国| 日韩影片一区二区三区不卡免费 | 亚洲av香蕉一区区二区三区犇| avjpm亚洲伊人久久| 午夜精品一区二区三区4| 亚洲午夜福利中文乱码字幕| 亚洲另类伦春色综合小| 国产亚洲精品品视频在线| 成年人该看的视频黄免费| 成人免费做爰高潮视频| 香蕉av影视在线观看| 国产伊人免费在线播放| 深夜男人福利在线观看| chinese国产盗摄一区二区 | 亚洲高清自偷揄拍自拍| asmr福利视频在线观看| 亚洲欧美福利在线观看| 777奇米久久精品一区| 韩国亚洲欧美超一级在线播放视频 | 一区二区三区日韩久久| 日韩在线视频观看有码在线| 久久热这里这里只有精品| 2017亚洲男人天堂| 黑人巨大的吊bdsm| 亚洲欧美综合另类13p| 天天通天天透天天插| 2021最新热播中文字幕| 大鸡巴插入美女黑黑的阴毛| 亚洲一级av无码一级久久精品| 国产91精品拍在线观看| 在线亚洲天堂色播av电影| 天天日天天透天天操| 青青擦在线视频国产在线| 天堂资源网av中文字幕| 国产黄色a级三级三级三级| 国产va在线观看精品| 最新国产精品网址在线观看| 手机看片福利盒子日韩在线播放| 色婷婷六月亚洲综合香蕉| 自拍偷拍一区二区三区图片| 国产麻豆91在线视频| 97国产福利小视频合集| 99热这里只有国产精品6| 欧洲亚洲欧美日韩综合| 1区2区3区4区视频在线观看| 男人和女人激情视频| 晚上一个人看操B片| 天天操天天插天天色| 后入美女人妻高清在线| 夜夜操,天天操,狠狠操| 99精品视频之69精品视频| 青青青青青操视频在线观看| 好了av中文字幕在线| 亚洲日产av一区二区在线| 精品成人午夜免费看| 丰满的继坶3中文在线观看| 免费观看成年人视频在线观看| 一区二区久久成人网| 亚洲免费视频欧洲免费视频| 国产一区成人在线观看视频| 丁香花免费在线观看中文字幕| 中国熟女一区二区性xx| 午夜极品美女福利视频| 性感美女高潮视频久久久| 天天干夜夜操啊啊啊| 日本三极片中文字幕| 亚洲图片偷拍自拍区| 成人av在线资源网站| 任我爽精品视频在线播放| 人妻丝袜av在线播放网址| 偷拍自拍亚洲美腿丝袜| 玩弄人妻熟妇性色av少妇| 在线免费观看国产精品黄色| 97超碰人人搞人人| 国产真实乱子伦a视频| 亚洲激情偷拍一区二区| 91麻豆精品91久久久久同性| brazzers欧熟精品系列| 欧美精产国品一二三产品区别大吗| www日韩a级s片av| 天天色天天舔天天射天天爽| 好吊视频—区二区三区| 天天操天天射天天操天天天| 亚洲午夜精品小视频| 青青草原色片网站在线观看| 不卡精品视频在线观看| 亚洲国产在线精品国偷产拍| 亚洲综合图片20p| 亚洲少妇人妻无码精品| 国产精品久久久久久美女校花| 中文字幕视频一区二区在线观看| 硬鸡巴动态操女人逼视频| 青青色国产视频在线| 91久久国产成人免费网站| 亚洲图库另类图片区| xxx日本hd高清| 天天色天天操天天舔| 免费成人va在线观看| 欧美viboss性丰满| 性色av一区二区三区久久久| 亚洲av日韩精品久久久| 国产V亚洲V天堂无码欠欠| 国产在线拍揄自揄视频网站| 男女啪啪啪啪啪的网站| 综合页自拍视频在线播放| 在线国产精品一区二区三区| 视频二区在线视频观看| 成人av电影免费版| 偷青青国产精品青青在线观看| 2018在线福利视频| 亚洲高清国产一区二区三区| 2021国产一区二区| 自拍偷区二区三区麻豆| 大胸性感美女羞爽操逼毛片| 欧美黄片精彩在线免费观看| 亚洲一区二区三区五区 | 亚洲 清纯 国产com| 国产精品成久久久久三级蜜臀av| 狠狠躁夜夜躁人人爽天天久天啪| 91‖亚洲‖国产熟女| 搡老熟女一区二区在线观看| 日本一区二区三区免费小视频| 国产麻豆国语对白露脸剧情| 青青草人人妻人人妻| 在线视频自拍第三页| 国产日本欧美亚洲精品视| 日本熟女50视频免费| 亚洲福利精品福利精品福利| 国产亚州色婷婷久久99精品| 免费岛国喷水视频在线观看| 9国产精品久久久久老师| 天天日天天干天天要| 91在线免费观看成人| 精品高跟鞋丝袜一区二区| 美味人妻2在线播放| 国产+亚洲+欧美+另类| 99热久久这里只有精品8| 午夜成午夜成年片在线观看| 密臀av一区在线观看| 精品久久婷婷免费视频| 在线观看视频网站麻豆| 国产三级精品三级在线不卡| 成人资源在线观看免费官网| 2o22av在线视频| 黄色大片男人操女人逼| 欧美一区二区三区乱码在线播放 | 在线观看国产网站资源| 欧美黄片精彩在线免费观看| 色花堂在线av中文字幕九九| 日本午夜福利免费视频| 偷拍自拍亚洲视频在线观看| 偷青青国产精品青青在线观看| 欧美国品一二三产区区别| 天天日天天添天天爽| jiuse91九色视频| 11久久久久久久久久久| 久久久久久久久久久免费女人| 天天色天天舔天天射天天爽 | 人妻另类专区欧美制服| 亚洲激情唯美亚洲激情图片| 熟女妇女老妇一二三区| 在线观看视频 你懂的| 精品黑人巨大在线一区| 欧洲日韩亚洲一区二区三区| 国产精品人妻66p| 一区二区三区 自拍偷拍| 欧美成人综合视频一区二区 | 久久精品亚洲成在人线a| 在线观看视频一区麻豆| 阴茎插到阴道里面的视频| 午夜精品福利一区二区三区p| 男人的天堂一区二区在线观看| 天天操天天射天天操天天天| 欧美一区二区三区激情啪啪啪 | 精品一区二区三区三区88| 天天操夜夜操天天操天天操| 国产精品一区二区av国| 亚洲蜜臀av一区二区三区九色| 日本丰满熟妇大屁股久久| 亚洲人妻30pwc| 欧美国品一二三产区区别| 做爰视频毛片下载蜜桃视频1| 第一福利视频在线观看| 中文字日产幕乱六区蜜桃| 精品国产成人亚洲午夜| 蜜桃视频在线欧美一区| 做爰视频毛片下载蜜桃视频1| 亚洲精品成人网久久久久久小说| 欧美激情精品在线观看| 免费在线看的黄片视频| 天天色天天操天天透| 99精品免费观看视频| 免费岛国喷水视频在线观看| 美女吃鸡巴操逼高潮视频| 国产亚洲视频在线观看| 国产精品伦理片一区二区| 国产91久久精品一区二区字幕| okirakuhuhu在线观看| 国产高清在线在线视频| 久久www免费人成一看片| 熟女少妇激情五十路| 国产精品自拍在线视频| 女警官打开双腿沦为性奴| 国产亚洲天堂天天一区| 免费大片在线观看视频网站| 国产精品伦理片一区二区| 日韩午夜福利精品试看| 国产综合精品久久久久蜜臀| 青青草原色片网站在线观看| 人妻无码中文字幕专区| 91在线视频在线精品3| 欧美一区二区三区啪啪同性| 18禁网站一区二区三区四区| 中国黄色av一级片| 午夜在线观看一区视频| 国产一区二区久久久裸臀| 欧美日本国产自视大全| 亚洲va国产va欧美va在线| 中文字幕人妻被公上司喝醉在线 | 人人妻人人爽人人添夜| 亚洲av色香蕉一区二区三区| 91国内精品久久久久精品一| 老司机你懂得福利视频| 午夜蜜桃一区二区三区| 极品粉嫩小泬白浆20p主播 | 姐姐的朋友2在线观看中文字幕| 久久久久久久久久性潮| 国产亚洲天堂天天一区| 一区二区三区日本伦理| 欧美日韩精品永久免费网址 | av欧美网站在线观看| 免费国产性生活视频| 蜜桃视频在线欧美一区| 人人妻人人爽人人澡人人精品| 晚上一个人看操B片| 黑人解禁人妻叶爱071| 动漫美女的小穴视频| 宅男噜噜噜666国产| 黄色成人在线中文字幕| 不卡一不卡二不卡三| 人人人妻人人澡人人| 人妻少妇亚洲一区二区| 亚洲码av无色中文| 桃色视频在线观看一区二区| 在线国产日韩欧美视频| 热久久只有这里有精品| 黑人大几巴狂插日本少妇| 国产亚洲精品欧洲在线观看| 国产激情av网站在线观看| 小泽玛利亚视频在线观看| 亚洲 中文字幕在线 日韩| 亚洲av可乐操首页| 乱亲女秽乱长久久久| 91大神福利视频网| 亚洲精品乱码久久久久久密桃明| 国产黄色片蝌蚪九色91| 自拍偷区二区三区麻豆| 亚洲成人线上免费视频观看| 99精品视频在线观看婷婷| 在线免费观看国产精品黄色| 免费在线黄色观看网站| 夜色福利视频在线观看| 日韩精品中文字幕播放| 美女吃鸡巴操逼高潮视频| 亚洲超碰97人人做人人爱| 一二三区在线观看视频| 成人av久久精品一区二区| 欧美精品中文字幕久久二区| 久久国产精品精品美女| 日本熟女50视频免费| 成人蜜桃美臀九一一区二区三区| 天天干天天搞天天摸| 人妻av无码专区久久绿巨人 | 黑人解禁人妻叶爱071| 青青草亚洲国产精品视频| 色秀欧美视频第一页| 美女福利写真在线观看视频| 中文字幕人妻一区二区视频| 男人的天堂在线黄色| 沈阳熟妇28厘米大战黑人| 97国产精品97久久| 懂色av之国产精品| 色婷婷久久久久swag精品| 亚洲综合一区成人在线| 大鸡巴操b视频在线| 九色porny九色9l自拍视频| 国产97视频在线精品| 天天通天天透天天插| 亚洲公开视频在线观看| 精品黑人一区二区三区久久国产| 欧美亚洲少妇福利视频| 亚洲精品 日韩电影| 蜜桃精品久久久一区二区| 五色婷婷综合狠狠爱| 国产麻豆剧果冻传媒app| 天天射夜夜操狠狠干| 欧美男同性恋69视频| 视频 国产 精品 熟女 | 91在线免费观看成人| 人妻激情图片视频小说| 日日夜夜大香蕉伊人| 日韩a级精品一区二区| 91国内视频在线观看| 天堂中文字幕翔田av| 亚洲中文字幕人妻一区| 成人激情文学网人妻| 国产在线观看黄色视频| 亚洲成人激情视频免费观看了| 国产成人小视频在线观看无遮挡| 38av一区二区三区| 蜜臀av久久久久蜜臀av麻豆| 男人靠女人的逼视频| 欧美va亚洲va天堂va| 欧美熟妇一区二区三区仙踪林| 一级黄色片夫妻性生活| 2020久久躁狠狠躁夜夜躁| 3D动漫精品啪啪一区二区下载| 在线制服丝袜中文字幕| 成人24小时免费视频| 动漫黑丝美女的鸡巴| 天天色天天操天天舔| 区一区二区三国产中文字幕| 日本精品一区二区三区在线视频。| 一区二区三区四区中文| 国产在线自在拍91国语自产精品| 78色精品一区二区三区| 日本高清撒尿pissing| 亚洲特黄aaaa片| 国产成人精品久久二区91| 一区二区三区综合视频| 福利一二三在线视频观看| 在线视频免费观看网| 午夜久久久久久久精品熟女| 日曰摸日日碰夜夜爽歪歪| 天天干天天搞天天摸| 美味人妻2在线播放| 蜜臀av久久久久久久| 青青青视频自偷自拍38碰| 农村胖女人操逼视频| 日本人妻精品久久久久久| 美女 午夜 在线视频| av日韩在线观看大全| 自拍偷区二区三区麻豆| 日本熟妇一区二区x x| 亚洲免费成人a v| 天天日天天添天天爽| 老师啊太大了啊啊啊尻视频| 夫妻在线观看视频91| 又粗又硬又猛又黄免费30| 免费观看国产综合视频| 国产精品人妻一区二区三区网站| 在线观看黄色成年人网站| 大尺度激情四射网站| 日韩a级精品一区二区| 啊啊好大好爽啊啊操我啊啊视频 | 99精品国产免费久久| 亚洲国产最大av综合| 夜夜嗨av一区二区三区中文字幕| 欧美视频综合第一页| www天堂在线久久| 99久久99一区二区三区| 欧美偷拍亚洲一区二区| 无码精品一区二区三区人| 亚洲欧洲av天堂综合| 国产麻豆国语对白露脸剧情| 91亚洲手机在线视频播放| 欧美aa一级一区三区四区 | 综合国产成人在线观看| 午夜91一区二区三区| 黑人性生活视频免费看| 成人免费毛片aaaa| 一区二区三区另类在线| 人妻丝袜精品中文字幕| 欧美另类一区二区视频| 亚洲一区二区三区av网站| 一区二区三区av高清免费| 黑人性生活视频免费看| 中文字幕在线观看极品视频| 午夜久久香蕉电影网| 亚洲国产欧美一区二区丝袜黑人| 美女张开两腿让男人桶av| 亚洲1卡2卡三卡4卡在线观看| 日韩精品一区二区三区在线播放| 亚洲男人让女人爽的视频| 欧美女同性恋免费a| 污污小视频91在线观看| 99国内精品永久免费视频| 搡老妇人老女人老熟女| 国产成人精品亚洲男人的天堂| 又粗又硬又猛又黄免费30| 日韩欧美中文国产在线| 淫秽激情视频免费观看| 久久久超爽一二三av| 伊人开心婷婷国产av| 啊啊啊想要被插进去视频| 亚洲精品在线资源站| 成人高清在线观看视频| 经典国语激情内射视频| 大香蕉福利在线观看| 鸡巴操逼一级黄色气| 成人福利视频免费在线| 中文字幕AV在线免费看 | 久草视频在线一区二区三区资源站| 天天综合天天综合天天网| 欧美一区二区三区高清不卡tv | 精品亚洲在线免费观看| 国产美女一区在线观看| 免费av岛国天堂网站| 国产极品精品免费视频 | 熟女俱乐部一二三区| 中文 成人 在线 视频| 国产黑丝高跟鞋视频在线播放| 91天堂天天日天天操| 毛片av在线免费看| 在线观看日韩激情视频| 在线观看黄色成年人网站| 天天操天天污天天射| 日本少妇人妻xxxxxhd| 日本人竟这样玩学生妹| 78色精品一区二区三区| 天美传媒mv视频在线观看| 国产乱子伦一二三区| 专门看国产熟妇的网站| 国产精品视频资源在线播放| 青青青激情在线观看视频| 国产日本精品久久久久久久 | 这里只有精品双飞在线播放| 亚洲少妇人妻无码精品| 亚洲一区二区三区偷拍女厕91| 国产精品成久久久久三级蜜臀av | 自拍偷拍vs一区二区三区| 任你操视频免费在线观看| 国产亚洲精品视频合集| 少妇人妻100系列| 绝色少妇高潮3在线观看| 欧美日本aⅴ免费视频| 中文字幕,亚洲人妻| 好了av中文字幕在线| 天堂va蜜桃一区入口| 日本三极片中文字幕| 在线不卡成人黄色精品| 亚洲成人国产综合一区| 一二三中文乱码亚洲乱码one| 美味人妻2在线播放| av网站色偷偷婷婷网男人的天堂| 精品美女久久久久久| 国产密臀av一区二区三| 亚洲精品ww久久久久久| 亚洲av无码成人精品区辽| 亚洲福利精品福利精品福利| 国产在线拍揄自揄视频网站| 中文字幕—97超碰网| 天天艹天天干天天操| 婷婷午夜国产精品久久久| 免费观看国产综合视频| 亚洲自拍偷拍精品网| 岛国免费大片在线观看| 韩国黄色一级二级三级| 久久久久久久久久久免费女人| 日本少妇在线视频大香蕉在线观看| 中文字幕一区二区人妻电影冢本 | 日本高清在线不卡一区二区 | 熟女在线视频一区二区三区| 亚洲美女高潮喷浆视频| 偷拍美女一区二区三区| 69精品视频一区二区在线观看| 亚洲综合乱码一区二区| 亚洲精品ww久久久久久| 免费福利av在线一区二区三区| 99国内小视频在现欢看| av成人在线观看一区| 亚洲中文字幕国产日韩| 青青在线视频性感少妇和隔壁黑丝| 99久久久无码国产精品性出奶水| 综合精品久久久久97| 中文字幕亚洲久久久| 99精品一区二区三区的区| 一区二区三区四区视频| 无码日韩人妻精品久久| 丝袜肉丝一区二区三区四区在线| 一区二区麻豆传媒黄片| 女生自摸在线观看一区二区三区| 人妻熟女中文字幕aⅴ在线| 成人激情文学网人妻| 久久久久久cao我的性感人妻 | 在线免费观看日本伦理| 开心 色 六月 婷婷| 777奇米久久精品一区| 日本www中文字幕| 中国无遮挡白丝袜二区精品| 精品欧美一区二区vr在线观看| 91久久综合男人天堂| 午夜极品美女福利视频| 国产日韩精品电影7777| 欧美精品欧美极品欧美视频 | 国产精品国产三级麻豆| 一区二区三区 自拍偷拍| 999热精品视频在线| 中文字幕,亚洲人妻| 黑人大几巴狂插日本少妇| 久久久精品999精品日本| 久久久久久久久久久久久97| 国产精品亚洲在线观看| 偷拍美女一区二区三区| 一区二区免费高清黄色视频| 人妻无码中文字幕专区| 国产一区成人在线观看视频| 欧美精产国品一二三产品价格 | 中文字幕免费在线免费| 国产成人精品福利短视频| 狠狠鲁狠狠操天天晚上干干| 国产刺激激情美女网站| 蜜桃色婷婷久久久福利在线| 人妻少妇性色欲欧美日韩| 大香蕉福利在线观看| 色天天天天射天天舔| 久久亚洲天堂中文对白| 天天干夜夜操啊啊啊| 中文字幕—97超碰网| 加勒比视频在线免费观看| 水蜜桃国产一区二区三区| 国产精品视频男人的天堂| 国产日韩av一区二区在线| 天天干天天操天天爽天天摸| 欧美另类z0z变态| 大香蕉玖玖一区2区| 91免费观看在线网站| 国产极品精品免费视频| 免费看国产av网站| 激情色图一区二区三区| 国产亚洲精品品视频在线| 国产成人综合一区2区| 国产真实乱子伦a视频| 中英文字幕av一区| 97香蕉碰碰人妻国产樱花| 欧美老鸡巴日小嫩逼| 黑人巨大精品欧美视频| 最近中文字幕国产在线| 久久久制服丝袜中文字幕| 动漫黑丝美女的鸡巴| 人妻熟女中文字幕aⅴ在线| AV天堂一区二区免费试看| 中文字幕1卡1区2区3区| 亚洲欧美成人综合视频| 亚洲av可乐操首页| 免费岛国喷水视频在线观看 | 国产亚洲视频在线二区| 亚洲熟妇无码一区二区三区| 免费黄页网站4188| 中文字幕AV在线免费看 | 偷拍自拍国产在线视频| 绝顶痉挛大潮喷高潮无码 | 欧美精品欧美极品欧美视频| 国产chinesehd精品麻豆| 久久精品久久精品亚洲人| 精品久久久久久久久久久久人妻| 最近中文2019年在线看| 欧美美女人体视频一区| 一区二区三区久久中文字幕| 社区自拍揄拍尻屁你懂的| 日韩av大胆在线观看| 夜色撩人久久7777| 老有所依在线观看完整版 | 91精品视频在线观看免费| 中文字幕之无码色多多| 中文字幕国产专区欧美激情| 中文字幕之无码色多多| 一区二区三区蜜臀在线| 非洲黑人一级特黄片| free性日本少妇| 5528327男人天堂| 青青草视频手机免费在线观看| 免费69视频在线看| 精品美女久久久久久| av线天堂在线观看| 日本熟妇喷水xxx| 97国产福利小视频合集| 天天操天天爽天天干| 自拍 日韩 欧美激情| 香蕉av影视在线观看| 久久久久久九九99精品| 成人av亚洲一区二区| 天天日夜夜干天天操| 红杏久久av人妻一区| 免费岛国喷水视频在线观看| 2018最新中文字幕在线观看| 蜜桃精品久久久一区二区| 亚洲欧美一卡二卡三卡| 免费岛国喷水视频在线观看 | 黄片大全在线观看观看| 日韩欧美国产一区不卡| 极品粉嫩小泬白浆20p主播| 亚洲免费va在线播放| 午夜激情高清在线观看| 粉嫩av蜜乳av蜜臀| 国语对白xxxx乱大交| 玖玖一区二区在线观看| 99一区二区在线观看| 成人av在线资源网站| 男人插女人视频网站| 日韩av大胆在线观看| 亚洲av日韩高清hd| 人妻素人精油按摩中出| 超碰公开大香蕉97| 伊人日日日草夜夜草| 乱亲女秽乱长久久久| 国产美女一区在线观看| 性欧美激情久久久久久久| 中文字幕在线视频一区二区三区| 欧美性受xx黑人性猛交| 午夜精品一区二区三区城中村| 精品日产卡一卡二卡国色天香| 黑人乱偷人妻中文字幕| 硬鸡巴动态操女人逼视频| 国产中文精品在线观看| 性色蜜臀av一区二区三区| 日本阿v视频在线免费观看| 日韩av有码中文字幕| 日本少妇的秘密免费视频| 日比视频老公慢点好舒服啊| 亚洲国产精品久久久久久6| 在线视频免费观看网| 97瑟瑟超碰在线香蕉| 久久久久久97三级| 97人人妻人人澡人人爽人人精品| 国产福利小视频免费观看| huangse网站在线观看| 2018在线福利视频| 青青青aaaa免费| 日本人妻少妇18—xx| 一区二区三区 自拍偷拍| 日韩成人性色生活片| 国产高清精品极品美女| 色伦色伦777国产精品| 区一区二区三国产中文字幕| 强行扒开双腿猛烈进入免费版| 精品高跟鞋丝袜一区二区| 国产自拍在线观看成人| 亚洲护士一区二区三区| 成人动漫大肉棒插进去视频| 男女之间激情网午夜在线| 国产日韩精品免费在线| jiuse91九色视频| 91p0rny九色露脸熟女| 天天射夜夜操狠狠干| 一区二区三区蜜臀在线| 久久久久久97三级| 亚洲免费国产在线日韩| 伊人网中文字幕在线视频| 天天干天天搞天天摸| 18禁无翼鸟成人在线| 激情图片日韩欧美人妻| 日韩少妇人妻精品无码专区| 免费一级黄色av网站| 亚洲青青操骚货在线视频| 姐姐的朋友2在线观看中文字幕| 99久久久无码国产精品性出奶水| 免费成人av中文字幕| 韩国亚洲欧美超一级在线播放视频| 国产实拍勾搭女技师av在线| 在线观看免费岛国av| 成人av亚洲一区二区| 国产女人被做到高潮免费视频| 亚洲午夜精品小视频| 日本性感美女视频网站| 久久精品久久精品亚洲人| 18禁网站一区二区三区四区| 欧美成人猛片aaaaaaa| 日本性感美女视频网站| 国产日本欧美亚洲精品视| 粉嫩小穴流水视频在线观看| 欧美精品欧美极品欧美视频| 欧美视频中文一区二区三区| 快点插进来操我逼啊视频| 91免费放福利在线观看| 51国产成人精品视频| 国产一级麻豆精品免费| 亚洲av色图18p| 亚洲午夜在线视频福利| 国产麻豆乱子伦午夜视频观看| av中文字幕福利网| 538精品在线观看视频| 精品视频国产在线观看| 欧美另类一区二区视频| 自拍偷拍亚洲另类色图| 久久久久久性虐视频| 丝袜肉丝一区二区三区四区在线| 超级福利视频在线观看| 欧美精产国品一二三区| 91色九色porny| 又粗又硬又猛又爽又黄的| 动漫精品视频在线观看| 国产1区,2区,3区| 521精品视频在线观看| 国产丰满熟女成人视频| 自拍 日韩 欧美激情| 亚洲人妻av毛片在线| 国产不卡av在线免费| 非洲黑人一级特黄片| 超碰在线中文字幕一区二区| nagger可以指黑人吗| 在线视频自拍第三页| 97青青青手机在线视频 | 69精品视频一区二区在线观看| 久久h视频在线观看| 亚洲Av无码国产综合色区| 社区自拍揄拍尻屁你懂的| 国产麻豆国语对白露脸剧情| 精品老妇女久久9g国产| 2021年国产精品自拍| 老司机99精品视频在线观看| 人妻最新视频在线免费观看| 日韩欧美国产精品91| 少妇系列一区二区三区视频| 精品国产亚洲av一淫| 快点插进来操我逼啊视频| 一级a看免费观看网站| 91在线视频在线精品3| 国产精品中文av在线播放 | 色婷婷六月亚洲综合香蕉| 亚洲一区二区人妻av| 自拍偷拍,中文字幕| 99re久久这里都是精品视频| 亚洲伊人av天堂有码在线| 偷青青国产精品青青在线观看| 亚洲激情唯美亚洲激情图片| 99热99这里精品6国产| 亚洲免费va在线播放| 日韩中文字幕精品淫| 女蜜桃臀紧身瑜伽裤| 亚洲欧美激情国产综合久久久| 成人性黑人一级av| 伊人日日日草夜夜草| 狠狠地躁夜夜躁日日躁| 福利视频广场一区二区| 青青草精品在线视频观看| 精品人人人妻人人玩日产欧| 午夜激情久久不卡一区二区| 福利视频一区二区三区筱慧| 国产成人自拍视频播放| 成人av在线资源网站| 国产乱子伦一二三区| 亚洲国产最大av综合| 亚洲欧美在线视频第一页| 欧美综合婷婷欧美综合| xxx日本hd高清| aⅴ五十路av熟女中出| 在线亚洲天堂色播av电影| 亚洲一区二区三区uij| 青青色国产视频在线| 亚洲av琪琪男人的天堂| 噜噜色噜噜噜久色超碰| 视频一区二区三区高清在线| 欧美专区第八页一区在线播放| 中文字幕在线欧美精品| 中文字幕午夜免费福利视频| 一区二区三区日本伦理| 一本久久精品一区二区| 亚洲美女自偷自拍11页| 亚洲成人国产综合一区| 欧美交性又色又爽又黄麻豆| 国产精品污污污久久| 18禁污污污app下载| 精品国产成人亚洲午夜| 五月天色婷婷在线观看视频免费| 中文字幕亚洲中文字幕| 精品美女在线观看视频在线观看| 国产精品中文av在线播放| 第一福利视频在线观看| 美洲精品一二三产区区别| 在线免费观看日本伦理| 日韩av大胆在线观看| 又大又湿又爽又紧A视频| 在线视频国产欧美日韩| 久久三久久三久久三久久| 国产午夜亚洲精品麻豆| 国产精品视频男人的天堂| 亚洲免费视频欧洲免费视频| 久草视频在线免播放| 日韩精品电影亚洲一区| 被大鸡吧操的好舒服视频免费| 日本精品视频不卡一二三| 一区二区视频在线观看视频在线| 天天操天天爽天天干| 狍和女人的王色毛片| 2020国产在线不卡视频| 超碰97免费人妻麻豆| 日韩美女福利视频网| 天天操天天干天天插| 欧美一区二区三区高清不卡tv| 久久久久久久久久久免费女人| 亚洲推理片免费看网站| 在线免费91激情四射| 午夜福利人人妻人人澡人人爽| 欧美黑人性暴力猛交喷水| 男人的天堂av日韩亚洲| 深田咏美亚洲一区二区| 久久久久久久久久久久久97| 在线国产日韩欧美视频| 亚洲久久午夜av一区二区| 1024久久国产精品| 无码中文字幕波多野不卡| 丰满少妇人妻xxxxx| 国产性生活中老年人视频网站| 亚洲天堂av最新网址| 大胆亚洲av日韩av| 日韩av有码一区二区三区4| 天天操夜夜骑日日摸| 亚洲2021av天堂| 久草视频中文字幕在线观看| 天天摸天天日天天操| 91色网站免费在线观看| www日韩a级s片av| 操日韩美女视频在线免费看 | 2o22av在线视频| 久久久久国产成人精品亚洲午夜| 岛国一区二区三区视频在线| 激情图片日韩欧美人妻| 超级碰碰在线视频免费观看| 91精品国产91久久自产久强 | 国产日韩欧美美利坚蜜臀懂色| 欧美亚洲偷拍自拍色图| 国产麻豆剧传媒精品国产av蜜桃| 国产熟妇乱妇熟色T区| 91九色porny国产在线| 日本黄在免费看视频| 国产一区二区在线欧美| 含骚鸡巴玩逼逼视频| 中文字幕乱码av资源| 传媒在线播放国产精品一区| 伊人成人在线综合网| aⅴ五十路av熟女中出| 日日操综合成人av| 欧美怡红院视频在线观看| 熟女人妻三十路四十路人妻斩| 黄色av网站免费在线| 日韩美av高清在线| 天堂av在线播放免费| 日本黄在免费看视频| 沈阳熟妇28厘米大战黑人| 东游记中文字幕版哪里可以看到| 久久亚洲天堂中文对白| aⅴ五十路av熟女中出| 国产精品国产三级国产精东| 青青草人人妻人人妻| 偷拍自拍视频图片免费| 中文字幕无码日韩专区免费| 只有精品亚洲视频在线观看| 日本人妻欲求不满中文字幕| 伊人开心婷婷国产av| 99热99这里精品6国产| 激情综合治理六月婷婷| 91国内视频在线观看| 中文字幕网站你懂的| 亚洲国产欧美国产综合在线| 97精品人妻一区二区三区精品| 国产欧美精品一区二区高清| 日本真人性生活视频免费看| 亚洲国产成人最新资源| 精品成人午夜免费看| 天天草天天色天天干| 自拍偷拍,中文字幕| 无码日韩人妻精品久久| 97色视频在线观看| 日本一道二三区视频久久| 白嫩白嫩美女极品国产在线观看| 黄色资源视频网站日韩| 成年人的在线免费视频| 亚洲精品国产在线电影| 日韩av大胆在线观看| 国产在线免费观看成人| 熟女人妻在线观看视频| 欧美偷拍亚洲一区二区| 男生用鸡操女生视频动漫| 国产女孩喷水在线观看| 综合色区亚洲熟妇shxstz| 社区自拍揄拍尻屁你懂的| 欧美一区二区三区激情啪啪啪| 欧美特色aaa大片| 亚洲一区制服丝袜美腿| sejizz在线视频| 午夜91一区二区三区| 91国内精品自线在拍白富美| 青草久久视频在线观看| 久久久精品精品视频视频| 日本美女成人在线视频| 2021最新热播中文字幕| 亚洲激情,偷拍视频| 国产黄色片蝌蚪九色91| 啊啊好慢点插舔我逼啊啊啊视频| 人妻丝袜精品中文字幕| 97超碰人人搞人人| 可以在线观看的av中文字幕| sspd152中文字幕在线| 999九九久久久精品| 天堂资源网av中文字幕| 日本一区二区三区免费小视频 | 欧洲欧美日韩国产在线| 久久久极品久久蜜桃| 91色秘乱一区二区三区| 一区二区熟女人妻视频| 大香蕉伊人中文字幕| 亚洲第一黄色在线观看| 91高清成人在线视频| 亚洲精品高清自拍av| 大香蕉大香蕉大香蕉大香蕉大香蕉 | 国产成人精品福利短视频| 人妻av无码专区久久绿巨人| 99久久激情婷婷综合五月天| 啊用力插好舒服视频| 成人色综合中文字幕| 伊人综合免费在线视频| 黑人巨大的吊bdsm| 亚洲人妻av毛片在线| huangse网站在线观看| 国产成人精品亚洲男人的天堂| 中文字幕视频一区二区在线观看 | 人妻凌辱欧美丰满熟妇| 任我爽精品视频在线播放| 国产高清在线在线视频| 成人高清在线观看视频| 国产在线免费观看成人| 亚洲高清自偷揄拍自拍| 任你操任你干精品在线视频| 久草视频在线免播放| 把腿张开让我插进去视频| 亚洲国产中文字幕啊啊啊不行了| 亚洲成人精品女人久久久| 亚洲精品国品乱码久久久久 | 亚洲无码一区在线影院|