婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > MySQL中的長(zhǎng)事務(wù)示例詳解

MySQL中的長(zhǎng)事務(wù)示例詳解

熱門標(biāo)簽:美國(guó)反騷擾電話機(jī)器人 悟空科技電話機(jī)器人 福建外呼系統(tǒng)定制化 騰訊地圖標(biāo)注提升 真人語(yǔ)音電話機(jī)器人 電銷卡外呼系統(tǒng)供應(yīng)商 銅陵防封電銷卡 怎么在地圖標(biāo)注位置生成圖片 400電話可以免費(fèi)申請(qǐng)嗎

前言:

『入門MySQL』系列文章已經(jīng)完結(jié),今后我的文章還是會(huì)以MySQL為主,主要記錄下近期工作及學(xué)習(xí)遇到的場(chǎng)景或者自己的感悟想法,可能后續(xù)的文章不是那么連貫,但還是希望大家多多支持。言歸正傳,本篇文章主要介紹MySQL長(zhǎng)事務(wù)相關(guān)內(nèi)容,比如說(shuō)我們開啟的一個(gè)事務(wù),一直沒(méi)提交或回滾會(huì)怎樣呢,出現(xiàn)事務(wù)等待情況應(yīng)該如何處理,本篇文章將給你答案。

注意:本篇文章并不聚焦于談?wù)撌聞?wù)隔離級(jí)別以及相關(guān)特性。而是介紹長(zhǎng)事務(wù)相關(guān)危害以及監(jiān)控處理方法。本文是基于MySQL5.7.23版本,不可重復(fù)讀(RR)隔離級(jí)別所做實(shí)驗(yàn)。

1.什么是長(zhǎng)事務(wù)

首先我們先要知道什么是長(zhǎng)事務(wù),顧名思義就是運(yùn)行時(shí)間比較長(zhǎng),長(zhǎng)時(shí)間未提交的事務(wù),也可以稱之為大事務(wù)。這類事務(wù)往往會(huì)造成大量的阻塞和鎖超時(shí),容易造成主從延遲,要盡量避免使用長(zhǎng)事務(wù)。

下面我將演示下如何開啟事務(wù)及模擬長(zhǎng)事務(wù):

#假設(shè)我們有一張stu_tb表,結(jié)構(gòu)及數(shù)據(jù)如下
mysql> show create table stu_tb\G
*************************** 1. row ***************************
  Table: stu_tb
