久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

MySQL查詢緩存的小知識

瀏覽:3日期:2023-10-07 15:27:50
前言

我們知道,緩存的設計思想在RDBMS數據庫中無處不在,就拿號稱2500w行代碼,bug堆積如山的Oracle數據庫來說,SQL的執行計劃可以緩存在library cache中避免再次執行相同SQL發生硬解析(語法分析->語義分析->生成執行計劃),SQL執行結果緩存在RESULT CACHE內存組件中,有效的將物理IO轉化成邏輯IO,提高SQL執行效率。

MySQL的QueryCache跟Oracle類似,緩存的是SQL語句文本以及對應的結果集,看起來是一個很棒的Idea,那為什么從MySQL 4.0推出之后,5.6中默認禁用,5.7中被deprecated(廢棄)以及8.0版本被Removed,今天就聊聊MySQL QueryCache的前世今生。

QueryCache介紹

MySQL查詢緩(QC:QueryCache)在MySQL 4.0.1中引入,查詢緩存存儲SELECT語句的文本以及發送給客戶機的結果集,如果再次執行相同的SQL,Server端將從查詢緩存中檢索結果返回給客戶端,而不是再次解析執行SQL,查詢緩存在session之間共享,因此,一個客戶端生成的緩存結果集,可以響應另一個客戶端執行同樣的SQL。

MySQL查詢緩存的小知識

回到開頭的問題,如何判斷SQL是否共享?

通過SQL文本是否完全一致來判斷,包括大小寫,空格等所有字符完全一模一樣才可以共享,共享好處是可以避免硬解析,直接從QC獲取結果返回給客戶端,下面的兩個SQL是不共享滴,因為一個是from,另一個是From。

--SQL 1select id, balance from account where id = 121;--SQL 2select id, balance From account where id = 121;

下面是Oracle數據庫通過SQL_TEXT生成sql_id的算法,如果sql_id不一樣說明就不是同一個SQL,就不共享,就會發生硬解析。

#!/usr/bin/perl -wuse Digest::MD5 qw(md5 md5_hex md5_base64);use Math::BigInt;my $stmt = 'select id, balance from account where id = 1210'; my $hash = md5 $stmt; my($a,$b,$msb,$lsb) = unpack('V*',$hash);my $sqln = $msb*(2**32)+$lsb;my $stop = log($sqln) / log(32) + 1;my $sqlid = ’’;my $charbase32 = ’0123456789abcdfghjkmnpqrstuvwxyz’;my @chars = split ’’, $charbase32;for($i=0; $i < $stop-1; $i++){ my $x = Math::BigInt->new($sqln); my $seq = $x->bdiv(32**$i)->bmod(32); $sqlid = $chars[$seq].$sqlid;}print 'SQL is:n $stmt nSQL_ID isn $sqlidn';

大家可以發現SQL 1和SQL 2通過代碼生成的sql_id值是不一樣,所以不共享。

SQL is: select id, balance from account where id = 121 SQL_ID is dm5c6ck1g7bdsSQL is: select id, balance From account where id = 121 SQL_ID is 6xb8gvs5cmc9b

如果讓你比較兩個Java代碼文件的內容的有何差異,只需要將這段代碼理解透了,就可以改造實現自己的業務邏輯。

QueryCache配置

mysql> show variables like ’%query_cache%’;+------------------------------+----------+| Variable_name | Value |+------------------------------+----------+| have_query_cache | YES || query_cache_limit | 1048576 || query_cache_min_res_unit | 4096 || query_cache_size | 16777216 || query_cache_type | OFF || query_cache_wlock_invalidate | OFF | Variable_name Description have_query_cache 查詢緩存是否可用,YES-可用;NO-不可用,如果用標準二進制MySQL,值總是YES。 query_cache_limit 控制單個查詢結果集的最大尺寸,默認是1MB。 query_cache_min_res_unit 查詢緩存分片數據塊的大小,默認是4KB,可以滿足大部分業務場景。 query_cache_size 查詢緩存大小,單位Bytes,設置為0是禁用QueryCache,注意:不要將緩存的大小設置得太大,由于在更新過程中需要線程鎖定QueryCache,因此對于非常大的緩存,您可能會看到鎖爭用問題。 query_cache_type 當query_cache_size>0;該變量影響qc如何工作,有三個取值0,1,2,0:禁止緩存或檢索緩存結果;1:啟用緩存,SELECT SQL_NO_CACHE的語句除外;2:只緩存以SELECT SQL_CACHE開頭的語句。

