亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數(shù)據(jù)庫(kù) > MongoDB > 正文

深入理解MongoDB分片的管理

2020-10-29 18:48:45
字體:
供稿:網(wǎng)友

前言

在MongoDB(版本 3.2.9)中,分片集群(sharded cluster)是一種水平擴(kuò)展數(shù)據(jù)庫(kù)系統(tǒng)性能的方法,能夠?qū)?shù)據(jù)集分布式存儲(chǔ)在不同的分片(shard)上,每個(gè)分片只保存數(shù)據(jù)集的一部分,MongoDB保證各個(gè)分片之間不會(huì)有重復(fù)的數(shù)據(jù),所有分片保存的數(shù)據(jù)之和就是完整的數(shù)據(jù)集。分片集群將數(shù)據(jù)集分布式存儲(chǔ),能夠?qū)⒇?fù)載分?jǐn)偟蕉鄠€(gè)分片上,每個(gè)分片只負(fù)責(zé)讀寫一部分?jǐn)?shù)據(jù),充分利用了各個(gè)shard的系統(tǒng)資源,提高數(shù)據(jù)庫(kù)系統(tǒng)的吞吐量。

數(shù)據(jù)集被拆分成數(shù)據(jù)塊(chunk),每個(gè)數(shù)據(jù)塊包含多個(gè)doc,數(shù)據(jù)塊分布式存儲(chǔ)在分片集群中。MongoDB負(fù)責(zé)追蹤數(shù)據(jù)塊在shard上的分布信息,每個(gè)分片存儲(chǔ)哪些數(shù)據(jù)塊,叫做分片的元數(shù)據(jù),保存在config server上的數(shù)據(jù)庫(kù) config中,一般使用3臺(tái)config server,所有config server中的config數(shù)據(jù)庫(kù)必須完全相同。通過mongos能夠直接訪問數(shù)據(jù)庫(kù)config,查看分片的元數(shù)據(jù);mongo shell 提供 sh 輔助函數(shù),能夠安全地查看分片集群的元數(shù)據(jù)信息。

對(duì)任何一個(gè)shard進(jìn)行查詢,只會(huì)獲取collection在當(dāng)前分片上的數(shù)據(jù)子集,不是整個(gè)數(shù)據(jù)集。Application 只需要連接到mongos,對(duì)其進(jìn)行的讀寫操作,mongos自動(dòng)將讀寫請(qǐng)求路由到相應(yīng)的shard。MongoDB通過mongos將分片的底層實(shí)現(xiàn)對(duì)Application透明,在Application看來,訪問的是整個(gè)數(shù)據(jù)集。

一,主分片

在分片集群中,不是每個(gè)集合都會(huì)分布式存儲(chǔ),只有使用sh.shardCollection()顯式將collection分片后,該集合才會(huì)分布式存儲(chǔ)在不同的shard中。對(duì)于非分片集合(un-sharded collection),其數(shù)據(jù)只會(huì)存儲(chǔ)在主分片(Primary shard)中,默認(rèn)情況下,主分片是指數(shù)據(jù)庫(kù)最初創(chuàng)建的shard,用于存儲(chǔ)該數(shù)據(jù)庫(kù)中非分片集合的數(shù)據(jù)。每個(gè)數(shù)據(jù)庫(kù)都有一個(gè)主分片。

Each database in a sharded cluster has a primary shard that holds all the un-sharded collections for that database. Each database has its own primary shard.

例如,一個(gè)分片集群有三個(gè)分片:shard1,shard2,shard3,在分片shard1創(chuàng)建一個(gè)數(shù)據(jù)庫(kù)blog。如果將數(shù)據(jù)庫(kù)bolg分片,那么MongoDB會(huì)自動(dòng)在shard2,shard3上創(chuàng)建一個(gè)結(jié)構(gòu)相同的數(shù)據(jù)庫(kù)blog,數(shù)據(jù)庫(kù)blog的Primary Shard是Shard1。

圖示,Collection2的主分片是ShardA。

使用 movePrimary命令變更數(shù)據(jù)庫(kù)默認(rèn)的Primary shard,非分片集合將會(huì)從當(dāng)前shard移動(dòng)到新的主分片。

db.runCommand( { movePrimary : "test", to : "shard0001" } )

在使用movePrimary命令變更數(shù)據(jù)庫(kù)的主分片之后,config server中的配置信息是最新的,mongos緩存的配置信息變得過時(shí)了。MongoDB提供命令:flushRouterConfig 強(qiáng)制mongos從config server獲取最新的配置信息,刷新mongos的緩存。

