精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

分布式之MemCache詳細解讀

存儲 存儲軟件 分布式
MemCache是一個自由、源碼開放、高性能、分布式的分布式內存對象緩存系統,用于動態Web應用以減輕數據庫的負載。

MemCache是什么

MemCache是一個自由、源碼開放、高性能、分布式的分布式內存對象緩存系統,用于動態Web應用以減輕數據庫的負載。它通過在內存中緩存數據和對象來減少讀取數據庫的次數,從而提高了網站訪問的速度。MemCaChe是一個存儲鍵值對的HashMap,在內存中對任意的數據(比如字符串、對象等)所使用的key-value存儲,數據可以來自數據庫調用、API調用,或者頁面渲染的結果。MemCache設計理念就是小而強大,它簡單的設計促進了快速部署、易于開發并解決面對大規模的數據緩存的許多難題,而所開放的API使得MemCache能用于Java、C/C++/C#、Perl、Python、PHP、Ruby等大部分流行的程序語言。

[[257078]]

另外,說一下MemCache和MemCached的區別:

1、MemCache是項目的名稱

2、MemCached是MemCache服務器端可以執行文件的名稱

MemCache的官方網站為http://memcached.org/

MemCache訪問模型

為了加深理解,我模仿著原阿里技術專家李智慧老師《大型網站技術架構 核心原理與案例分析》一書MemCache部分,自己畫了一張圖:

 

特別澄清一個問題,MemCache雖然被稱為"分布式緩存",但是MemCache本身完全不具備分布式的功能,MemCache集群之間不會相互通信(與之形成對比的,比如JBoss Cache,某臺服務器有緩存數據更新時,會通知集群中其他機器更新緩存或清除緩存數據),所謂的"分布式",完全依賴于客戶端程序的實現,就像上面這張圖的流程一樣。

同時基于這張圖,理一下MemCache一次寫緩存的流程:

1、應用程序輸入需要寫緩存的數據

2、API將Key輸入路由算法模塊,路由算法根據Key和MemCache集群服務器列表得到一臺服務器編號

3、由服務器編號得到MemCache及其的ip地址和端口號

4、API調用通信模塊和指定編號的服務器通信,將數據寫入該服務器,完成一次分布式緩存的寫操作

讀緩存和寫緩存一樣,只要使用相同的路由算法和服務器列表,只要應用程序查詢的是相同的Key,MemCache客戶端總是訪問相同的客戶端去讀取數據,只要服務器中還緩存著該數據,就能保證緩存命中。

這種MemCache集群的方式也是從分區容錯性的方面考慮的,假如Node2宕機了,那么Node2上面存儲的數據都不可用了,此時由于集群中Node0和Node1還存在,下一次請求Node2中存儲的Key值的時候,肯定是沒有命中的,這時先從數據庫中拿到要緩存的數據,然后路由算法模塊根據Key值在Node0和Node1中選取一個節點,把對應的數據放進去,這樣下一次就又可以走緩存了,這種集群的做法很好,但是缺點是成本比較大。

一致性Hash算法

從上面的圖中,可以看出一個很重要的問題,就是對服務器集群的管理,路由算法至關重要,就和負載均衡算法一樣,路由算法決定著究竟該訪問集群中的哪臺服務器,先看一個簡單的路由算法。

1、余數Hash

比方說,字符串str對應的HashCode是50、服務器的數目是3,取余數得到2,str對應節點Node2,所以路由算法把str路由到Node2服務器上。由于HashCode隨機性比較強,所以使用余數Hash路由算法就可以保證緩存數據在整個MemCache服務器集群中有比較均衡的分布。

如果不考慮服務器集群的伸縮性(什么是伸縮性,請參見大型網站架構學習筆記),那么余數Hash算法幾乎可以滿足絕大多數的緩存路由需求,但是當分布式緩存集群需要擴容的時候,就難辦了。

就假設MemCache服務器集群由3臺變為4臺吧,更改服務器列表,仍然使用余數Hash,50對4的余數是2,對應Node2,但是str原來是存在Node1上的,這就導致了緩存沒有命中。如果這么說不夠明白,那么不妨舉個例子,原來有HashCode為0~19的20個數據,那么:

 