query_cache_min_res_unit說明

默認大小是4KB,如果有很多查詢結果很小,那么默認數據塊大小可能會導致內存碎片,由于內存不足,碎片可能會強制查詢緩存從緩存中刪除查詢。

在這種情況下,可以減小query_cache_min_res_unit的值,由于修剪而刪除的空閑塊和查詢的數量由Qcache_free_blocks和Qcache_lowmem_prunes狀態變量的值給出,如果大量的查詢有較大的結果集,可以增大該參數的值來提高性能。

通常開啟QueryCache方式

# 修改MySQL配置文件/etc/my.cnf,添加如下配置,重啟MySQL server即可。[mysqld]query_cache_size = 32Mquery_cache_type = 1QueryCache使用

先搞點測試數據,分別對禁用和開啟QueryCache下的場景進行測試。

--創建一個用戶表users,并且插入100w數據。CREATE TABLE `users` ( `id` bigint NOT NULL AUTO_INCREMENT, `name` varchar(20) NOT NULL DEFAULT ’’ COMMENT ’姓名’, `age` tinyint NOT NULL DEFAULT ’0’ COMMENT ’age’, `gender` char(1) NOT NULL DEFAULT ’M’ COMMENT ’性別’, `phone` varchar(16) NOT NULL DEFAULT ’’ COMMENT ’手機號’, `create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT ’創建時間’, `update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT ’修改時間’, PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT=’用戶信息表’;select count(*) from users;+----------+| count(*) |+----------+| 1000000 |禁用queryCache場景

在不使用QueryCache的時候,每次執行相同的查詢語句,都要發生一次硬解析,消耗大量的資源。

MySQL查詢緩存的小知識

#禁用QueryCache的配置query_cache_size = 0query_cache_type = 0

重復執行下面查詢,觀察執行時間。

--第一次執行查詢語句mysql> select * from users order by create_time desc limit 10;+---------+------------+-----+--------+-------------+---------------------+---------------------+| id | name | age | gender | phone | create_time | update_time |+---------+------------+-----+--------+-------------+---------------------+---------------------+| 997855 | User997854 | 54 | M | 15240540354 | 2020-12-15 14:34:50 | 2020-12-15 14:34:50 |.......10 rows in set (0.89 sec)--第二次執行同樣的查詢語句mysql> select * from users order by create_time desc limit 10;+---------+------------+-----+--------+-------------+---------------------+---------------------+| id | name | age | gender | phone | create_time | update_time |+---------+------------+-----+--------+-------------+---------------------+---------------------+| 997855 | User997854 | 54 | M | 15240540354 | 2020-12-15 14:34:50 | 2020-12-15 14:34:50 |.......10 rows in set (0.90 sec)-- profile跟蹤情況mysql> show profile cpu,block io for query 1; +----------------------+----------+----------+------------+--------------+---------------+| Status | Duration | CPU_user | CPU_system | Block_ops_in | Block_ops_out |+----------------------+----------+----------+------------+--------------+---------------+| preparing | 0.000022 | 0.000017 | 0.000004 | 0 | 0 || Sorting result | 0.000014 | 0.000009 | 0.000005 | 0 | 0 || executing | 0.000011 | 0.000007 | 0.000004 | 0 | 0 || Sending data | 0.000021 | 0.000016 | 0.000004 | 0 | 0 || Creating sort index | 0.906290 | 0.826584 | 0.000000 | 0 | 0 |

可以看到,多次執行同樣的SQL查詢語句,執行時間都是0.89s左右,幾乎沒有差別,同時時間主要消耗在Creating sort index階段。

開啟queryCache場景

開啟查詢緩存時,查詢語句第一次被執行時會將SQL文本及查詢結果緩存在QC中,下一次執行同樣的SQL執行從QC中獲取數據返回給客戶端即可。

MySQL查詢緩存的小知識

#禁用QueryCache的配置query_cache_size = 32Mquery_cache_type = 1

--第一次執行查詢語句mysql> select * from users order by create_time desc limit 10;+---------+------------+-----+--------+-------------+---------------------+---------------------+| id | name | age | gender | phone | create_time | update_time |+---------+------------+-----+--------+-------------+---------------------+---------------------+| 997855 | User997854 | 54 | M | 15240540354 | 2020-12-15 14:34:50 | 2020-12-15 14:34:50 |.......10 rows in set (0.89 sec)--第二次執行查詢語句mysql> select * from users order by create_time desc limit 10;+---------+------------+-----+--------+-------------+---------------------+---------------------+| id | name | age | gender | phone | create_time | update_time |+---------+------------+-----+--------+-------------+---------------------+---------------------+| 997855 | User997854 | 54 | M | 15240540354 | 2020-12-15 14:34:50 | 2020-12-15 14:34:50 |.......10 rows in set (0.00 sec)-- profile跟蹤數據mysql> show profile cpu,block io for query 3;+--------------------------------+----------+----------+------------+--------------+---------------+| Status | Duration | CPU_user | CPU_system | Block_ops_in | Block_ops_out |+--------------------------------+----------+----------+------------+--------------+---------------+| Waiting for query cache lock | 0.000016 | 0.000015 | 0.000001 | 0 | 0 || checking query cache for query | 0.000007 | 0.000007 | 0.000000 | 0 | 0 || checking privileges on cached | 0.000004 | 0.000003 | 0.000000 | 0 | 0 || checking permissions | 0.000034 | 0.000033 | 0.000001 | 0 | 0 || sending cached result to clien | 0.000018 | 0.000017 | 0.000001 | 0 | 0 |

可以看到,第一次執行QueryCache里沒有緩存SQL文本及數據,執行時間0.89s,由于開啟了QC,SQL文本及執行結果被緩存在QC中,第二次執行執行同樣的SQL查詢語句,直接命中QC且返回數據,不需要發生硬解析,所以執行時間降低為0s,從profile里看到sending cached result to client直接發送QC中的數據返回給客戶端。

查詢緩存命中率

查詢緩存相關的status變量

mysql>SHOW GLOBAL STATUS LIKE ’QCache_%’;+-------------------------+----------+| Variable_name | Value |+-------------------------+----------+| Qcache_free_blocks | 1 | --查詢緩存中可用內存塊的數目。| Qcache_free_memory | 33268592 | --查詢緩存的可用內存量。| Qcache_hits | 121 | --從QC中獲取結果集的次數。| Qcache_inserts | 91 | --將查詢結果集添加到QC的次數,意味著查詢已經不在QC中。| Qcache_lowmem_prunes | 0 | --由于內存不足而從查詢緩存中刪除的查詢數。| Qcache_not_cached | 0 | --未緩存的查詢數目。| Qcache_queries_in_cache | 106 | --在查詢緩存中注冊的查詢數。| Qcache_total_blocks | 256 | --查詢緩存中的塊總數。

查詢緩存命中率及平均大小

Qcache_hitsQuery cache hit rate = ------------------------------------------------ x 100% Qcache_hits + Qcache_inserts + Qcache_not_cached query_cache_size = Qcache_free_memoryQuery Cache Avg Query Size = --------------------------------------- Qcache_queries_in_cache更新操作對QC影響

舉個例子,支付系統的里轉賬邏輯,先要鎖定賬戶再修改余額,主要步驟如下:

MySQL查詢緩存的小知識

Query_ID Query Description 1 reset query cache 清空查詢緩存。 2 select balance from account where id = 121 第一次執行,未命中QC,添加到QC。 3 select balance from account where id = 121 命中QC,直接返回結果。 4 update account set balance = balance - 1000 where id = 121 更新,鎖定query cche進行更新,緩存數據失效。 5 select balance from account where id = 121 緩存已失效,未命中,添加到QC。 6 select balance from account where id = 121 命中QC,直接返回結果。 對于這種情況來說,QC是不太適合的,因為第一次執行查詢SQL未命中,返回結果給客戶端,添加SQL文本及結果集到QC之后,下一次執行同樣的SQL直接從QC返回結果,不需要硬解析操作,但是每次Update都是先更新數據,然后鎖定QC然后更新緩存結果,會導致之前的緩存結果失效,再次執行相的查詢SQL還是未命中,有得重新添加到QC,這樣頻繁的鎖定QC->檢查QC->添加QC->更新QC非常消耗資源,降低數據庫的并發處理能力。為何放棄QueryCache一般業務場景從業務系統的操作類型,可以分為OLTP(OnLine Transaction Processing 聯機事務處理系統)和OLAP(OnLine Analysis Processing聯機分析處理系統),對于政企業務,也可以分為BOSS(Business Operation Support System-業務操作支撐系統,簡稱業支)和BASS(Business Analysis Support System-業務分析支撐系統,簡稱經分),來總結下這兩類系統的特點。

MySQL查詢緩存的小知識

適合QueryCache的場景

首先,查詢緩存QC的大小只有幾MB,不適合將緩存設置得太大,由于在更新過程中需要線程鎖定QueryCache,因此對于非常大的緩存,可能會看到鎖爭用問題。那么,哪些情況有助于從查詢緩存中獲益呢?以下是理想條件:

相同的查詢是由相同或多個客戶機重復發出的。 被訪問的底層數據本質上是靜態或半靜態的。 查詢有可能是資源密集型和/或構建簡短但計算復雜的結果集,同時結果集比較小。 并發性和查詢QPS都不高。

這4種情況只是理想情況下,實際的業務系統都是有CRUD操作的,數據更新比較頻繁,查詢接口的QPS比較高,所以能滿足上面的理想情況下的業務場景實在很少,我能想到就是配置表,數據字典表這些基本都是靜態或半靜態的,可以時通過QC來提高查詢效率。

不適合QueryCache的場景

如果表數據變化很快,則查詢緩存將失效,并且由于不斷從緩存中刪除查詢,從而使服務器負載升高,處理速度變得更慢,如果數據每隔幾秒鐘更新一次或更加頻繁,則查詢緩存不太可能合適。

同時,查詢緩存使用單個互斥體來控制對緩存的訪問,實際上是給服務器SQL處理引擎強加了一個單線程網關,在查詢QPS比較高的情況下,可能成為一個性能瓶頸,會嚴重降低查詢的處理速度。因此,MySQL 5.6中默認禁用了查詢緩存。

刪除QueryCache

The query cache is deprecated as of MySQL 5.7.20, and is removed in MySQL 8.0. Deprecation includes query_cache_type,可以看到從MySQL 5.6的默認禁用,5.7的廢棄以及8.0的徹底刪除,Oracle也是綜合了各方面考慮做出了這樣的選擇。

上面聊了下適合和不適合的QueryCache的業務場景,發現這個特性對業務場景要求過于苛刻,與實際業務很難吻合,而且開啟之后,對數據庫并發度和處理能力都會降低很多,下面總結下為何MySQL從Disabled->Deprecated->Removed QueryCache的主要原因。

MySQL查詢緩存的小知識

同時查詢緩存碎片化還會導致服務器的負載升高,影響數據庫的穩定性,在Oracle官方搜索QueryCache可以發現,有很多Bug存在,這也就決定了MySQL 8.0直接果斷的Remove了該特性。

總結

上面為大家介紹了MySQL QueryCache從推出->禁用->廢棄->刪除的心路歷程,設計之初是為了減少重復SQL查詢帶來的硬解析開銷,同時將物理IO轉化為邏輯IO,來提高SQL的執行效率,但是MySQL經過了多個版本的迭代,同時在硬件存儲發展之快的今天,QC幾乎沒有任何收益,而且還會降低數據庫并發處理能力,最終在8.0版本直接Removd掉了。

其實緩存設計思想在硬件和軟件領域無處不在,硬件方面:RAID卡,CPU都有自己緩存,軟件方面就太多了,OS的cache,數據庫的buffer pool以及Java程序的緩存,作為一名研發工程師,需要根據業務場景選擇合適緩存方案是非常重要的,如果都不合適,就需進行定制化開發緩存,來更好的Match自己的業務場景,今天就聊這么多,希望對大家有所幫助。

我是敖丙,你知道的越多,你不知道的越多,感謝各位人才的:點贊、收藏和評論,我們下期見!

以上就是MySQL查詢緩存的小知識的詳細內容,更多關于MySQL查詢緩存的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 日韩3级在线观看 | 91原创视频在线观看 | 国产午夜精品在线 | 亚洲一级毛片 | 亚洲精品在线播放 | 国产农村妇女精品一二区 | 黄色骚片 | 国产精品国产精品国产专区不片 | 北条麻妃国产九九九精品小说 | 欧美一区二区三区 | 国产精品一区三区 | 亚洲毛片在线观看 | 久久社区 | 不卡免费视频 | 国产精品一二区 | 久久久精品一区二区三区 | 欧美一区二区久久久 | 午夜免费av | 日本一区二区三区视频免费看 | 精品日韩一区二区 | 国产精品45p | www.欧美亚洲 | 国产真实精品久久二三区 | 亚洲无吗天堂 | 黄网站色大毛片 | 欧美激情精品久久久久久免费 | 精品国产一区二区三区成人影院 | 69久久99精品久久久久婷婷 | 久久久亚洲一区二区三区 | 亚洲欧美日韩精品久久奇米色影视 | 国产欧美在线视频 | 亚洲精品成人免费 | 久久生活片 | 久久机热 | 国产精品美女一区二区三区四区 | 羞羞视频网站 | 成人久久 | 久久国产精品99精国产 | 亚洲一区中文字幕在线 | 国产最好的精华液网站 | 自拍偷拍99 | 久久成人高清 | 久久精品一区二区三区中文字幕 | 亚洲欧洲一区二区 | 免费观看日韩一级片 | 国产精品久久久久久久福利院 | 超碰8| 精品久久久久香蕉网 | 国产一区在线看 | 97久久精品 | 国产精品一区在线观看你懂的 | 日韩欧美一区二区三区免费观看 | 国产精品爱久久久久久久 | 资源av| 欧美日一区二区 | 欧美另类专区 | 亚洲色图一区二区三区 | 国产精品毛片无码 | 在线精品一区二区 | 日韩在线免费电影 | 亚洲精品一区二区三区中文字幕 | 九九综合九九综合 | 黄色免费高清视频 | 国产成人精品无人区一区 | 91中文在线观看 | 91天堂在线观看 | 欧美成人一级 | 毛片链接| 男女羞羞视频免费在线观看 | 久久精品免费看 | 久久99精品久久久 | 男人天堂社区 | 久久久久久久国产精品 | 日本黄色影片在线观看 | 在线欧美日韩 | 国产一区二区观看 | 国产成人午夜视频 | 99久热在线精品视频观看 | 日韩国产欧美亚洲 | 免费成人av在线 | 国产99久久久精品视频 | 久久综合爱 | 久久国产精品久久久久久 | 国产精品久久久久久久久久久久久 | 日本免费在线 | 久草久草久草 | 国产ts余喵喵和直男多体位 | 日韩一区二区三区在线播放 | 中文字幕亚洲欧美 | 久久99久久99精品免观看粉嫩 | 欧美综合国产 | 国产一级免费视频 | 午夜影院免费视频 | 狠狠操夜夜操 | 欧美精品一区二区三区在线四季 | 日韩福利一区二区 | 蜜桃毛片| 色一色网站 | 国产欧美久久久久久 | 中文字幕在线第一页 | 国产精品一区二区久久 | www.久草| www天天干| 午夜精品久久久久久久久久久久 | 国产电影一区二区在线观看 | 国产99久久精品一区二区永久免费 | 宅男伊人| 日本视频一区二区三区 | 中文字幕 在线观看 | 91国内| 国产一二三在线 | 在线日韩视频 | 久久久亚洲精 | 日本免费在线 | 98久久久| 国产激情一区二区三区成人免费 | 天堂亚洲| 亚洲成人精品av | 欧美日韩精品一区 | 亚洲国产成人在线视频 | 久久免费精品 | 国产毛片av | 久久久精品欧美 | 国产精品一区av | 国产中文| 福利视频一区 | 免费观看一区二区三区毛片 | 91麻豆精品国产91久久久久久久久 | 欧美久久精品 | 99精品全国免费观看视频软件 | 久草成人 | 久久精品国产v日韩v亚洲 | 日韩国产一区二区三区 | 美女91| 四虎影院在线看 | 成人久久18免费观看 | 91免费看 | 国产一区二区三区四区在线观看 | 国产美女精品 | 欧美全黄 | 欧美一级欧美三级在线观看 | 噜噜噜天天躁狠狠躁夜夜精品 | 亚洲网站免费观看 | 日日干夜夜操 | 亚洲精品成人免费 | 国产成人精品a视频一区www | 一区二区三区亚洲 | 日韩中文视频 | 成人午夜在线观看 | 高清视频一区 | 亚洲午夜免费视频 | 亚洲午夜精品一区二区三区 | 久久久久99| 日本成人中文字幕 | 99精品一区二区三区 | 国产精品对白一区二区三区 | 亚洲国产成人在线 | 亚洲色图偷拍视频 | 久久亚洲精品中文字幕 | 太平公主一级艳史播放高清 | 韩国精品一区 | 亚洲精品九九 | 亚洲一区二区三区在线播放 | 成人在线免费视频 | 久久久久亚洲av毛片大全 | 久久成人综合网 | 国产精品99久久久久久久vr | 国产精品天堂 | 国产黄色在线观看 | 成人xxx| 中文字幕视频一区 | 成人在线观看免费 | 成人在线一区二区 | 国产精品亚洲视频 | 91亚洲国产 | 婷婷视频在线 | 老师的朋友2 | 国内精品视频一区二区三区八戒 | 日日干夜夜操 | 国产美女网站视频 | 激情小视频在线观看 | 久久久久久99精品 | www一区| 日韩一二三区视频 | 欧美精品一区二区三区四区在线 | 欧美精品综合 | 蜜桃一区| 午夜精品网站 | 亚洲网站久久 | 四虎影院免费网址 | 久久三级视频 | av手机在线播放 | 久久久亚洲成人 | 日日天天 | 久久久国产精品入口麻豆 | av午夜电影| 午夜寂寞网站 | 日韩三区 | 日韩免费在线 | 国产欧美综合一区二区三区 | 国内精品99| 成人性大片免费观看网站 | 精品久久久久久久久久久 | 日韩av福利 | 成人福利av | 色视频网站在线观看 | 国产中文字幕一区二区三区 | 91精品国产高清一区二区三区 | 黑人巨大精品欧美黑白配亚洲 | 欧美视频免费在线 | aⅴ色国产 欧美 | 精品国产一区在线 | 欧美一级视频 | 欧美精品亚洲精品日韩精品 | 一区二区三区不卡视频 | 欧美久久久 | 欧洲精品一区 | 综合久久国产九一剧情麻豆 | 宅男lu666噜噜噜在线观看 | 国产999久久 | 一级毛片,一级毛片 | 日本精品免费在线观看 | 亚州中文 | 欧美一区二区三区精品 | 日韩精品专区在线影院重磅 | 精品影院| 超碰香蕉 | 综合色播 | 色一情一乱一伦一区二区三区 | 午夜精品久久久久 | 国产亚洲视频在线观看 | 国产成人精品综合 | 亚洲精品不卡 | 91中文字幕| 欧美一区二区三区四区不卡 | 亚洲精品91 | 99热精品在线 | 欧美成人小视频 | 亚洲精品久久久一区二区三区 | 天天拍天天草 | 91精品久久 | 亚洲一区二区三区在线视频 | 亚洲国产精品久久久 | 亚洲毛片网站 | 丁香五月网久久综合 | 成人中文网 | 亚洲成人av片 | av一级在线 | 久久久一区二区三区 | 日本精品在线观看 | 国产精品成人一区二区三区夜夜夜 | 99这里只有精品 | 日韩精品一二三区 | 欧美成人专区 | www.久草 | yy6080久久伦理一区二区 | 欧美一级视频 | 久久综合久 | 亚洲一区视频在线播放 | 国产精品久久久久影院色老大 | 久久叉 | 国产精品久久久久久二区 | 日韩欧美在线观看一区 | 日日干夜夜干 | 国产精品1区 | h片在线免费观看 | 亚洲欧美日韩在线 | 国产中文字幕在线观看 | 蜜桃av网址| 国产农村妇女精品 | 热re99久久精品国99热线看 | 国产成人亚洲综合 | 毛片视频播放 | 成年人免费看 | 亚洲一区精品在线 | 日韩精品av一区二区三区 | 一区二区三区久久 | av一级毛片| 蜜月久综合久久综合国产 | 天堂免费在线 | 青青草一区 | 91色视频在线观看 | 亚洲一级视频在线 | 日韩精品视频在线播放 | 最新久久精品 | 日日骚视频 | 久久一二区 | 91视频在线看 | 国产高清在线观看 | 日韩久久久久 | 一区二区三区在线观看国产 | 国产高清小视频 | 国产目拍亚洲精品99久久精品 | 图片区 国产 欧美 另类 在线 | 91性高湖久久久久久久久_久久99 | 国产精品1区2区 | 一区二区视频 | 精品免费国产 | 99福利视频 | 麻豆自拍偷拍 | 国产一区免费 | 欧美日韩一区二区视频在线观看 | 亚洲精彩视频 | www.日韩在线观看 | 91在线| 日日操夜夜操天天操 | 久久精品国产视频 | 九一亚洲精品 | 精品国精品国产自在久不卡 | 夜添久久精品亚洲国产精品 | 精品久久久久久国产三级 | 成人小视频在线播放 | 五月天婷婷在线视频 | 欧美视频在线免费 | 91亚洲国产精品 | 国产精品亚洲成人 | 国产一区在线视频 | 国产激情一区二区三区 | 精品在线一区 | 亚洲精品乱码久久久久久金桔影视 | 成人性视频在线播放 | 中文字幕视频在线免费 | 亚洲啊v在线 | av中文字幕在线播放 | 免费av观看 | 国产精品99精品久久免费 | 成人毛片视频免费 | 超碰免费观看 | 涩涩视频在线免费看 | 免费在线黄 | 99草免费视频 | 在线成人免费观看www | 亚洲高清视频在线 | 成人亚洲 | 午夜成人免费电影 | 我看午夜视频 | 麻豆产精国品免费 | 视频一区在线播放 | 黄色一级视 | 伊人欧美在线 | 国产一区二区三区在线免费 | 精品一区二区三区在线视频 | 亚洲精品免费观看 | 男女全黄一级一级高潮免费看 | 成人欧美一区二区三区在线播放 | 亚洲欧美综合 | 亚洲网在线 | 狠狠综合久久av一区二区老牛 | 成人在线不卡 | 欧美日韩在线观看一区二区 | 亚洲精品在线播放视频 | 视频在线一区 | a级毛片免费高清视频 | 欧美激情 | 亚洲一区播放 | 国产一区日韩在线 | 久久久综合亚洲91久久98 | 亚洲高清在线视频 | 一区二区三区四区在线播放 | 欧美亚洲日本 | 丝袜 亚洲 另类 欧美 综合 | 久久草在线视频 | 亚洲一区二区三区爽爽爽爽爽 | 久久九九| 欧美国产综合一区 | 国产一区二区三区免费观看 | h视频免费在线 | 狠狠天天 | 五月激情六月婷婷 | xvideos.蜜桃一区二区 | 国产成人综合网 | 女人夜夜春 | 午夜av电影 | 91精品国产欧美一区二区成人 | 国产日韩精品一区二区 | 国产日韩精品一区二区 | 欧美一级片免费看 | 欧美激情综合五月色丁香小说 | 一区二区在线免费观看 | 欧美精三区欧美精三区 | 欧美一极片 | 欧美成人精品一区二区三区在线看 | 久久成人午夜 | 精品国产精品国产偷麻豆 | 99色播| 亚洲欧美日韩在线 | 成人欧美 | 亚洲人人| 久久激情五月丁香伊人 | 日韩2区| 精品中文字幕在线观看 | 亚洲视频精品在线 | 一区二区毛片 | 最新日韩av | 91精品国产99 | 日本黄色一级电影 | 午夜看片 | 亚洲视频自拍 | 久久综合狠狠综合久久综合88 | 视频一区免费观看 | 午夜私人影院在线观看 | 视频一区二区三 | 波多野结衣一二三 | 永久免费在线 | 国产精品成av人在线视午夜片 | 精品久久久久久久人人人人传媒 | 日本三级中国三级99人妇网站 | 国产性猛交xxxx免费看久久 | 欧美日韩一区二区三区在线观看 | 中文字幕一区在线 | 亚洲精品久久久久一区二区三区 | 欧洲妇女成人淫片aaa视频 | 国产精选视频 | 久久精品91 | 天天操夜夜操 | 免费操片 | 黄色一级毛片免费 | 国产一级片 | 91久久国产精品 | 免费av片在线 | 国产成人精品久久二区二区91 | 亚洲毛片| 在线亚洲一区 | 黄色片网站在线观看 | 免费观看一级毛片 | 成人av福利| 在线播放亚洲 | 免费观看一级毛片 | 精品国产一区二区三区在线观看 | 一级黄色录像视频 | 2020亚洲视频 | 欧美一级在线免费观看 | 国产在线一区二区 | 久久久精彩视频 | 日韩毛片| 在线观看免费视频日韩 | 国产精品免费视频观看 | 99伊人| 91亚洲国产成人久久精品网站 | 久久久久国产一区二区三区四区 | 久久91视频 | 亚洲午夜在线 | 亚洲一区中文字幕在线观看 | 午夜成人在线视频 | 国产高清在线观看 | 午夜视频网站 | 视频一区二区三区中文字幕 | 青青草在线免费视频 | 国产精品一区二区三区四区 | 91精品视频在线播放 | 超碰在线影院 | 一区二区三区福利视频 | 99精品一区二区三区 | 国产精品一二区 | 丝袜+亚洲+另类+欧美+变态 | 日韩中文字幕在线视频 | 国产拍揄自揄精品视频麻豆 | 国内精品国产成人国产三级粉色 | 青娱乐网站 | 国产精品久久久久久吹潮 | 久久人人爽人人爽 | 久草免费在线 | 日韩精品免费在线视频 | 天天射影院 | 国产精品毛片一区二区在线看 | 国产一区a | 欧美精品乱码久久久久久按摩 | 综合中文字幕 | 男女羞羞视频免费在线观看 | 黑人av | 久久久久国产 | 黄色a视频 | 国产精品精品视频一区二区三区 | 福利视频三区 | 精品国产乱码久久久久久1区2区 | 久久久久久99 | 国产中文字幕亚洲 | 色婷婷综合在线 | 国产精品午夜电影 | 青青久久| 国产精品免费观看 | 欧美一区二区三区 | 欧美亚洲视频 | 亚洲小视频 | 超碰导航| 91精品国产自产精品男人的天堂 | 91资源在线观看 | 中文字幕乱码亚洲精品一区 | 亚洲国产成人精品女人久久久 | 精品久久久久久久 | 正在播放欧美 | 午夜精品久久久久久久久 | 91精品一区二区三区久久久久 | 亚洲精品aaa | 色黄视频在线看 | 99久久免费视频在线观看 | 一区免费在线观看 | 精品一区二区三区四区五区 | 国产精品一区在线观看 | 亚洲tv国产 | 欧美日本一区 | 一级毛片大全免费播放 | 亚洲aⅴ网站 | 久草久草久草 | 成人免费小视频 | 亚洲情综合五月天 | 婷色综合 | 中文字幕亚洲区 | 日韩在线视频第一页 | 精品亚洲一区二区三区 | 欧美经典一区 | 日本色站| 久久99深爱久久99精品 | 国产一级高清视频 | 中文字幕综合 | 91嫩草在线 | 成人亚洲精品久久久久软件 | 成人在线视频播放 | 精品亚洲一区二区三区四区五区 | 国产精品美女www爽爽爽动态图 | a毛片| 国产精品中文字幕在线 | 久久久久综合 | 精品久久久久久国产三级 | 亚洲精品成人 | 在线观看91视频 | 狠狠久| 一级片av| 国产精品久久久久久久久 | 欧美激情欧美激情在线五月 | 亚洲乱码一区二区三区在线观看 | 久久久国产精品 | 国产美女av在线 | 国产午夜精品久久久久久久 | 国产99久久 | 色婷婷网 | 精品亚洲在线 | 欧美日韩在线一区二区三区 | 久久久中文字幕 | 日本一区二区高清视频 | www.久久99| 成人影| 久久女同互慰一区二区三区 | 亚洲美女在线视频 | 草久网| 国产毛片a级 | 国产不卡在线视频 | 一区二区三区免费 | 中文字幕一区二区三区乱码在线 | 青青草久 | 一级在线看 | 爱爱精品 | 99精品免费 | 天堂资源在线 | 97久久精品人人做人人爽50路 | 一区二区中文 | 日韩中文字幕一区二区 | 国产三级在线观看 | 欧美一级欧美三级在线观看 | 欧美日韩视频网站 | av77| 欧美久久视频 | 精品亚洲一区二区三区 | 久久国产精品免费一区二区三区 | 国产不卡在线视频 | 98久久久| 福利视频网址导航 | 亚洲区在线 | 久久人人爽人人爽人人片av高清 | 欧美视频一级 | 国内精品久久久久久影视8 91一区二区在线观看 | 都市激情av | 亚洲一区二区三区蜜桃 | 久久精品欧美一区二区三区不卡 | 国产不卡免费视频 | 九九九久久久 | 福利网在线 | 国产区视频在线观看 | 天天操天天碰 | 亚洲一级淫片 | 中文字幕免费在线 | 日韩超碰在线观看 | 九九热精| 日本久草 | 成人免费视频网站在线看 | 成人av免费 | 久久se精品一区精品二区 | 精品国产视频 | 国产精品久久婷婷六月丁香 | 国产欧美综合一区二区三区 | 9191视频 | 在线视频日韩 | 婷婷视频在线 | 在线视频一区二区 | 国产精品久久久久久久久久妇女 | 理论片87福利理论电影 | 欧美日韩在线电影 | 99爱在线观看 | 成人性毛片 | 亚洲系列 | 一级特黄| 草草成人 | 国产日韩欧美 | 国产午夜久久 | 国产日韩精品一区二区 | 国产三级视频 | 欧洲成人在线 | 91精品久久久久久久久中文字幕 | 日韩91| 国产欧美一区二区 | 99热精品视 | 欧美成人一级 | 黄视频在线播放 | av一区二区在线播放 | 久久久久久国产精品 |