db.adminCommand({"flushRouterConfig":1})

二,分片的元數(shù)據(jù)

不要直接到config server上查看分片集群的元數(shù)據(jù)信息,這些數(shù)據(jù)非常重要,安全的方式是通過mongos連接到config數(shù)據(jù)查看,或者使用sh輔助函數(shù)查看。

使用sh輔助函數(shù)查看

sh.status()

連接到mongos查看config數(shù)據(jù)庫(kù)中的集合

mongos> use config

1,shards 集合保存分片信息

db.shards.find()

shard的數(shù)據(jù)存儲(chǔ)在host指定的 replica set 或 standalone mongod中。

{ "_id" : "shard_name", "host" : "replica_set_name/host:port", "tag":[shard_tag1,shard_tag2] }

2,databases集合保存分片集群中所有數(shù)據(jù)庫(kù)的信息,不管數(shù)據(jù)庫(kù)是否分片

db.databases.find()

如果在數(shù)據(jù)庫(kù)上執(zhí)行sh.enableSharding(“db_name”) ,那么字段partitioned字段值就是true;primary 字段指定數(shù)據(jù)庫(kù)的主分片(primary shard)。

{ "_id" : "test", "primary" : "rs0", "partitioned" : true}

3,collections集合保存所有已分片集合的信息,不包括非分片集合(un-sharded collections)

key是:分片的片鍵

db.collections.find(){ "_id" : "test.foo", "lastmodEpoch" : ObjectId("57dcd4899bd7f7111ec15f16"), "lastmod" : ISODate("1970-02-19T17:02:47.296Z"), "dropped" : false, "key" : {  "_id" : 1 }, "unique" : true}

4,chunks 集合保存數(shù)據(jù)塊信息,

ns:分片的集合,結(jié)構(gòu)是:db_name.collection_name

min 和 max: 片鍵的最小值和最大值

shard:塊所在的分片

db.chunks.find(){ "_id" : "test.foo-_id_MinKey", "lastmod" : Timestamp(1, 1), "lastmodEpoch" : ObjectId("57dcd4899bd7f7111ec15f16"), "ns" : "test.foo", "min" : {  "_id" : 1 }, "max" : {  "_id" : 3087 }, "shard" : "rs0"}

5,changelog集合記錄分片集群的操作,包括chunk的拆分和遷移操作,Shard的增加或刪除操作

what 字段:表示操作的類型,例如:multi-split表示chunk的拆分,

"what" : "addShard","what" : "shardCollection.start","what" : "shardCollection.end", "what" : "multi-split",

6,tags 記錄shard的tag和對(duì)應(yīng)的片鍵范圍

{ "_id" : { "ns" : "records.users", "min" : { "zipcode" : "10001" } }, "ns" : "records.users", "min" : { "zipcode" : "10001" }, "max" : { "zipcode" : "10281" }, "tag" : "NYC"}

7,settings 集合記錄均衡器狀態(tài)和chunk的大小,默認(rèn)的chunk size是64MB。

{ "_id" : "chunksize", "value" : 64 }{ "_id" : "balancer", "stopped" : false }

8,locks 集合記錄分布鎖(distributed lock),保證只有一個(gè)mongos 實(shí)例能夠在分片集群中執(zhí)行管理任務(wù)。

mongos在擔(dān)任balancer時(shí),會(huì)獲取一個(gè)分布鎖,并向config.locks中插入一條doc。

The locks collection stores a distributed lock. This ensures that only one mongos instance can perform administrative tasks on the cluster at once. The mongos acting as balancer takes a lock by inserting a document resembling the following into the locks collection.

{ "_id" : "balancer", "process" : "example.net:40000:1350402818:16807", "state" : 2, "ts" : ObjectId("507daeedf40e1879df62e5f3"), "when" : ISODate("2012-10-16T19:01:01.593Z"), "who" : "example.net:40000:1350402818:16807:Balancer:282475249", "why" : "doing balance round"}

三,刪除分片

刪除分片時(shí),必須確保該分片上的數(shù)據(jù)被移動(dòng)到其他分片中,對(duì)于以分片的集合,使用均衡器來遷移數(shù)據(jù)塊,對(duì)于非分片的集合,必須修改集合的主分片。

1,刪除已分片的集合數(shù)據(jù)

step1,保證均衡器是開啟的

sh.setBalancerState(true);

step2,將已分片的集合全部遷移到其他分片