現在我擴容到4臺,加粗標紅的表示命中:

 

如果我擴容到20+的臺數,只有前三個HashCode對應的Key是命中的,也就是15%。當然這只是個簡單例子,現實情況肯定比這個復雜得多,不過足以說明,使用余數Hash的路由算法,在擴容的時候會造成大量的數據無法正確命中(其實不僅僅是無法命中,那些大量的無法命中的數據還在原緩存中在被移除前占據著內存)。這個結果顯然是無法接受的,在網站業務中,大部分的業務數據度操作請求上事實上是通過緩存獲取的,只有少量讀操作會訪問數據庫,因此數據庫的負載能力是以有緩存為前提而設計的。當大部分被緩存了的數據因為服務器擴容而不能正確讀取時,這些數據訪問的壓力就落在了數據庫的身上,這將大大超過數據庫的負載能力,嚴重的可能會導致數據庫宕機。

這個問題有解決方案,解決步驟為:

(1)在網站訪問量低谷,通常是深夜,技術團隊加班,擴容、重啟服務器

(2)通過模擬請求的方式逐漸預熱緩存,使緩存服務器中的數據重新分布

2、一致性Hash算法

一致性Hash算法通過一個叫做一致性Hash環的數據結構實現Key到緩存服務器的Hash映射,看一下我自己畫的一張圖:

 

具體算法過程為:先構造一個長度為232的整數環(這個環被稱為一致性Hash環),根據節點名稱的Hash值(其分布為[0, 232-1])將緩存服務器節點放置在這個Hash環上,然后根據需要緩存的數據的Key值計算得到其Hash值(其分布也為[0, 232-1]),然后在Hash環上順時針查找距離這個Key值的Hash值最近的服務器節點,完成Key到服務器的映射查找。

就如同圖上所示,三個Node點分別位于Hash環上的三個位置,然后Key值根據其HashCode,在Hash環上有一個固定位置,位置固定下之后,Key就會順時針去尋找離它最近的一個Node,把數據存儲在這個Node的MemCache服務器中。使用Hash環如果加了一個節點會怎么樣,看一下:

 

看到我加了一個Node4節點,只影響到了一個Key值的數據,本來這個Key值應該是在Node1服務器上的,現在要去Node4了。采用一致性Hash算法,的確也會影響到整個集群,但是影響的只是加粗的那一段而已,相比余數Hash算法影響了遠超一半的影響率,這種影響要小得多。更重要的是,集群中緩存服務器節點越多,增加節點帶來的影響越小,很好理解。換句話說,隨著集群規模的增大,繼續命中原有緩存數據的概率會越來越大,雖然仍然有小部分數據緩存在服務器中不能被讀到,但是這個比例足夠小,即使訪問數據庫,也不會對數據庫造成致命的負載壓力。

至于具體應用,這個長度為232的一致性Hash環通常使用二叉查找樹實現,至于二叉查找樹,就是算法的問題了,可以自己去查詢相關資料。

MemCache實現原理

首先要說明一點,MemCache的數據存放在內存中,存放在內存中個人認為意味著幾點:

1、訪問數據的速度比傳統的關系型數據庫要快,因為Oracle、MySQL這些傳統的關系型數據庫為了保持數據的持久性,數據存放在硬盤中,IO操作速度慢

2、MemCache的數據存放在內存中同時意味著只要MemCache重啟了,數據就會消失

3、既然MemCache的數據存放在內存中,那么勢必受到機器位數的限制,這個之前的文章寫過很多次了,32位機器最多只能使用2GB的內存空間,64位機器可以認為沒有上限

然后我們來看一下MemCache的原理,MemCache最重要的莫不是內存分配的內容了,MemCache采用的內存分配方式是固定空間分配,還是自己畫一張圖說明:

 

這張圖片里面涉及了slab_class、slab、page、chunk四個概念,它們之間的關系是:

1、MemCache將內存空間分為一組slab

2、每個slab下又有若干個page,每個page默認是1M,如果一個slab占用100M內存的話,那么這個slab下應該有100個page