Create Table: CREATE TABLE `stu_tb` (
 `increment_id` int(11) NOT NULL AUTO_INCREMENT COMMENT '自增主鍵',
 `stu_id` int(11) NOT NULL COMMENT '學(xué)號(hào)',
 `stu_name` varchar(20) DEFAULT NULL COMMENT '學(xué)生姓名',
 `create_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '創(chuàng)建時(shí)間',
 `update_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '修改時(shí)間',
 PRIMARY KEY (`increment_id`),
 UNIQUE KEY `uk_stu_id` (`stu_id`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=9 DEFAULT CHARSET=utf8 COMMENT='測(cè)試學(xué)生表'
1 row in set (0.01 sec)

mysql> select * from stu_tb;
+--------------+--------+----------+---------------------+---------------------+
| increment_id | stu_id | stu_name | create_time   | update_time   |
+--------------+--------+----------+---------------------+---------------------+
|   1 | 1001 | from1 | 2019-09-15 14:27:34 | 2019-09-15 14:27:34 |
|   2 | 1002 | dfsfd | 2019-09-15 14:27:34 | 2019-09-15 14:27:34 |
|   3 | 1003 | fdgfg | 2019-09-15 14:27:34 | 2019-09-15 14:27:34 |
|   4 | 1004 | sdfsdf | 2019-09-15 14:27:34 | 2019-09-15 14:27:34 |
|   5 | 1005 | dsfsdg | 2019-09-15 14:27:34 | 2019-09-15 14:27:34 |
|   6 | 1006 | fgd  | 2019-09-15 14:27:34 | 2019-09-15 14:27:34 |
|   7 | 1007 | fgds  | 2019-09-15 14:27:34 | 2019-09-15 14:27:34 |
|   8 | 1008 | dgfsa | 2019-09-15 14:27:34 | 2019-09-15 14:27:34 |
+--------------+--------+----------+---------------------+---------------------+
8 rows in set (0.00 sec)

#顯式開啟事務(wù),可用begin或start transaction
mysql> start transaction;
Query OK, 0 rows affected (0.00 sec)

mysql> select * from stu_tb where stu_id = 1006 for update;
+--------------+--------+----------+---------------------+---------------------+
| increment_id | stu_id | stu_name | create_time   | update_time   |
+--------------+--------+----------+---------------------+---------------------+
|   6 | 1006 | fgd  | 2019-09-15 14:27:34 | 2019-09-15 14:27:34 |
+--------------+--------+----------+---------------------+---------------------+
1 row in set (0.01 sec)

#如果我們不及時(shí)提交上個(gè)事務(wù),那么這個(gè)事務(wù)就變成了長(zhǎng)事務(wù),當(dāng)其他會(huì)話要操作這條數(shù)據(jù)時(shí),就會(huì)一直等待。

2.如何找到長(zhǎng)事務(wù)

遇到事務(wù)等待問(wèn)題時(shí),我們首先要做的是找到正在執(zhí)行的事務(wù)。 information_schema.INNODB_TRX 表中包含了當(dāng)前innodb內(nèi)部正在運(yùn)行的事務(wù)信息,這個(gè)表中給出了事務(wù)的開始時(shí)間,我們可以稍加運(yùn)算即可得到事務(wù)的運(yùn)行時(shí)間。

mysql> select t.*,to_seconds(now())-to_seconds(t.trx_started) idle_time from INFORMATION_SCHEMA.INNODB_TRX t \G
*************************** 1. row ***************************
     trx_id: 6168
     trx_state: RUNNING
    trx_started: 2019-09-16 11:08:27
  trx_requested_lock_id: NULL
   trx_wait_started: NULL
    trx_weight: 3
  trx_mysql_thread_id: 11
     trx_query: NULL
  trx_operation_state: NULL
   trx_tables_in_use: 0
   trx_tables_locked: 1
   trx_lock_structs: 3
  trx_lock_memory_bytes: 1136
   trx_rows_locked: 2
   trx_rows_modified: 0
 trx_concurrency_tickets: 0
  trx_isolation_level: REPEATABLE READ
   trx_unique_checks: 1
 trx_foreign_key_checks: 1
trx_last_foreign_key_error: NULL
 trx_adaptive_hash_latched: 0
 trx_adaptive_hash_timeout: 0
   trx_is_read_only: 0
trx_autocommit_non_locking: 0
     idle_time: 170

在結(jié)果中idle_time是計(jì)算產(chǎn)生的,也是事務(wù)的持續(xù)時(shí)間。但事務(wù)的trx_query是NUL,這并不是說(shuō)事務(wù)什么也沒(méi)執(zhí)行,一個(gè)事務(wù)可能包含多個(gè)SQL,如果SQL執(zhí)行完畢就不再顯示了。當(dāng)前事務(wù)正在執(zhí)行,innodb也不知道這個(gè)事務(wù)后續(xù)還有沒(méi)有sql,啥時(shí)候會(huì)commit。 因此trx_query不能提供有意義的信息。

如果我們想看到這個(gè)事務(wù)執(zhí)行過(guò)的SQL,看是否可以殺掉長(zhǎng)事務(wù),怎么辦呢?我們可以聯(lián)合其他系統(tǒng)表查詢得到,具體查詢SQL如下:

mysql> select now(),(UNIX_TIMESTAMP(now()) - UNIX_TIMESTAMP(a.trx_started)) diff_sec,b.id,b.user,b.host,b.db,d.SQL_TEXT from information_schema.innodb_trx a inner join
  -> information_schema.PROCESSLIST b
  -> on a.TRX_MYSQL_THREAD_ID=b.id and b.command = 'Sleep'
  -> inner join performance_schema.threads c ON b.id = c.PROCESSLIST_ID
  -> inner join performance_schema.events_statements_current d ON d.THREAD_ID = c.THREAD_ID;
+---------------------+----------+----+------+-----------+--------+-----------------------------------------------------+
| now()        | diff_sec | id | user | host   | db   | SQL_TEXT                      |
+---------------------+----------+----+------+-----------+--------+-----------------------------------------------------+
| 2019-09-16 14:06:26 |    54 | 17 | root | localhost | testdb | select * from stu_tb where stu_id = 1006 for update |
+---------------------+----------+----+------+-----------+--------+-----------------------------------------------------+

上述結(jié)果中diff_sec和上面idle_time表示意思相同,都是代表此事務(wù)持續(xù)的秒數(shù)。SQL_TEXT表示該事務(wù)剛執(zhí)行的SQL。但是呢,上述語(yǔ)句只能查到事務(wù)最后執(zhí)行的SQL,我們知道,一個(gè)事務(wù)里可能包含多個(gè)SQL,那我們想查詢這個(gè)未提交的事務(wù)執(zhí)行過(guò)哪些SQL,是否可以滿足呢,答案是結(jié)合events_statements_history系統(tǒng)表也可以滿足需求。下面語(yǔ)句將會(huì)查詢出該事務(wù)執(zhí)行過(guò)的所有SQL:

mysql> select now(),(UNIX_TIMESTAMP(now()) - UNIX_TIMESTAMP(a.trx_started)) diff_sec,b.id,b.user,b.host,b.db,d.SQL_TEXT from information_schema.innodb_trx a inner join
  -> information_schema.PROCESSLIST b
  -> on a.TRX_MYSQL_THREAD_ID=b.id and b.command = 'Sleep'
  -> inner join performance_schema.threads c ON b.id = c.PROCESSLIST_ID
  -> inner join performance_schema.events_statements_current d ON d.THREAD_ID = c.THREAD_ID;
+---------------------+----------+----+------+-----------+--------+-----------------------------------------------------+
| now()        | diff_sec | id | user | host   | db   | SQL_TEXT                      |
+---------------------+----------+----+------+-----------+--------+-----------------------------------------------------+
| 2019-09-16 14:06:26 |    54 | 17 | root | localhost | testdb | select * from stu_tb where stu_id = 1006 for update |
+---------------------+----------+----+------+-----------+--------+-----------------------------------------------------+

從上述結(jié)果中我們可以看到該事務(wù)從一開始到現(xiàn)在執(zhí)行過(guò)的所有SQL,當(dāng)我們把該事務(wù)相關(guān)信息都查詢清楚后,我們就可以判定該事務(wù)是否可以殺掉,以免影響其他事務(wù)造成等待現(xiàn)象。

在這里稍微拓展下,長(zhǎng)事務(wù)極易造成阻塞或者死鎖現(xiàn)象,通常情況下我們可以首先查詢 sys.innodb_lock_waits 視圖確定有沒(méi)有事務(wù)阻塞現(xiàn)象:

#假設(shè)一個(gè)事務(wù)執(zhí)行 select * from stu_tb where stu_id = 1006 for update
#另外一個(gè)事務(wù)執(zhí)行 update stu_tb set stu_name = 'wang' where stu_id = 1006

mysql> select * from sys.innodb_lock_waits\G
*************************** 1. row ***************************
        wait_started: 2019-09-16 14:34:32
          wait_age: 00:00:03
        wait_age_secs: 3
        locked_table: `testdb`.`stu_tb`
        locked_index: uk_stu_id
         locked_type: RECORD
       waiting_trx_id: 6178
     waiting_trx_started: 2019-09-16 14:34:32
       waiting_trx_age: 00:00:03
   waiting_trx_rows_locked: 1
  waiting_trx_rows_modified: 0
         waiting_pid: 19
        waiting_query: update stu_tb set stu_name = 'wang' where stu_id = 1006
       waiting_lock_id: 6178:47:4:7
      waiting_lock_mode: X
       blocking_trx_id: 6177
        blocking_pid: 20
       blocking_query: NULL
      blocking_lock_id: 6177:47:4:7
     blocking_lock_mode: X
    blocking_trx_started: 2019-09-16 14:18:44
      blocking_trx_age: 00:15:51
  blocking_trx_rows_locked: 2
 blocking_trx_rows_modified: 0
   sql_kill_blocking_query: KILL QUERY 20
sql_kill_blocking_connection: KILL 20

上述結(jié)果顯示出被阻塞的SQL以及鎖的類型,更強(qiáng)大的是殺掉會(huì)話的語(yǔ)句也給出來(lái)了。但是并沒(méi)有找到阻塞會(huì)話執(zhí)行的SQL,如果我們想找出更詳細(xì)的信息,可以使用下面語(yǔ)句:

mysql> SELECT
  ->  tmp.*,
  ->  c.SQL_Text blocking_sql_text,
  ->  p.HOST blocking_host
  -> FROM
  ->  (
  ->  SELECT
  ->   r.trx_state wating_trx_state,
  ->   r.trx_id waiting_trx_id,
  ->   r.trx_mysql_thread_Id waiting_thread,
  ->   r.trx_query waiting_query,
  ->   b.trx_state blocking_trx_state,
  ->   b.trx_id blocking_trx_id,
  ->   b.trx_mysql_thread_id blocking_thread,
  ->   b.trx_query blocking_query
  ->  FROM
  ->   information_schema.innodb_lock_waits w
  ->   INNER JOIN information_schema.innodb_trx b ON b.trx_id = w.blocking_trx_id
  ->   INNER JOIN information_schema.innodb_trx r ON r.trx_id = w.requesting_trx_id
  ->  ) tmp,
  ->  information_schema.PROCESSLIST p,
  ->  PERFORMANCE_SCHEMA.events_statements_current c,
  ->  PERFORMANCE_SCHEMA.threads t
  -> WHERE
  ->  tmp.blocking_thread = p.id
  ->  AND t.thread_id = c.THREAD_ID
  ->  AND t.PROCESSLIST_ID = p.id \G
*************************** 1. row ***************************
 wating_trx_state: LOCK WAIT
  waiting_trx_id: 6180
  waiting_thread: 19
   waiting_query: update stu_tb set stu_name = 'wang' where stu_id = 1006
blocking_trx_state: RUNNING
  blocking_trx_id: 6177
  blocking_thread: 20
  blocking_query: NULL
 blocking_sql_text: select * from stu_tb where stu_id = 1006 for update
   blocking_host: localhost

上面結(jié)果顯得更加清晰,我們可以清楚的看到阻塞端及被阻塞端事務(wù)執(zhí)行的語(yǔ)句,有助于我們排查并確認(rèn)是否可以殺掉阻塞的會(huì)話。

3.監(jiān)控長(zhǎng)事務(wù)

現(xiàn)實(shí)工作中我們需要監(jiān)控下長(zhǎng)事務(wù),定義一個(gè)閾值,比如說(shuō)30s 執(zhí)行時(shí)間超過(guò)30s的事務(wù)即為長(zhǎng)事務(wù),要求記錄并告警出來(lái),提醒管理人員去處理。下面給出監(jiān)控腳本,各位可以參考下,根據(jù)需求改動(dòng)使用:

#!/bin/bash
# -------------------------------------------------------------------------------
# FileName:  long_trx.sh
# Describe:  monitor long transaction
# Revision:  1.0
# Date:    2019/09/16
# Author:   wang

/usr/local/mysql/bin/mysql -N -uroot -pxxxxxx -e "select now(),(UNIX_TIMESTAMP(now()) - UNIX_TIMESTAMP(a.trx_started)) diff_sec,b.id,b.user,b.host,b.db,d.SQL_TEXT from information_schema.innodb_trx a inner join
information_schema.PROCESSLIST b
on a.TRX_MYSQL_THREAD_ID=b.id and b.command = 'Sleep'
inner join performance_schema.threads c ON b.id = c.PROCESSLIST_ID
inner join performance_schema.events_statements_current d ON d.THREAD_ID = c.THREAD_ID;" | while read A B C D E F G H
do
 if [ "$C" -gt 30 ]
   then
   echo $(date +"%Y-%m-%d %H:%M:%S")
   echo "processid[$D] $E@$F in db[$G] hold transaction time $C SQL:$H"
 fi
done >> /tmp/longtransaction.txt

簡(jiǎn)單說(shuō)明一下,這里的-gt 30是30秒鐘的意思,只要超過(guò)了30秒鐘就認(rèn)定是長(zhǎng)事務(wù),可以根據(jù)實(shí)際需要自定義。將該腳本加入定時(shí)任務(wù)中即可執(zhí)行。

總結(jié):

本文主要介紹了長(zhǎng)事務(wù)相關(guān)內(nèi)容,怎樣找到長(zhǎng)事務(wù),怎么處理長(zhǎng)事務(wù),如何監(jiān)控長(zhǎng)事務(wù)。可能有些小伙伴對(duì)事務(wù)理解還不多,希望這篇文章對(duì)你有所幫助。由于本篇文章列出的查詢事務(wù)相關(guān)語(yǔ)句較多,現(xiàn)總結(jié)如下:

# 查詢所有正在運(yùn)行的事務(wù)及運(yùn)行時(shí)間
select t.*,to_seconds(now())-to_seconds(t.trx_started) idle_time from INFORMATION_SCHEMA.INNODB_TRX t \G

# 查詢事務(wù)詳細(xì)信息及執(zhí)行的SQL
select now(),(UNIX_TIMESTAMP(now()) - UNIX_TIMESTAMP(a.trx_started)) diff_sec,b.id,b.user,b.host,b.db,d.SQL_TEXT from information_schema.innodb_trx a inner join information_schema.PROCESSLIST b
on a.TRX_MYSQL_THREAD_ID=b.id and b.command = 'Sleep'
inner join performance_schema.threads c ON b.id = c.PROCESSLIST_ID
inner join performance_schema.events_statements_current d ON d.THREAD_ID = c.THREAD_ID;

# 查詢事務(wù)執(zhí)行過(guò)的所有歷史SQL記錄
SELECT
 ps.id 'PROCESS ID',
 ps.USER,
 ps.HOST,
 esh.EVENT_ID,
 trx.trx_started,
 esh.event_name 'EVENT NAME',
 esh.sql_text 'SQL',
 ps.time 
FROM
 PERFORMANCE_SCHEMA.events_statements_history esh
 JOIN PERFORMANCE_SCHEMA.threads th ON esh.thread_id = th.thread_id
 JOIN information_schema.PROCESSLIST ps ON ps.id = th.processlist_id
 LEFT JOIN information_schema.innodb_trx trx ON trx.trx_mysql_thread_id = ps.id 
WHERE
 trx.trx_id IS NOT NULL 
 AND ps.USER != 'SYSTEM_USER' 
ORDER BY
 esh.EVENT_ID;
 
 # 簡(jiǎn)單查詢事務(wù)鎖
 select * from sys.innodb_lock_waits\G
 
 # 查詢事務(wù)鎖詳細(xì)信息
 SELECT
 tmp.*,
 c.SQL_Text blocking_sql_text,
 p.HOST blocking_host 
FROM
 (
 SELECT
  r.trx_state wating_trx_state,
  r.trx_id waiting_trx_id,
  r.trx_mysql_thread_Id waiting_thread,
  r.trx_query waiting_query,
  b.trx_state blocking_trx_state,
  b.trx_id blocking_trx_id,
  b.trx_mysql_thread_id blocking_thread,
  b.trx_query blocking_query 
 FROM
  information_schema.innodb_lock_waits w
  INNER JOIN information_schema.innodb_trx b ON b.trx_id = w.blocking_trx_id
  INNER JOIN information_schema.innodb_trx r ON r.trx_id = w.requesting_trx_id 
 ) tmp,
 information_schema.PROCESSLIST p,
 PERFORMANCE_SCHEMA.events_statements_current c,
 PERFORMANCE_SCHEMA.threads t 
WHERE
 tmp.blocking_thread = p.id 
 AND t.thread_id = c.THREAD_ID 
 AND t.PROCESSLIST_ID = p.id \G

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。

您可能感興趣的文章:
  • 詳解 Mysql 事務(wù)和Mysql 日志
  • MySQL事務(wù)及Spring隔離級(jí)別實(shí)現(xiàn)原理詳解
  • MySQL 事務(wù)概念與用法深入詳解
  • mysql事務(wù)管理操作詳解
  • MySQL查看和修改事務(wù)隔離級(jí)別的實(shí)例講解
  • mysql的事務(wù),隔離級(jí)別和鎖用法實(shí)例分析
  • mysql實(shí)現(xiàn)事務(wù)的提交與回滾的實(shí)例詳解
  • MYSQL事務(wù)教程之Yii2.0商戶提現(xiàn)功能
  • MySQL找出未提交事務(wù)信息的方法分享
  • Mysql中事務(wù)ACID的實(shí)現(xiàn)原理詳解
  • mysql跨庫(kù)事務(wù)XA操作示例
  • 深入了解mysql長(zhǎng)事務(wù)

標(biāo)簽:聊城 云浮 湖南 武威 臨汾 烏海 湖北 白銀

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL中的長(zhǎng)事務(wù)示例詳解》,本文關(guān)鍵詞  MySQL,中的,長(zhǎng),事務(wù),示例,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL中的長(zhǎng)事務(wù)示例詳解》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于MySQL中的長(zhǎng)事務(wù)示例詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产精品18久久久久| 欧美日韩小视频| 亚洲精品一二三| 中文字幕亚洲电影| 久久一夜天堂av一区二区三区| 欧美色图激情小说| 欧美不卡一区二区三区| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 中文字幕一区二区不卡| 亚洲视频你懂的| 蜜桃av一区二区三区电影| 国产一区二区三区最好精华液| 成人爽a毛片一区二区免费| 91亚洲精华国产精华精华液| 欧美日韩免费观看一区三区| 精品毛片乱码1区2区3区| 国产欧美在线观看一区| 国产欧美一区二区精品性| 久久久久久久综合日本| 日韩高清在线电影| 亚洲成人综合视频| 日韩一区二区三免费高清| 国产一区二区伦理| 久久人人97超碰com| 国产精品一区二区无线| 国产精品欧美经典| 国产一区三区三区| 欧美日韩www| 午夜欧美一区二区三区在线播放 | 麻豆精品在线观看| 一本到三区不卡视频| 精品捆绑美女sm三区| 亚洲国产成人高清精品| 不卡视频在线看| 国产精品无遮挡| 成人丝袜高跟foot| 国产午夜亚洲精品不卡| 久久精品国产亚洲a| 91精品国产综合久久精品| 天天色天天操综合| 国产女主播视频一区二区| 亚洲一二三四在线观看| 99久久久久久| 亚洲动漫第一页| 欧美日韩国产色站一区二区三区| 国产精品免费人成网站| www.日本不卡| 亚洲男人的天堂在线观看| 99精品视频在线观看免费| 中文字幕一区二区三| 99精品视频在线观看免费| 亚洲精品日韩专区silk | 精品久久国产字幕高潮| 麻豆一区二区在线| 欧美一区二区在线免费播放| 青青草97国产精品免费观看 | 国产精品久久综合| 欧美日本在线视频| 91在线观看视频| 男男gaygay亚洲| 午夜精品一区二区三区免费视频| 久久久影视传媒| 欧美精品九九99久久| 成人理论电影网| 国产成人综合精品三级| 国产农村妇女精品| 精品福利在线导航| 日韩免费观看2025年上映的电影| 99re热这里只有精品视频| 极品美女销魂一区二区三区| 亚洲成人你懂的| 中文字幕第一区第二区| 久久午夜电影网| 久久久精品日韩欧美| 日韩一卡二卡三卡国产欧美| 日韩影院精彩在线| 91免费精品国自产拍在线不卡| 亚洲精品老司机| 国产精品嫩草99a| 韩国一区二区在线观看| 日韩精品中文字幕在线不卡尤物| 国产精品一区二区x88av| 蜜臀av一级做a爰片久久| 亚洲成人免费影院| 国产精品国产三级国产aⅴ入口| 亚洲精品日产精品乱码不卡| 中文字幕不卡在线观看| 国产精品久久精品日日| 亚洲成在人线在线播放| 亚洲精品日韩一| 日韩二区在线观看| 久久精品国产99| 久99久精品视频免费观看| 国产精品一区二区不卡| 北条麻妃一区二区三区| 99国产精品久| 日韩亚洲欧美一区二区三区| 久久综合成人精品亚洲另类欧美| 日韩伦理av电影| 婷婷六月综合网| 成人美女在线视频| 久久先锋影音av鲁色资源网| 亚洲同性gay激情无套| 日韩不卡一区二区| 一本一本久久a久久精品综合麻豆| 成人美女在线观看| 欧美精品自拍偷拍动漫精品| 国产精品色噜噜| 日本欧美韩国一区三区| 欧美在线制服丝袜| 一区二区三区中文字幕精品精品| 日韩专区在线视频| 欧美日韩国产欧美日美国产精品| 亚洲三级电影全部在线观看高清| 蜜桃在线一区二区三区| 欧美视频完全免费看| 国产精品久久毛片| 国产成人精品午夜视频免费| 欧美日韩五月天| 亚洲欧美偷拍另类a∨色屁股| 狠狠色狠狠色综合系列| 欧美日韩国产一二三| 亚洲理论在线观看| 91久久人澡人人添人人爽欧美 | 图片区小说区国产精品视频| 欧美性猛交xxxxxxxx| 午夜精品在线看| 精品伦理精品一区| av亚洲精华国产精华| 亚洲午夜av在线| 91网站在线观看视频| 悠悠色在线精品| 成人app下载| 亚洲欧美aⅴ...| 在线不卡的av| 国产精品66部| 青娱乐精品在线视频| 国产精品女同一区二区三区| 欧美色偷偷大香| 久久国产夜色精品鲁鲁99| 中文字幕在线一区二区三区| 成人激情动漫在线观看| 亚洲图片一区二区| 久久久夜色精品亚洲| 日本道精品一区二区三区| 国产永久精品大片wwwapp| 亚洲免费成人av| 中文字幕亚洲一区二区av在线 | 亚洲欧美日韩中文播放| 欧美一区二区视频在线观看2022| 韩国三级中文字幕hd久久精品| 中文av字幕一区| 日韩欧美国产一区二区三区| 成人丝袜高跟foot| 国产另类ts人妖一区二区| 亚洲午夜精品久久久久久久久| 国产精品久久影院| 日韩精品在线一区| 欧美日韩一区三区四区| 99re热视频这里只精品| 国产suv精品一区二区6| 久久久精品影视| 精品久久99ma| 9色porny自拍视频一区二区| 国产精品中文欧美| 免费高清在线一区| 婷婷亚洲久悠悠色悠在线播放| 亚洲人成在线播放网站岛国| 亚洲你懂的在线视频| 欧美国产乱子伦 | 亚洲人成7777| 亚洲美女屁股眼交| 亚洲欧美日韩综合aⅴ视频| 亚洲男人天堂一区| 亚洲成人激情自拍| 日日夜夜精品视频免费 | 亚洲在线成人精品| 亚洲精品久久久久久国产精华液| 有码一区二区三区| 免费欧美在线视频| 国产91对白在线观看九色| 99久久久久免费精品国产| 欧美综合一区二区| 精品国精品自拍自在线| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 国产精品视频观看| 五月婷婷激情综合| 美女精品自拍一二三四| 福利一区二区在线| 欧美精品1区2区3区| 国产精品久久久久久久久免费相片 | 亚洲精品福利视频网站| 日韩国产精品91| 色一情一乱一乱一91av| 欧美一区二区三区免费大片| 国产精品久久久久久久久免费桃花| 亚洲高清视频在线| 成人性色生活片免费看爆迷你毛片| 欧美丰满少妇xxxxx高潮对白| 国产精品麻豆视频|