use admindb.adminCommand({"removeShard":"shard_name"})

removeShard命令會(huì)將數(shù)據(jù)塊從當(dāng)前分片上遷移到其他分片上去,如果分片上的數(shù)據(jù)塊比較多,遷移過程可能耗時(shí)很長(zhǎng)。

step3,檢查數(shù)據(jù)塊遷移的狀態(tài)

use admindb.runCommand( { removeShard: "shard_name" } )

使用removeShard命令能夠查看數(shù)據(jù)塊遷移的狀態(tài),remaining 字段表示剩余數(shù)據(jù)塊的數(shù)量

{  "msg" : "draining ongoing", "state" : "ongoing", "remaining" : {  "chunks" : 42,  "dbs" : 1 }, "ok" : 1}

step4,數(shù)據(jù)塊完成遷移

use admindb.runCommand( { removeShard: "shard_name" } ){ "msg" : "removeshard completed successfully", "state" : "completed", "shard" : "shard_name", "ok" : 1}

2,刪除未分片的數(shù)據(jù)庫(kù)

step1,查看未分片的數(shù)據(jù)庫(kù)

未分片的數(shù)據(jù)庫(kù),包括兩部分:

     1、數(shù)據(jù)庫(kù)未被分片,該數(shù)據(jù)沒有使用sh.enableSharding(“db_name”) ,在數(shù)據(jù)庫(kù)config中,該數(shù)據(jù)庫(kù)的partitioned字段是false

     2、數(shù)據(jù)庫(kù)中存在collection未被分片,即當(dāng)前的分片是該集合的主分片

use configdb.databases.find({$or:[{"partitioned":false},{"primary":"shard_name"}]})

對(duì)于partitioned=false的數(shù)據(jù)庫(kù),其數(shù)據(jù)全部保存在當(dāng)前shard中;對(duì)于partitioned=true,primary=”shard_name“的數(shù)據(jù)庫(kù),表示存在未分片(un-sharded collection)存儲(chǔ)在該數(shù)據(jù)庫(kù)中,必須變更這些集合的主分片。

step2,修改數(shù)據(jù)庫(kù)的主分片

db.runCommand( { movePrimary: "db_name", to: "new_shard" })

四,增加分片

由于分片存儲(chǔ)的是數(shù)據(jù)集的一部分,為了保證數(shù)據(jù)的高可用性,推薦使用Replica Set作為shard,即使Replica Set中只包含一個(gè)成員。連接到mongos,使用sh輔助函數(shù)增加分片。

sh.addShard("replica_set_name/host:port")

不推薦將standalone mongod作為shard

sh.addShard("host:port")

五,特大塊

在有些情況下,chunk會(huì)持續(xù)增長(zhǎng),超出chunk size的限制,成為特大塊(jumbo chunk),出現(xiàn)特大塊的原因是chunk中的所有doc使用同一個(gè)片鍵(shard key),導(dǎo)致MongoDB無法拆分該chunk,如果該chunk持續(xù)增長(zhǎng),將會(huì)導(dǎo)致chunk的分布不均勻,成為性能瓶頸。

在chunk遷移時(shí),存在限制:每個(gè)chunk的大小不能超過2.5萬條doc,或者1.3倍于配置值。chunk size默認(rèn)的配置值是64MB,超過限制的chunk會(huì)被MongoDB標(biāo)記為特大塊(jumbo chunk),MongoDB不能將特大塊遷移到其他shard上。

MongoDB cannot move a chunk if the number of documents in the chunk exceeds either 250000 documents or 1.3 times the result of dividing the configured chunk size by the average document size.

1,查看特大塊

使用sh.status(),能夠發(fā)現(xiàn)特大塊,特大塊的后面存在 jumbo 標(biāo)志

 { "x" : 2 } -->> { "x" : 3 } on : shard-a Timestamp(2, 2) jumbo

2,分發(fā)特大塊

特大塊不能拆分,不能通過均衡器自動(dòng)分發(fā),必須手動(dòng)分發(fā)。

step1,關(guān)閉均衡器

sh.setBalancerState(false)

step2,增大Chunk Size的配置值

由于MongoDB不允許移動(dòng)大小超出限制的特大塊,因此,必須臨時(shí)增加chunk size的配置值,再將特大塊均衡地分發(fā)到分片集群中。

use configdb.settings.save({"_id":"chunksize","value":"1024"})

step3,移動(dòng)特大塊

sh.moveChunk("db_name.collection_name",{sharded_filed:"value_in_chunk"},"new_shard_name")