3、每個page里面包含一組chunk,chunk是真正存放數據的地方,同一個slab里面的chunk的大小是固定的

4、有相同大小chunk的slab被組織在一起,稱為slab_class

MemCache內存分配的方式稱為allocator,slab的數量是有限的,幾個、十幾個或者幾十個,這個和啟動參數的配置相關。

MemCache中的value過來存放的地方是由value的大小決定的,value總是會被存放到與chunk大小最接近的一個slab中,比如slab[1]的chunk大小為80字節、slab[2]的chunk大小為100字節、slab[3]的chunk大小為128字節(相鄰slab內的chunk基本以1.25為比例進行增長,MemCache啟動時可以用-f指定這個比例),那么過來一個88字節的value,這個value將被放到2號slab中。放slab的時候,首先slab要申請內存,申請內存是以page為單位的,所以在放入第一個數據的時候,無論大小為多少,都會有1M大小的page被分配給該slab。申請到page后,slab會將這個page的內存按chunk的大小進行切分,這樣就變成了一個chunk數組,最后從這個chunk數組中選擇一個用于存儲數據。

如果這個slab中沒有chunk可以分配了怎么辦,如果MemCache啟動沒有追加-M(禁止LRU,這種情況下內存不夠會報Out Of Memory錯誤),那么MemCache會把這個slab中最近最少使用的chunk中的數據清理掉,然后放上最新的數據。針對MemCache的內存分配及回收算法,總結三點:

1、MemCache的內存分配chunk里面會有內存浪費,88字節的value分配在128字節(緊接著大的用)的chunk中,就損失了30字節,但是這也避免了管理內存碎片的問題

2、MemCache的LRU算法不是針對全局的,是針對slab的

3、應該可以理解為什么MemCache存放的value大小是限制的,因為一個新數據過來,slab會先以page為單位申請一塊內存,申請的內存最多就只有1M,所以value大小自然不能大于1M了

再總結MemCache的特性和限制

上面已經對于MemCache做了一個比較詳細的解讀,這里再次總結MemCache的限制和特性:

1、MemCache中可以保存的item數據量是沒有限制的,只要內存足夠

2、MemCache單進程在32位機中最大使用內存為2G,這個之前的文章提了多次了,64位機則沒有限制

3、Key最大為250個字節,超過該長度無法存儲

4、單個item最大數據是1MB,超過1MB的數據不予存儲

5、MemCache服務端是不安全的,比如已知某個MemCache節點,可以直接telnet過去,并通過flush_all讓已經存在的鍵值對立即失效

6、不能夠遍歷MemCache中所有的item,因為這個操作的速度相對緩慢且會阻塞其他的操作

7、MemCache的高性能源自于兩階段哈希結構:第一階段在客戶端,通過Hash算法根據Key值算出一個節點;第二階段在服務端,通過一個內部的Hash算法,查找真正的item并返回給客戶端。從實現的角度看,MemCache是一個非阻塞的、基于事件的服務器程序

8、MemCache設置添加某一個Key值的時候,傳入expiry為0表示這個Key值永久有效,這個Key值也會在30天之后失效,見memcache.c的源代碼:

這個失效的時間是mem

 

cache源碼里面寫的,開發者沒有辦法改變MemCache的Key值失效時間為30天這個限制

MemCache指令匯總

上面說過,已知MemCache的某個節點,直接telnet過去,就可以使用各種命令操作MemCache了,下面看下MemCache有哪幾種命令:

 

stats指令解讀

stats是一個比較重要的指令,用于列出當前MemCache服務器的狀態,拿一組數據舉個例子:

 

這些參數反映著MemCache服務器的基本信息,它們的意思是:

參 數 名作 用pidMemCache服務器的進程id uptime服務器已經運行的秒數time服務器當前的UNIX時間戳 versionMemCache版本 pointer_size當前操作系統指針大小,反映了操作系統的位數,64意味著MemCache服務器是64位的 rusage_user進程的累計用戶時間 rusage_system 進程的累計系統時間 curr_connections 當前打開著的連接數total_connections 當服務器啟動以后曾經打開過的連接數connection_structures 服務器分配的連接構造數 cmd_get get命令總請求次數 cmd_setset命令總請求次數 cmd_flush flush_all命令總請求次數 get_hits 總命中次數,重要,緩存最重要的參數就是緩存命中率,以get_hits / (get_hits + get_misses)表示,比如這個緩存命中率就是99.2% get_misses 總未命中次數 auth_cmds 認證命令的處理次數 auth_errors 認證失敗的處理次數 bytes_read 總讀取的字節數bytes_written 總發送的字節數 limit_maxbytes分配給MemCache的內存大小(單位為字節) accepting_conns 是否已經達到連接的最大值,1表示達到,0表示未達到listen_disabled_num 統計當前服務器連接數曾經達到最大連接的次數,這個次數應該為0或者接近于0,如果這個數字不斷增長, 就要小心我們的服務了threads 當前MemCache總線程數,由于MemCache的線程是基于事件驅動機制的,因此不會一個線程對應一個用戶請求 bytes 當前服務器存儲的items總字節數current_items 當前服務器存儲的items總數量 total_items 自服務器啟動以后存儲的items總數量

stats slab指令解讀

如果對上面的MemCache存儲機制比較理解了,那么我們來看一下各個slab中的信息,還是拿一組數據舉個例子:

 

首先看到,第二個slab的chunk_size(144)/第一個slab的chunk_size(96)=1.5,第三個slab的chunk_size(216)/第二個slab的chunk_size(144)=1.5,可以確定這個MemCache的增長因子是1.5,chunk_size以1.5倍增長。然后解釋下字段的含義:

 

看到這個命令的輸出量很大,所有信息都很有作用。舉個例子吧,比如第一個slab中使用的chunks很少,第二個slab中使用的chunks很多,這時就可以考慮適當增大MemCache的增長因子了,讓一部分數據落到第一個slab中去,適當平衡兩個slab中的內存,避免空間浪費。

MemCache的Java實現實例

講了這么多,作為一個Java程序員,怎么能不寫寫MemCache的客戶端的實現呢?MemCache的客戶端有很多第三方jar包提供了實現,其中比較好的當屬XMemCached了,XMemCached具有效率高、IO非阻塞、資源耗費少、支持完整的協議、允許設置節點權重、允許動態增刪節點、支持JMX、支持與Spring框架集成、使用連接池、可擴展性好等諸多優點,因而被廣泛使用。這里利用XMemCache寫一個簡單的MemCache客戶單實例,也沒有驗證過,純屬拋磚引玉:

分布式之MemCache詳細解讀
責任編輯:武曉燕 來源: 今日頭條
相關推薦

2012-07-20 14:40:22

2014-07-15 11:15:44

hadoop分布式部署

2013-06-18 14:00:59

HDFS分布式文件系統

2021-12-13 11:07:10

鴻蒙HarmonyOS應用

2018-07-17 08:14:22

分布式分布式鎖方位

2025-06-13 07:30:51

2022-03-06 21:43:05

Citus架構PostgreSQL

2019-09-26 15:43:52

Hadoop集群防火墻

2019-10-10 09:16:34

Zookeeper架構分布式

2019-06-19 15:40:06

分布式鎖RedisJava

2023-05-29 14:07:00

Zuul網關系統

2017-09-01 05:35:58

分布式計算存儲

2019-12-26 08:59:20

Redis主從架構

2021-12-28 17:03:29

數據質量分布式

2019-07-04 15:13:16

分布式緩存Redis

2025-05-13 03:22:00

2019-09-05 13:06:08

雪花算法分布式ID

2021-12-14 08:19:59

系統分布式網絡

2019-01-21 11:01:52

Redis分布式鎖缺陷

2013-12-05 09:54:50

FusionCubeHANA分布式架構
點贊
收藏

51CTO技術棧公眾號