step4,啟用均衡器

sh.setBalancerState(true)

step5,刷新mongos的配置緩存

強(qiáng)制mongos從config server同步配置信息,并刷新緩存。

use admindb.adminCommand({ flushRouterConfig: 1 } )

六,均衡器

均衡器是由mongos轉(zhuǎn)變的,就是說,mongos不僅負(fù)責(zé)將查詢路由到相應(yīng)的shard上,還要負(fù)責(zé)數(shù)據(jù)塊的均衡。一般情況下,MongoDB會(huì)自動(dòng)處理數(shù)據(jù)均衡,通過config.settings能夠查看balancer的狀態(tài),或通過sh輔助函數(shù)查看

sh.getBalancerState()

返回true,表示均衡器在正運(yùn)行,系統(tǒng)自動(dòng)處理數(shù)據(jù)均衡,使用sh輔助函數(shù)能夠關(guān)閉balancer

sh.setBalancerState(false)

balancer不能立即終止正在運(yùn)行的塊遷移操作,在mongos轉(zhuǎn)變?yōu)閎alancer時(shí),會(huì)申請(qǐng)一個(gè)balancer lock,查看config.locks 集合,

use configdb.locks.find({"_id":"balancer"})--or sh.isBalancerRunning()

如果state=2,表示balancer正處于活躍狀態(tài),如果state=0,表示balancer已被關(guān)閉。

均衡過程實(shí)際上是將數(shù)據(jù)塊從一個(gè)shard遷移到其他shard,或者先將一個(gè)大的chunk拆分小的chunk,再將小塊遷移到其他shard上,塊的遷移和拆分都會(huì)增加系統(tǒng)的IO負(fù)載,最好將均衡器的活躍時(shí)間限制在系統(tǒng)空閑時(shí)進(jìn)行,可以設(shè)置balancer的活躍時(shí)間窗口,限制balancer在指定的時(shí)間區(qū)間內(nèi)進(jìn)行數(shù)據(jù)塊的拆分和遷移操作。

use configdb.settings.update(  {"_id":"balancer"},  "$set":{"activeWindow":{"start":"23:00","stop":"04:00"}}),  true)