91精品国产视频| 日韩国产成人无码av毛片| 亚洲 欧美 日韩在线| 国产v日韩v欧美v| 国产丝袜在线精品| 91久久精品日日躁夜夜躁国产| 日日碰狠狠添天天爽| 午夜精品在线| 精品美女永久免费视频| 欧美一级爱爱| www.av日韩| 免费欧美在线| 日韩视频欧美视频| 中文字幕 日本| 国产精品99精品一区二区三区∴| 樱桃视频在线观看一区| 欧美一卡2卡3卡4卡无卡免费观看水多多| 做爰视频毛片视频| 亚洲高清二区| 色婷婷综合久久久久| 影音先锋资源av| 欧美天堂一区| 欧美体内谢she精2性欧美| 正在播放国产精品| 日本ー区在线视频| 成人性生交大片免费看中文网站| 国产精品久久久久久久久| 久久国产一级片| 国产精品久久久久无码av| 亚洲激情 国产| av在线网站免费观看| 自拍偷拍欧美视频| 亚洲一区二区精品久久av| 亚洲国产精品久久久久久女王| 手机在线观看免费av| 久久爱另类一区二区小说| 26uuu亚洲伊人春色| 印度午夜性春猛xxx交| 日韩中文在线电影| 亚洲欧美综合v| 欧美性生交xxxxx| 国产在线视频欧美一区| 欧美吞精做爰啪啪高潮| 国产精品一区二区免费在线观看| 免费av在线播放| 一二区在线观看| 日韩精品一区二区三区免费观看| 亚洲第一精品久久忘忧草社区| 国产无色aaa| 国产69精品久久| 欧美日韩综合视频| 又粗又黑又大的吊av| av成人影院在线| 亚洲激情网站免费观看| 色婷婷777777仙踪林| 日本中文字幕伦在线观看| 日本一区二区免费在线| 欧美午夜精品久久久久久蜜| 日本精品专区| 久久婷婷色综合| 欧美日韩精品中文字幕一区二区| 手机亚洲第一页| 久久亚洲精华国产精华液 | 中文字幕免费在线不卡| 东热在线免费视频| 国产精品天美传媒| 中文视频一区视频二区视频三区| 午夜不卡视频| 亚洲丝袜精品丝袜在线| 激情视频小说图片| xxx性欧美| 岛国视频午夜一区免费在线观看| 女人和拘做爰正片视频| 婷婷电影在线观看| 在线欧美小视频| www.激情小说.com| 99精品国产九九国产精品| 69久久99精品久久久久婷婷| 粗大的内捧猛烈进出视频| 懂色av一区二区| 亚洲九九九在线观看| 人妻熟人中文字幕一区二区| 99久久.com| 免费不卡在线观看av| 久青草视频在线观看| 国产欧美成人| 国产欧美va欧美va香蕉在线| va婷婷在线免费观看| 丁香另类激情小说| 日本婷婷久久久久久久久一区二区| 国产精成人品localhost| 日本黄色中文字幕| 精品一区精品二区高清| 粉嫩av免费一区二区三区| 香蕉av一区二区三区| 国产欧美日韩在线视频| 国产精品12p| 182在线视频观看| 色婷婷精品大视频在线蜜桃视频 | 18aaaa精品欧美大片h| 日韩欧亚中文在线| 天堂在线一区二区三区| 大型av综合网站| 国产一区二区三区网站| 清纯粉嫩极品夜夜嗨av| 噜噜噜在线观看免费视频日韩| 国产免费亚洲高清| 手机看片福利永久| 中文字幕一区二区三区精华液| 黄色一级片在线看| 日本久久久久| 日韩国产精品亚洲а∨天堂免| 国产主播av在线| 日韩视频一区| 91精品视频免费观看| 日韩欧美亚洲系列| 亚洲精品免费在线观看| 激情伊人五月天| 精品国产一区二区三区性色av| 亚洲精品福利在线观看| 538任你躁在线精品视频网站| 久久久久免费| 99在线影院| 丝袜美腿美女被狂躁在线观看 | 国产剧情在线视频| 国产91精品在线观看| 亚洲精品无人区| 久久人体大尺度| 日韩精品一区在线| 99自拍偷拍视频| 久久久夜夜夜| 国内成+人亚洲| 都市激情久久综合| 欧美一卡2卡三卡4卡5免费| 国产精品无码无卡无需播放器| 亚洲国产免费看| 亚洲xxx自由成熟| 男女爱爱视频网站| 国产在线视频网址| 精品久久中文字幕| 在线播放第一页| 欧美在线日韩| 91九色偷拍| av网站导航在线观看免费| 欧美日韩亚洲综合| 国产三级黄色片| 日本人妖一区二区| 日韩三级电影| 日韩网站中文字幕| 一区二区欧美久久| 日韩精选在线观看| 国产亚洲精品bt天堂精选| 日日鲁鲁鲁夜夜爽爽狠狠视频97| 国产精品黄网站| 久久久久久亚洲| 色呦呦中文字幕| 婷婷一区二区三区| 丰满少妇一区二区| 午夜在线视频观看日韩17c| 国产91精品入口17c| 亚洲精品天堂| 精品久久人人做人人爽| 久热这里只有精品在线| 成人av网在线| 欧洲av无码放荡人妇网站| 五月激激激综合网色播| 热久久这里只有精品| 国产资源在线播放| 91豆麻精品91久久久久久| 国产综合精品在线| 麻豆成人综合网| 在线精品亚洲一区二区| 精品一区二区三区中文字幕| 精品中文字幕在线| 亚洲日本在线播放| 欧洲国产伦久久久久久久| 刘亦菲国产毛片bd| 国产精品亚洲成人| 日韩av高清在线看片| 少妇一区二区视频| 91免费电影网站| 大香伊人中文字幕精品| 亚洲精品自拍偷拍| 中文字幕日产av| 亚洲最新在线观看| 国产精品三级在线观看无码| 热久久一区二区| 欧美美女黄色网| 亚洲欧洲av| 成人免费视频网址| 久久露脸国语精品国产91| 日韩久久一区| 在线播放国产精品| 国产aⅴ一区二区三区| 黄网站色欧美视频| 美国精品一区二区| 成人福利电影精品一区二区在线观看| 337p粉嫩大胆噜噜噜鲁| 久久亚洲影视| 国内一区二区在线视频观看| 澳门av一区二区三区| 欧美超级乱淫片喷水| 日韩电影免费| 91精品国产综合久久福利| 一级片中文字幕| 亚洲欧美另类小说| 成人黄色免费网址| 国产成人精品免费在线| 99久久国产宗和精品1上映| 亚洲综合专区| 日韩jizzz| 国产一区二区在线视频你懂的| 国产精品久久二区| 国模精品视频| 九色精品美女在线| 999国产在线视频| 亚洲激情小视频| 国产欧美综合视频| 欧美综合一区二区| 午夜毛片在线观看| 亚洲精品午夜久久久| 99精品欧美一区二区| 99精品视频在线观看免费| www.污网站| 奇米777欧美一区二区| av日韩一区二区三区| 一区二区电影在线观看| 日韩欧美视频一区二区三区四区 | 国产精品外国| 国产专区在线视频| 婷婷亚洲五月| 午夜精品视频在线观看一区二区| 精品伊人久久久| 99视频网站| 国产精品视频一区视频二区 | 日韩中文第一页| 蝌蚪视频在线播放| 亚洲精品wwww| 黄色小视频免费在线观看| 欧美一区二区高清| 99视频免费看| 欧美一区二区三区的| 国产又粗又大又爽| 欧美在线小视频| 欧美激情成人网| 精品国产99久久久久久| 亚洲欧美在线磁力| 午夜在线视频免费| 亚洲а∨天堂久久精品喷水| 国产裸体无遮挡| 制服丝袜日韩国产| 96亚洲精品久久久蜜桃| 欧美日韩国产三级| 一本色道久久综合无码人妻| 欧美日韩免费观看一区二区三区| 无码无套少妇毛多18pxxxx| 欧美视频中文字幕在线| 日本韩国欧美中文字幕| 一本一道久久a久久精品| 台湾佬中文在线| 色婷婷综合久久久中文字幕| 亚洲乱码国产乱码精品| 色呦呦国产精品| 欧美性猛交xxxx乱大交hd | 草民午夜欧美限制a级福利片| 91xxx在线观看| 日韩在线观看av| 18+视频在线观看| 久久青草精品视频免费观看| 波多野结衣中文字幕久久| 欧美极品美女视频网站在线观看免费| 中中文字幕av在线| 午夜精品理论片| 在线观看v片| 国产精品极品美女粉嫩高清在线| 国产精品99| 99久久伊人精品影院| 国产精品毛片视频| 欧美精品123| 色999国产精品| 日韩一级免费看| 国产精品老牛| 最新天堂在线视频| 国产成人av资源| 国产呦小j女精品视频| 欧美高清在线视频| 日韩女优一区二区| 福利一区福利二区微拍刺激| 中文文字幕一区二区三三| 欧美久久久久中文字幕| 亚洲欧美另类一区| 亚洲一二三在线| а√资源新版在线天堂| 欧美一区二区三区免费观看| 国产精品videossex撒尿| 99re视频| 欧美裸体在线版观看完整版| 欧美美女黄色网| 久久久成人网| 潘金莲一级淫片aaaaa| 久久久久99精品国产片| 翔田千里88av中文字幕| 欧美日韩亚洲视频| 国产口爆吞精一区二区| 精品亚洲夜色av98在线观看| 欧美成年黄网站色视频| 国产在视频线精品视频www666| 欧美色图亚洲自拍| 欧美欧美全黄| 国产免费999| 成人短视频下载| 精品国产精品国产精品| 91久久精品一区二区二区| 亚洲av无码乱码国产精品| 一区二区三区精品99久久| a级片在线免费| 国产综合久久久久久| 精品在线播放| 国产午夜大地久久| 国产精品羞羞答答xxdd| 亚洲精品天堂网| 欧美午夜精品久久久久久久| www.色呦呦| www.xxxx欧美| 欧美日韩国产网站| 欧美精品免费观看二区| 黄色亚洲在线| 国产精久久久久| 亚洲欧美日韩国产另类专区| 中文字幕免费高清在线观看| 日韩精品免费在线视频| 福利成人导航| 丁香五月网久久综合| 亚洲情侣在线| 爱豆国产剧免费观看大全剧苏畅| 国产日韩精品视频一区| 秋霞精品一区二区三区| 日韩精品有码在线观看| 成av人片在线观看www| 国产欧美日韩在线播放| 激情av一区| 天天躁日日躁狠狠躁av麻豆男男| 一区二区欧美在线观看| 国产99对白在线播放| 九九久久综合网站| 精品一区二区三区中文字幕视频| 樱空桃在线播放| 国产一区二区三区四区五区美女 | 人成在线免费视频| 欧美一区深夜视频| 女厕嘘嘘一区二区在线播放 | 国产精品久久婷婷| 亚洲欧美另类在线观看| 亚洲人成午夜免电影费观看| 国产精品青青草| 久久国产影院| 在线免费av播放| 中文字幕第一区综合| 在线免费一级片| 日韩在线观看免费全集电视剧网站| 国产福利91精品一区二区| 亚洲精品欧洲精品| 精品一区二区三区不卡| 亚洲色图100p| 日本韩国一区二区三区| 成人在线免费观看| 国产精品日日做人人爱| 99精品视频在线| 国产精品美女av| 久久bbxx| 成人午夜黄色影院| 国模吧视频一区| 国产精久久久久| 色综合久久久久久久久久久| 欧美欧美欧美| 欧美又大又硬又粗bbbbb| 亚洲97av| 精品少妇无遮挡毛片| 日本一区二区免费在线观看视频| 日韩欧美国产另类| 久久国产精品久久久久久| 国产美女视频一区二区| 国产69精品久久久久久久| 91免费观看视频在线| 国产精品久久久免费视频| 亚洲人精品午夜在线观看| 日本在线精品| 男人c女人视频| 99久久精品一区| 亚洲一级av毛片| 久久99久久99精品免观看粉嫩| 日韩电影不卡一区| 日本成人在线免费视频| 国产精品免费久久久久| 性一交一乱一伧老太| 91精品国产91久久久久| 欧美a级片视频| 中文字幕在线国产| 欧美日韩一区 二区 三区 久久精品| 麻豆网站在线看|