均衡器拆分和移動(dòng)的對(duì)象是chunk,均衡器只保證chunk數(shù)量在各個(gè)shard上是均衡的,至于每個(gè)chunk包含的doc數(shù)量,并不一定是均衡的。可能存在一些chunk包含的doc數(shù)量很多,而有些chunk包含的doc數(shù)量很少,甚至不包含任何doc。因此,應(yīng)該慎重選擇分片的索引鍵,即片鍵,如果一個(gè)字段既能滿足絕大多數(shù)查詢的需求,又能使doc數(shù)量均勻分布,那么該字段是片鍵的最佳選擇。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)或者工作帶來一定的幫助,如果有疑問的大家可以留言交流。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
在线免费观看成年人视频| 国产精品腿扒开做爽爽爽挤奶网站| 日本成人三级电影网站| 欧美麻豆精品久久久久久| 国产视频1区2区| 久久影院一区二区| 国产偷窥女洗浴在线观看亚洲| 91在线看国产| 国产一区二区99| 粉嫩欧美一区二区三区高清影视| 久久国产直播| 日韩专区精品| 欧美日韩精品一区| 影音先锋男人看片资源| 蜜桃av一区| 日本免费高清一区二区| 亚洲一级淫片| 小小水蜜桃在线观看| 在线观看免费视频高清游戏推荐| 亚洲欧美日韩一级| 在线观看av每日更新免费| 2020中文字幕在线| 盗摄牛牛av影视一区二区| 色偷偷偷亚洲综合网另类| 精品国产一二| 国色天香2019中文字幕在线观看| 欧美不卡在线一区二区三区| 欧美大片免费观看| 免费精品一区二区三区在线观看| 日韩精品一区中文字幕| 青青草伊人久久| 一二三四区在线观看| 亚洲最大的成人网| 蜜臀国产一区二区三区在线播放| 亚洲精品自拍区在线观看| www.5588.com毛片| 国产精品亚洲自拍| 久久99精品久久久久久动态图| 亚洲欧洲精品在线| 天堂中文网在线| 国产精品调教| 亚洲高清国产精品| 久久精品国产亚洲a| 一个人免费播放在线视频看片| 黄色三级在线| 香蕉视频免费在线看| 色国产在线视频| 欧美日韩一级黄色片| 欧美成人综合一区| 97人人爽人人| 91精品国产福利在线观看麻豆| 免费无码毛片一区二区app| 中国极品少妇xxxx| 国产日韩精品一区观看| 亚洲私人影院| 波多野结衣一本一道| 鲁一鲁一鲁一鲁一av| 九一成人免费视频| 全部孕妇毛片丰满孕妇孕交| 91精品国产黑色瑜伽裤| 欧美日韩午夜电影网| 一本一道无码中文字幕精品热| 国产精品国产亚洲精品| 久久成年人免费电影| www.精品| 在线精品视频免费观看| 国产视频久久| 中文字幕av一区中文字幕天堂| 欧美性受ⅹ╳╳╳黑人a性爽| 91文字幕巨乱亚洲香蕉| 亚洲国产精品久久不卡毛片| 国产视频久久网| 国产农村妇女毛片精品久久麻豆| 天堂在线观看免费视频| 91精品中文字幕一区二区三区| 欧美人善zozσ性伦交| 欧美一级爆毛片| 在线欧美视频| 欧美一区二区三区四区视频| 日韩一区二区三区久久| 永久免费黄色软件| 日韩av一卡| 成人h动漫精品一区二区器材| 一级黄色大片网站| 日韩精品乱码免费| 丰满人妻熟女aⅴ一区| 久久99精品久久久野外观看| 久久久精品一区二区涩爱| 国产三级精品在线不卡| 亚洲人成精品久久久久久| 三级欧美韩日大片在线看| 亚洲成人动漫在线| 色就色 综合激情| 亚洲影视在线播放| 777丰满影院| 一区二区在线视频观看| 国产偷人爽久久久久久老妇app| 性色av一区| 亚洲国产成人无码av在线| 影音先锋在线亚洲| 欧美va在线| 星空无限传媒在线| 97久久精品在线| 日韩在线一区二区三区四区| 日韩久久不卡| 成人免费视频视频在线观看免费| 一区二区三区视频在线观看| 亚洲一级生活片| 成人永久免费| 欧美久久久网站| 日本在线视频观看| 怡红院一区二区| 久久国产精品无码网站| 色xxx在线播放| 97超级碰碰碰| 国产91xxx| 国产美女极度色诱视频www| 中文字幕+乱码+中文| 亚洲男人的天堂在线播放| 亚洲图片欧洲图片av| 黑人巨大40厘米重口ysn| 五月婷婷综合色| 亚洲一区美女| 性欧美13一14内谢| 亚洲精品福利电影| 国产免费无遮挡吸奶头视频| 中文字幕高清不卡| 中文字幕高清不卡| 亚洲第一天堂在线观看| 影音先锋男人看片资源站| 欧美乱做爰xxxⅹ久久久| 精品三级在线观看| 青草青青在线视频| 日韩av午夜在线观看| 亚洲欧美在线视频观看| 欧美波霸videosex极品| 日本高清免费不卡视频| 国产精品综合视频| 精品视频9999| 久久艹免费视频| 久久综合五月婷婷| 蜜桃久久一区二区三区| 91成人免费网站| 久久久久亚洲av片无码v| 久久中文资源| 日韩成人精品一区二区| 国产一区二区三区中文| 日韩电影大全免费观看2023年上| www.久久视频| 在线观看毛片网站| 99精品国产一区二区三区2021| 亚洲影视在线观看| 一本色道久久88综合日韩精品| 国产麻豆欧美日韩一区| 精品欧美激情精品一区| 国产精品99久久| 亚洲va久久久噜噜噜| 欧美孕妇毛茸茸xxxx| 中文字幕av免费专区久久| 99久久综合网| 免费看ww视频网站入口| 国产青青草视频| 老汉色老汉首页av亚洲| 成人高清在线观看免费| 99riav国产| 亚州av电影免费在线观看| 亚洲香蕉成人av网站在线观看| 欧美精品无码一区二区三区| 456亚洲影院| 亚洲欧美激情在线视频| 欧美成人一区二区三区电影| 国产精品海角社区在线观看| 欧美成人精品二区三区99精品| 欧美最猛性xxxxx(亚洲精品)| 国产偷人视频免费| 亚洲精品少妇30p| 国产91精品精华液一区二区三区| 欧美日韩极品在线观看一区| 国产精品一区二区三区毛片淫片| a视频免费看| 精品久久久久久久久久中文字幕| 菠萝蜜一区二区| 欧美一区久久| 欧美另类videos黑人极品| 日韩av在线导航| 国内精品久久久久久影院老狼| 任我爽在线视频精品一| 久久久精品国产sm调教| 丁香花高清视频完整版在线观看| 美女喷白浆视频| 久久久免费精品视频| 精品一区二区在线观看| 久久精品一二三区| 久久久久久久久久婷婷| 精品影院一区二区久久久| 高清一区二区三区av| 日韩精品一区二区不卡| 青丝免费观看高清影视| 成人黄色网址| 日本精品在线| 久久综合综合久久综合| 国产精品999久久久| 精品无码久久久久成人漫画| 亚洲日本护士毛茸茸| 九一精品在线观看| 久久久久久网| 欧美黄色视屏| 欧美h版在线观看| 九九综合九九| 在线成人av电影| 残酷重口调教一区二区| 麻豆一区二区| 欧美在线视频一二三| 伊人久久大香线蕉av超碰演员| 欧美激情在线精品一区二区三区| 色婷婷av久久久久久久| 97成人资源站| 欧美va在线观看| 日韩精品a在线观看91| 理论不卡电影大全神| 国产精品久久久久久五月尺| 日韩一区电影| 国产写真视频在线观看| 51精品国产黑色丝袜高跟鞋| 高清精品一区二区三区一区| 国产一二三视频| 91免费视频网站| 中文字幕av高清| 日韩精品免费在线| 激情小说中文字幕| aaaaa级片| 欧美成人国产精品一区二区| 亚洲3atv精品一区二区三区| 欧美国产日韩亚洲一区| 欧美日韩亚洲国产一区| 亚洲一区二区三区免费| 一级一片免费看| 午夜视频久久久| 亚洲国产日韩一区| 91久久久精品国产| 国精品日韩欧美一区二区三区| 欧美在线视频免费播放| 国产亚洲综合在线| 欧美大胆在线视频| 综合久久2o19| 亚洲免费av观看| jazzjazz国产精品久久| 国产成人手机高清在线观看网站| 五月天婷婷网站| 亚洲综合在线网站| 六月丁香综合网| 国产啪精品视频网站| 四虎1515hh.com| 热99re久久精品这里都是免费| 亚洲成人高清在线| 97在线免费视频观看| 久久riav二区三区| 欧美久久久久久久久久久久| 国产卡二和卡三的视频| 亚洲精品日韩久久久| 黄色美女一级片| 麻豆视频在线观看免费| 在线观看视频黄色| 综合久久中文字幕| 一个色妞综合视频在线观看| 麻豆明星ai换脸视频| 中文字幕电影在线| 在线免费观看黄色av| 国产精品亚洲第一区在线暖暖韩国| 九九视频精品全部免费播放| 欧美日韩成人网| 成人免费公开视频| 亚洲美女屁股眼交| 欧美国产一区二区| 久久99精品久久久久久| 欧美色老头old∨ideo| 看电视剧不卡顿的网站| 欧美极品少妇xxxxⅹ喷水| 欧美一级国产精品| 97成人在线视频| 欧美国产高跟鞋裸体秀xxxhd| 日韩一级淫片| 亚洲午夜一区| 亚洲一区二区三区四区五区中文| 成人综合久久网| 国产亚洲精品自在线观看| 国产传媒一区在线| 欧美一级一级性生活免费录像| 日日欢夜夜爽一区| 国产精品福利一区二区| 国产做a爰片久久毛片| 在线日韩视频| 无人区乱码一区二区三区| 日本不卡1区2区3区| 色婷婷成人综合| 亚洲国产精彩中文乱码av在线播放| 亚洲欧洲av一区二区三区久久| 亚洲理论在线a中文字幕| 亚洲国产日韩欧美综合久久| 国产精品18在线| 国产专区第一页| 国产69精品久久久久久久| 亚洲在线视频一区| 蜜桃狠狠狠狠狠狠狠狠狠| 国产最新精品| 奇门遁甲1982国语版免费观看高清| 日韩av首页| 欧美体内she精视频在线观看| 久久久久久久无码| 国内精品模特av私拍在线观看| 911精品美国片911久久久| 美女精品在线观看| 九九久久久2| 国产精品国产成人国产三级| 91久久久久国产一区二区| 欧美在线观看www| 天天干天天曰天天操| 尤物视频免费在线观看| 狠狠88综合久久久久综合网| 香蕉av在线| 日韩伦理在线电影| 91jq激情在线观看| 97精品视频| 欧美日韩福利电影| 可以看av的网站久久看| 欧美激情第一页在线观看| eeuss国产一区二区三区| 18av在线视频|