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

淺析MongoDB數據庫分布式存儲物理文件

數據庫 分布式 MongoDB
今天我們將談到的是基于MongoDB數據庫的分布式存儲物理文件,包括測試的過程,希望本文能對大家有所幫助。

我們知道了如何對關系型數據數據通過auto-sharding進行分布式數據存儲,今天介紹如何對物理文件(小文件,基本小于100K)進行分布式存儲。

接著看一下要配置的測試環境(與前一篇中類似):

 模擬2個shard服務和一個config服務, 均運行在10.0.4.85機器上,只是端口不同:    

Shard1:27020

Shard2:27021

Config:27022

Mongos啟動時默認使用的27017端口

在C,D,E磁盤下分別建立如下文件夾:

mongodb\bin

mongodb\db

然后用CMD命令行依次打開相應文件夾下的mongd文件:

c:\mongodb\bin\mongod --dbpath c:\mongodb\db\ --port 27020

d:\mongodb\bin\mongod --dbpath d:\mongodb\db\ --port 27021

e:\mongodb\bin\mongod --configsvr --dbpath e:\mongodb\db\ --port 27022   (注:config配置服務器)

啟動mongos時,默認開啟了27017端口

e:\mongodb\bin\mongos --configdb 10.0.4.85:27022

然后打開mongo:

E:\mongodb\bin>mongo   回車  (有時加端口會造成下面的addshard命令出問題)

  1.  > use admin  
  2.           switched to db admin  
  3. > db.runCommand( { addshard : "10.0.4.85:27020", allowLocal : 1, maxSize:2 , minKey:1, maxKey:10} )    
  4.  
  5. --添加sharding,maxsize單位是M,此處設置比較小的數值只為演示sharding效果  
  6.  
  7.          { "shardAdded" : "shard0000", "ok" : 1 }  
  8. > db.runCommand( { addshard : "10.0.4.85:27021", allowLocal : 1, minKey:1000} )  
  9.          { "shardAdded" : "shard0001", "ok" : 1 }    

注:如果要移除sharding,可用下面寫法

  1.  db.runCommand( { removeshard : "localhost:10000" } );  
  2.  
  3. > db.runCommand({listshards:1});   --查看shard節點列表      
  4. > config = connect("10.0.4.85:27022")  
  5. > configconfig = config.getSisterDB("config")  
  6. > dnt_mongodb=db.getSisterDB("dnt_mongodb");  
  7.           dnt_mongodb  
  8. > db.runCommand({enablesharding:"dnt_mongodb"})  
  9.           { "ok" : 1 }  
  10.      
  11. > db.printShardingStatus()    
  12.  
  1. --- Sharding Status ---  
  2.  sharding version: { "_id" : 1, "version" : 3 }  
  3.  shards:  
  4.      {  
  5.        "_id" : "shard0000",  
  6.        "host" : "10.0.4.85:27020",  
  7.        "maxSize" : NumberLong( 2 )  
  8.      }  
  9.      { "_id" : "shard0001", "host" : "10.0.4.85:27021" }  
  10.  databases:  
  11.        { "_id" : "admin", "partitioned" : false, "primary" : "config" }  
  12.        { "_id" : "dnt_mongodb", "partitioned" : true, "primary" : "shard0001" }  
  13.  
  14. > db.runCommand( { shardcollection : "dnt_mongodb.attach_gfstream.chunks", key : { files_id : 1 } } )  
  15. --此處與之前的數據存儲方式有些不同,目前shard似乎僅支持files_id  
  16.       { "collectionsharded" : "dnt_mongodb.attach_gfstream.chunks", "ok" : 1 } 

注:運行上面命令之前需要設置files_id為唯一索引[unique index]。        

創建完sharding和設置相應信息后,我們加載一下測試數據,我用下面代碼來讀取要本地文件,然后批量向mongodb中添加(通過循環修改文件名來添加相同大小的文件)。       

  1. /// <summary>  
  2.         /// 上傳文件到mongodb  
  3.         /// </summary>  
  4.         /// <param name="uploadDir">要上傳文件所在路徑</param>  
  5.         /// <param name="fileName">要上傳的文件名</param>  
  6.         /// <returns></returns>  
  7.         public bool UploadFile(string uploadDir, string fileName)  
  8.         {  
  9.             for (int i = 1; i < 10000; i++)  
  10.             {  
  11.                 try 
  12.                 {  
  13.                     Mongo mongo = mongoDB;  
  14.                     mongo.Connect();  
  15.                     IMongoDatabase DB = mongo["dnt_mongodb"];  
  16.  using (FileStream fileStream = new FileStream(uploadDir + fileName, FileMode.Open))  
  17.                     {  
  18.                         int nFileLen = (int)fileStream.Length;  
  19.  
  20.                         byte[] myData = new Byte[nFileLen];  
  21.                         fileStream.Read(myData, 0, nFileLen);  
  22.  
  23.                         GridFile fs = new GridFile(DB, "attach_gfstream");  
  24.                         using (GridFileStream gfs = fs.Create(fileName + i))  
  25.                         {  
  26.                             gfs.Write(myData, 0, nFileLen);  
  27.                         }  
  28.                     }  
  29.                     mongo.Disconnect();  
  30.                 }  
  31.                 catch { }           
  32.             }  
  33.             return true;  
  34.         } 

在批量添加約10000次(約10000個文件)之后,mongodb開始把sharding出來的chunk從shard0000分布到shard0001上,我們可以用下面指令來進行驗證:

> db.printShardingStatus()

  1. --- Sharding Status ---  
  2.   sharding version: { "_id" : 1, "version" : 3 }  
  3.   shards:  
  4.       {  
  5.         "_id" : "shard0000",  
  6.         "host" : "10.0.4.85:27020",  
  7.         "maxSize" : NumberLong( 2 )  
  8.       }  
  9.       { "_id" : "shard0001", "host" : "10.0.4.85:27021" }  
  10.   databases:  
  11.         { "_id" : "admin", "partitioned" : false, "primary" : "config" }  
  12.         { "_id" : "dnt_mongodb", "partitioned" : true, "primary" : "shard0000" }  
  13.  
  14.                 dnt_mongodb.attach_gfstream.chunks chunks:  
  15.                         { "files_id" : { $minKey : 1 } } -->> { "files_id" : ObjectId("4c85fd02145a9b1534010d89") } on : shard0001 { "t" : 2000, "i" : 0 }  
  16.                         { "files_id" : ObjectId("4c85fd02145a9b1534010d89") } -->> { "files_id" : ObjectId("4c85fdec145a9b0b340005a7") } on : shard0000 { "t" :3000, "i" : 1 }  
  17.                         { "files_id" : ObjectId("4c85fdec145a9b0b340005a7") } -->> { "files_id" : ObjectId("4c85fe08145a9b0b34000aaf") } on : shard0001 { "t" :3000, "i" : 4 }  
  18.                         { "files_id" : ObjectId("4c85fe08145a9b0b34000aaf") } -->> { "files_id" : ObjectId("4c85fe27145a9b0b34000fb7") } on : shard0001 { "t" :4000, "i" : 1 }  
  19.                         { "files_id" : ObjectId("4c85fe27145a9b0b34000fb7") } -->> { "files_id" : ObjectId("4c85fe43145a9b0b340014bf") } on : shard0000 { "t" :4000, "i" : 7 }  
  20.                         { "files_id" : ObjectId("4c85fe43145a9b0b340014bf") } -->> { "files_id" : ObjectId("4c85fe61145a9b0b340019c7") } on : shard0000 { "t" :4000, "i" : 8 }  
  21.                         { "files_id" : ObjectId("4c85fe61145a9b0b340019c7") } -->> { "files_id" : ObjectId("4c85fe7b145a9b0b34001ecf") } on : shard0000 { "t" :5000, "i" : 1 }  
  22.                         { "files_id" : ObjectId("4c85fe7b145a9b0b34001ecf") } -->> { "files_id" : ObjectId("4c85fe9a145a9b0b340023d7") } on : shard0001 { "t" :5000, "i" : 4 }  
  23.                         { "files_id" : ObjectId("4c85fe9a145a9b0b340023d7") } -->> { "files_id" : ObjectId("4c85feb7145a9b0b340028df") } on : shard0001 { "t" :6000, "i" : 1 }  
  24.                         { "files_id" : ObjectId("4c85feb7145a9b0b340028df") } -->> { "files_id" : ObjectId("4c85feea145a9b0b340032ef") } on : shard0000 { "t" :6000, "i" : 4 }  
  25.                         { "files_id" : ObjectId("4c85feea145a9b0b340032ef") } -->> { "files_id" : ObjectId("4c85ff25145a9b0b34003cff") } on : shard0000 { "t" :7000, "i" : 1 }  
  26.                         { "files_id" : ObjectId("4c85ff25145a9b0b34003cff") } -->> { "files_id" : ObjectId("4c85ff57145a9b0b3400470f") } on : shard0001 { "t" :7000, "i" : 4 }  
  27.                         { "files_id" : ObjectId("4c85ff57145a9b0b3400470f") } -->> { "files_id" : ObjectId("4c85ff87145a9b0b3400511f") } on : shard0001 { "t" :8000, "i" : 1 }  
  28.                         { "files_id" : ObjectId("4c85ff87145a9b0b3400511f") } -->> { "files_id" : ObjectId("4c85ffcd145a9b0b34005b2f") } on : shard0000 { "t" :8000, "i" : 16 }  
  29.                         { "files_id" : ObjectId("4c85ffcd145a9b0b34005b2f") } -->> { "files_id" : ObjectId("4c85fff7145a9b0b3400653f") } on : shard0000 { "t" :8000, "i" : 17 }  
  30.                         { "files_id" : ObjectId("4c85fff7145a9b0b3400653f") } -->> { "files_id" : ObjectId("4c860021145a9b0b34006f4f") } on : shard0000 { "t" :8000, "i" : 18 }  
  31.                         { "files_id" : ObjectId("4c860021145a9b0b34006f4f") } -->> { "files_id" : ObjectId("4c86004f145a9b0b3400795f") } on : shard0000 { "t" :8000, "i" : 19 }  
  32.                         { "files_id" : ObjectId("4c86004f145a9b0b3400795f") } -->> { "files_id" : ObjectId("4c860080145a9b0b3400836f") } on : shard0000 { "t" :9000, "i" : 1 }  
  33.                         { "files_id" : ObjectId("4c860080145a9b0b3400836f") } -->> { "files_id" : ObjectId("4c8600b5145a9b0b34008d7f") } on : shard0001 { "t" :9000, "i" : 7 }  
  34.                         { "files_id" : ObjectId("4c8600b5145a9b0b34008d7f") } -->> { "files_id" : ObjectId("4c860115145a9b0b3400a183") } on : shard0001 { "t" :9000, "i" : 8 }  
  35.                         { "files_id" : ObjectId("4c860115145a9b0b3400a183") } -->> { "files_id" : ObjectId("4c860198145a9b0b3400b587") } on : shard0001 { "t" :10000, "i" : 1 }  
  36.                         { "files_id" : ObjectId("4c860198145a9b0b3400b587") } -->> { "files_id" : ObjectId("4c8601fc145a9b0b3400c98b") } on : shard0000 { "t" :10000, "i" : 11 }  
  37.                         { "files_id" : ObjectId("4c8601fc145a9b0b3400c98b") } -->> { "files_id" : ObjectId("4c86025b145a9b0b3400dd8f") } on : shard0000 { "t" :10000, "i" : 12 }  
  38.                         { "files_id" : ObjectId("4c86025b145a9b0b3400dd8f") } -->> { "files_id" : ObjectId("4c8602ca145a9b0b3400f193") } on : shard0000 { "t" :10000, "i" : 13 }  
  39.                         { "files_id" : ObjectId("4c8602ca145a9b0b3400f193") } -->> { "files_id" : ObjectId("4c860330145a9b0b34010597") } on : shard0000 { "t" :10000, "i" : 14 }  
  40.                         { "files_id" : ObjectId("4c860330145a9b0b34010597") } -->> { "files_id" : { $maxKey : 1 } } on : shard0000 { "t" : 10000, "i" : 15 } 

當前,綜合比較,發現還是chunks的值要遠大于files集合所占用的磁盤空間(前者存儲文件二進制流信息,后者存儲結構化數據信息(如文件名稱大小等):

      

  磁盤信息比較    

    

  

下面是一個測試,用于讀寫shard0001(注意不是shard0000)上的圖片數據,因為mongos可以很好的管理sharding下各分區下的數據chunk,所以我們只要告訴它要取的文件名稱即可:)

比如要獲取"2010\09\07\2\2856090617370.gif6243"這個文件(帶日期型文件路徑只是一種格式,因為我們的產品會將上傳的附件放到相應磁盤目錄下,這種帶路徑的命名方式會方便與磁盤路徑進行對應),其目前位于shard0001中,我們只要通過下面html代碼即可獲取圖文件信息:      

  1. <img src="getfile.aspx?filename=2010\09\07\2\2856090617370.gif6243"  width="30" /> 

相應的getfile.aspx.cs 代碼參見如下:       

  1. public partial class getfile : System.Web.UI.Page  
  2.     {  
  3.  public Mongo Mongo { getset; }  
  4. public IMongoDatabase DB  
  5.         {  
  6.             get 
  7.             {  
  8.                 return this.Mongo["dnt_mongodb"];  
  9.             }  
  10.         }  
  11.  
  12.         /// <summary>  
  13. /// Sets up the test environment.  
  14. You can either override this OnInit to add custom initialization.  
  15.         /// </summary>  
  16.         public virtual void Init()  
  17.         {  
  18. string ConnectionString = "Server=10.0.4.85:27017;ConnectTimeout=30000;ConnectionLifetime=300000;
  19. MinimumPoolSize=512;MaximumPoolSize=51200;Pooled=true";  
  20. if (String.IsNullOrEmpty(ConnectionString))  
  21. throw new ArgumentNullException("Connection string not found.");  
  22.             this.Mongo = new Mongo(ConnectionString);  
  23.             this.Mongo.Connect();    
  24.         }   
  25.  
  26.         protected void Page_Load(object sender, EventArgs e)  
  27.         {  
  28.             if (!string.IsNullOrEmpty(Request.QueryString["filename"]))  
  29.             {  
  30.                 string filename = Request.QueryString["filename"];  
  31.                 Init();  
  32.                 String filesystem = "attach_gfstream";  
  33.  
  34.                 GridFile fs = new GridFile(DB, filesystem);  
  35.                 GridFileStream gfs = fs.OpenRead(filename);  
  36.  
  37.                 Byte[] buffer = new Byte[gfs.Length];  
  38.  
  39. //下面的Expires和Cache-Control設置主要用于squid反向加速
  40. 更多內容參見  http://www.cnblogs.com/daizhj/archive/2010/08/19/1803454.html  
  41.                 HttpContext.Current.Response.AddHeader("Expires", DateTime.Now.AddDays(20).ToString("r"));  
  42.                 HttpContext.Current.Response.AddHeader("Cache-Control""public");  
  43.     
  44.                 // 需要讀的數據長度  
  45.                 long dataToRead = gfs.Length;  
  46.                 int length;  
  47.                 while (dataToRead > 0)  
  48.                 {  
  49.                     // 檢查客戶端是否還處于連接狀態  
  50.                     if (HttpContext.Current.Response.IsClientConnected)  
  51.                     {  
  52.                         length = gfs.Read(buffer, 0, 10000);  
  53.                         HttpContext.Current.Response.OutputStream.Write(buffer, 0, length);  
  54.                         HttpContext.Current.Response.Flush();  
  55.                         buffer = new Byte[10000];  
  56.                         dataToRead = dataToRead - length;  
  57.                     }  
  58.                     else 
  59.                     {  
  60.                         // 如果不再連接則跳出死循環  
  61.                         dataToRead = -1;  
  62.                     }  
  63.                 }  
  64.                 gfs.Dispose();  
  65.                 this.Mongo.Disconnect();  
  66.                 HttpContext.Current.Response.End();           
  67.             }  
  68.         }  
  69.     } 

當然,上面只是對chunks進行sharding,如果要對files集合分片時,可以用下面命令行:            

  1. > db.runCommand( { shardcollection : "dnt_mongodb.attach_gfstream.files", key : { _id : 1 } } )    
  2. { "collectionsharded" : "dnt_mongodb.attach_gfstream.files", "ok" : 1 } 

在我添加了近50萬記錄后,mongos開始將新的文件信息保存到shard0001上,如下圖:

              

可以使用如下命令行來查看 shard上的信息:

  1. > db.printShardingStatus()  
  2.  .../省略之前files_id的shard信息  
  3.  { "filename" : { $minKey : 1 } } -->> { "filename" : "2010\\09\\08\\2\\1393993713076.gif1" } on : shard0000 { "t" : 1000, "i" : 6 }  
  4.  { "filename" : "2010\\09\\08\\2\\1393993713076.gif1" } -->> { "filename" : "2010\\09\\08\\2\\2396571814760.gif9999" } on : shard0000 { "t" : 1000, "i" : 7 }  
  5.  { "filename" : "2010\\09\\08\\2\\2396571814760.gif9999"} -->> { "filename" : "2010\\09\\08\\2\\2819270318096.gif25366" } on : shard0000 { "t" : 2000, "i" : 2 }  
  6.  { "filename" : "2010\\09\\08\\2\\2819270318096.gif25366" } -->> { "filename" : "2010\\09\\08\\2\\3100748419355.gif999" } on : shard0000{ "t" : 2000, "i" : 3 }  
  7.  { "filename" : "2010\\09\\08\\2\\3100748419355.gif999" } -->> { "filename" : { $maxKey : 1 } } on : shard0001 { "t" : 2000, "i" : 0 } 

下面是mongos上進行sharding時的信息:    

  1.  Wed Sep 08 17:25:44 [conn5] ns: dnt_mongodb.attach_gfstream.files ClusteredCursor::query ShardConnection had to change attempt: 0  
  2.      Wed Sep 08 17:32:34 [conn6] ns: dnt_mongodb.attach_gfstream.files ClusteredCursor::query ShardConnection had to change attempt: 0  
  3.      Wed Sep 08 17:38:49 [conn55] autosplitting dnt_mongodb.attach_gfstream.chunks size: 188884488 shard: ns:dnt_mongodb.attach_gfstream.chunks at: shard0001:10.0.4.85:27021 lastmod: 11|3 min: { files_id: ObjectId('4c8755b3145a9b16d41d5dc9') } m  
  4. ax: { files_id: MaxKey } on: { files_id: ObjectId('4c8759a5145a9b16d42300d7') }(splitThreshold 188743680)  
  5.      Wed Sep 08 17:38:49 [conn55] config change: { _id: "4_85-2010-09-08T09:38:49-10", server: "4_85", time: new Date(1283938729648), what: "split", ns: "dnt_mongodb.attach_gfstream.chunks", details: { before: { min: { files_id: ObjectId('4c8755  
  6. b3145a9b16d41d5dc9') }, max: { files_id: MaxKey } }, left: { min: { files_id: ObjectId('4c8755b3145a9b16d41d5dc9') }, max: { files_id: ObjectId('4c8759a5145a9b16d42300d7') } }, right: { min: { files_id: ObjectId('4c8759a5145a9b16d42300d7')  
  7. }, max: { files_id: MaxKey } } } }  
  8.      Wed Sep 08 17:38:49 [conn98] ns: dnt_mongodb.attach_gfstream.chunks ClusteredCursor::query ShardConnection had to change attempt: 0 

好了,今天的文章就先到這里了。

原文標題:基于Mongodb分布式存儲物理文件

鏈接:http://www.cnblogs.com/daizhj/archive/2010/09/08/1821481.html

【編輯推薦】

  1. MongoDB CEO談NoSQL的大數據量處理能力
  2. 拋棄關系數據庫 PHP程序員應了解MongoDB的五件事
  3. MongoDB,無模式文檔型數據庫簡介
  4. 關系數據庫的末日是否已經來臨
  5. 扔掉沉沒成本 嘗試關系數據庫替代品OODBMS  
責任編輯:彭凡 來源: 博客園
相關推薦

2025-05-16 08:58:47

Mongodb分布式存儲

2019-06-10 14:31:24

MySQL存儲數據庫

2012-05-10 10:49:41

MongoDB

2021-11-08 10:52:02

數據庫分布式技術

2011-03-18 08:51:23

MongoDB分布式文檔

2009-06-19 15:28:31

JDBC分布式事務

2023-09-11 11:22:22

分布式數據庫數據庫

2013-04-26 16:18:29

大數據全球技術峰會

2021-12-20 15:44:28

ShardingSph分布式數據庫開源

2023-03-26 12:43:31

數據庫KeyValue

2023-12-05 07:30:40

KlustronBa數據庫

2014-06-30 14:20:05

NoSQL數據庫

2018-01-02 20:00:28

數據庫MySQL分布式存儲

2017-10-17 08:33:31

存儲系統分布式

2023-08-22 13:16:00

分布式數據庫架構數據存儲

2009-12-31 09:51:59

BeansDB鍵值存儲

2024-03-11 08:57:02

國產數據庫證券

2023-11-14 08:24:59

性能Scylla系統架構

2017-07-18 09:51:36

文件存儲系統
點贊
收藏

51CTO技術棧公眾號

国产成人欧美在线观看| 亚洲精品国产免费| 99热都是精品| 精品人妻一区二区三区蜜桃| 亚洲国产91| 日韩精品久久久久久久玫瑰园| 男女视频一区二区三区| 美女免费久久| 成人午夜视频福利| 国产成人在线精品| 国产一二三四区| 五月激激激综合网色播| 欧美日韩情趣电影| 男人添女荫道口图片| 高清av在线| 高清av一区二区| 国产精品免费看久久久香蕉| 国产亚洲成人精品| 日本不卡电影| 日韩精品免费看| 亚洲综合123| 韩国成人动漫| 亚洲成人自拍一区| 午夜精品一区二区在线观看 | 成年人小视频在线观看| 欧美一区国产| 亚洲成人自拍偷拍| 日本黄色播放器| 男人的天堂在线免费视频| 国产精品一二三四五| 国产成人一区二区| 成年人免费看毛片| 欧美大片专区| 最近2019中文字幕一页二页| 右手影院亚洲欧美| 国产精品中文字幕制服诱惑| 91麻豆精品国产无毒不卡在线观看 | 99999精品| 51一区二区三区| 疯狂做受xxxx高潮欧美日本| 欧美大黑帍在线播放| 麻豆视频免费在线观看| 国产欧美日韩不卡| 久久亚洲精品欧美| 香蕉国产在线视频| 丰满白嫩尤物一区二区| 92国产精品视频| 亚洲一区中文字幕永久在线| 日韩一区欧美二区| 日本一区二区在线播放| 国产91精品一区| 中文亚洲字幕| 91av在线不卡| 欧美一二三区视频| 亚洲精品社区| 97免费中文视频在线观看| 欧美黄色一级网站| 日本在线播放一区| 触手亚洲一区二区三区| 国产日韩精品一区二区浪潮av| 欧美极品色图| 国产中文在线视频| 中文字幕第一页久久| 五月天久久狠狠| 欧美日韩在线看片| 亚洲欧洲韩国日本视频| 国产四区在线观看| 日韩av官网| 午夜精品在线看| 欧美成人高潮一二区在线看| 九色porny视频在线观看| 欧美日韩中文字幕| 欧美自拍小视频| 欧美综合影院| 日韩欧美成人激情| 特级西西人体4444xxxx| 亚洲涩涩av| 一区二区成人精品| 亚洲区一区二区三| 国内精品久久久久久久影视蜜臀| 久久久久中文字幕2018| 久久久久女人精品毛片九一 | 91国内在线播放| 久久九九精品视频| 精品国产第一区二区三区观看体验| 91传媒理伦片在线观看| 亚洲精品白浆高清| 深夜福利日韩在线看| 青娱乐在线视频免费观看| 99在线|亚洲一区二区| 国产不卡av在线| 97人妻精品一区二区三区软件 | xxxx日本黄色| 一本到12不卡视频在线dvd| 欧美激情免费看| 国产视频1区2区| 久久99精品久久久久久久久久久久 | 中国一级大黄大黄大色毛片| jizz一区二区三区| 欧美亚一区二区| 免费在线观看日韩av| 亚洲素人在线| 欧美日韩国产成人高清视频| jizz国产在线观看| 国产成人自拍网| 青青草原成人| av电影在线免费| 欧美日韩成人高清| 法国伦理少妇愉情| 亚洲精品国产成人影院| 日本乱人伦a精品| 国产成人麻豆精品午夜在线 | 黄色资源网久久资源365| 国产欧美日韩伦理| 成人在线观看亚洲| 色88888久久久久久影院按摩| 精品人妻一区二区三| 国产一区二区三区电影在线观看 | 日韩电影免费在线观看中文字幕| 日本女人性生活视频| 亚洲欧美日韩国产| 国产91aaa| 成人在线观看免费网站| 欧洲视频一区二区| mm131美女视频| 伊人蜜桃色噜噜激情综合| 91精品国产综合久久香蕉922| 男人天堂网在线| 精品久久久久久国产| xxx中文字幕| 欧美残忍xxxx极端| 国产91免费观看| 亚洲欧洲视频在线观看| 亚洲午夜视频在线观看| 最新av免费在线观看| 欧美一级本道电影免费专区| 日本精品视频在线观看| 日漫免费在线观看网站| 图片区小说区区亚洲影院| 色黄视频免费看| 久久美女视频| 国产精品美女久久久久久免费| 色综合成人av| 欧美日韩中文在线| 欧美 变态 另类 人妖| 一区在线播放| 国产精品夜夜夜一区二区三区尤| 日本理论片午伦夜理片在线观看| 日韩欧美国产1| 久久精品女人毛片国产| 岛国一区二区在线观看| 欧美黑人在线观看| 成人香蕉社区| 97精品视频在线观看| 熟妇高潮一区二区高潮| 五月综合激情日本mⅴ| 国产精品麻豆入口| 亚洲一区二区动漫| 青青草国产精品| 91亚洲视频| 日韩有码在线观看| 99产精品成人啪免费网站| 亚洲男人电影天堂| 久久久久国产免费| 一区二区日本视频| 蜜桃精品久久久久久久免费影院 | 免费av网站在线看| 91精品欧美福利在线观看| 欧美日韩三级在线观看| 成人免费看黄yyy456| 男人日女人逼逼| 国产精品一区二区三区av麻| 国产精品自产拍在线观| 国产在线高清视频| 精品久久人人做人人爽| 中文字幕日韩一级| 国产日韩影视精品| 香蕉视频xxxx| 国产精品试看| 一本久道久久综合| 成人看片爽爽爽| 国产精品久久久999| 顶级网黄在线播放| 亚洲精品国产电影| 最新中文字幕第一页| 亚洲精品水蜜桃| 成人影视免费观看| 久久99久久精品欧美| 97超碰在线人人| 国产熟女精品视频| 日本福利在线| 欧美精品高清视频| 免费看一级一片| av资源站一区| 男女男精品视频站| 欧美激情五月| 欧美精品v日韩精品v国产精品| 日韩av电影资源网| 九九热99久久久国产盗摄| 亚洲欧美综合一区二区| 欧美久久婷婷综合色| 日韩三级免费看| 国产精品久久毛片av大全日韩| 欧美夫妇交换xxx| 人妖欧美一区二区| 国产二区视频在线| 天天综合网网欲色| 欧美人与物videos另类| 精品国产乱码一区二区三区| 日本亚洲精品在线观看| 国产网红在线观看| 中文字幕欧美日韩精品| 日韩一级免费毛片| 91精品国产91久久综合桃花| 日本中文字幕久久| 亚洲高清免费观看| 午夜精品一区二区三级视频| 久久久久久久综合日本| 韩国av中国字幕| 久久99国产精品麻豆| 人妻内射一区二区在线视频| 欧美精品18| 国产高清免费在线| 精品久久视频| 欧美二级三级| 精品国产导航| 91久久久一线二线三线品牌| 日韩电影精品| 国产成人欧美在线观看| 在线免费日韩片| 97在线观看免费| 欧美1234区| 久久99热精品这里久久精品| 黄色一级片在线观看| 在线观看欧美www| 看电影就来5566av视频在线播放| 亚洲激情中文字幕| 欧美 日韩 综合| 精品国产一区二区国模嫣然| 午夜精品久久久久久久99| 欧美一区二区性放荡片| 在线观看亚洲一区二区| 在线看国产一区二区| 国产精品suv一区| 一本色道久久综合亚洲aⅴ蜜桃| 日韩无码精品一区二区三区| 亚洲高清免费视频| 日韩女优在线观看| 五月天精品一区二区三区| 青青操免费在线视频| 欧美日韩国产一区在线| 国产精品午夜影院| 天天av天天翘天天综合网色鬼国产| 国产精品9191| 午夜精品一区二区三区免费视频| 日韩三级一区二区三区| 午夜婷婷国产麻豆精品| 色婷婷av国产精品| 欧美日韩一区二区在线| 国产性生活视频| 欧美色视频在线| 国产一区二区自拍视频| 91精品黄色片免费大全| 国产激情无套内精对白视频| 精品乱码亚洲一区二区不卡| 国产刺激高潮av| 亚洲精品视频网上网址在线观看| 国内av一区二区三区| 一区二区福利视频| 成人在线免费看黄| 国内精品久久久久伊人av| 黄频免费在线观看| 国产成人精品免费视频| 亚洲成人精品综合在线| 99re在线国产| 欧美激情15p| 性欧美精品一区二区三区在线播放 | 国产精品久久久久久久久久三级| 91九色综合| 99在线免费观看视频| 色爱av综合网| 亚洲一区二区三区四区中文| 亚洲国产一成人久久精品| 男女日批视频在线观看| 老司机久久99久久精品播放免费| 国产原创精品在线| 懂色av中文一区二区三区| 草草地址线路①屁屁影院成人| 欧美高清在线视频| 永久看片925tv| 日韩欧美亚洲成人| 国产美女免费视频| 亚洲精品国产欧美| 久操免费在线| 欧美做受高潮1| 国产精久久久| 欧美日韩高清在线一区| 影音先锋成人在线电影| 亚洲乱码中文字幕久久孕妇黑人| 久久99久久精品| 人妻丰满熟妇av无码久久洗澡 | 国产第一页在线播放| 欧洲精品在线观看| 日本美女一级片| zzjj国产精品一区二区| 欧美激情网站| 99精品国产一区二区| 精品视频日韩| 国产黄页在线观看| 国产综合成人久久大片91| 青青草福利视频| 亚洲综合免费观看高清完整版 | 日韩三级电影免费观看| 红桃视频国产精品| 中文字幕av不卡在线| 91蜜桃婷婷狠狠久久综合9色| 丝袜美腿小色网| 欧美亚洲愉拍一区二区| 西西人体44www大胆无码| 九九热精品视频在线播放| 国产原创一区| 欧美中日韩一区二区三区| 影音先锋亚洲精品| 精品人妻一区二区三| 国产精品素人一区二区| 午夜影院免费在线观看| 亚洲成人黄色网址| 欧美aaaaaaa| av观看久久| 欧美高清不卡| 红桃视频 国产| 日本一区二区综合亚洲| 69亚洲精品久久久蜜桃小说| 亚洲激情视频在线观看| 高端美女服务在线视频播放| 国产99午夜精品一区二区三区| 91精品成人| 欧美一级xxxx| 国产精品久久久久一区二区三区| 日日噜噜噜噜人人爽亚洲精品| 亚洲高清久久久久久| www在线看| 国产视频不卡| 亚洲激情专区| 久久久高清视频| 亚洲18女电影在线观看| 男人天堂综合网| 2018日韩中文字幕| 亚洲精品无吗| 男女曰b免费视频| 国产日韩精品视频一区| 在线播放精品视频| 中文字幕一区二区三区电影| 日韩在线电影| 7777在线视频| 风间由美性色一区二区三区| 日本视频免费在线| 日韩精品电影网| 怡红院成人在线| 亚洲精品一区二区三区蜜桃久| 美女脱光内衣内裤视频久久网站| 性少妇xx生活| 欧美一区二区三区人| 岛国成人毛片| 国产一区二区高清视频| 亚洲欧美日韩在线观看a三区| 亚洲黄色小说视频| 欧美久久一二三四区| 久草在线视频网站| 久久亚洲午夜电影| 美女mm1313爽爽久久久蜜臀| 男人操女人的视频网站| 欧美精品一区二区三区四区| 欧美动物xxx| 自拍另类欧美| 成人动漫中文字幕| 日本一本在线观看| 久久在精品线影院精品国产| 国产精伦一区二区三区| 无码精品国产一区二区三区免费| 国产精品午夜春色av| 精品久久久久久亚洲综合网站| 91国内产香蕉| 成人羞羞网站| 国产清纯白嫩初高中在线观看性色| 欧美日韩中文字幕在线| 欧美三级黄网| 精品视频免费观看| 蜜乳av一区二区| 九热这里只有精品| 亚洲天堂男人的天堂| 欧美a级大片在线| 午夜肉伦伦影院| 亚洲欧美激情视频在线观看一区二区三区| 风流老熟女一区二区三区| 国产成人一区二区三区| 欧美激情视频一区二区三区在线播放| 青青草视频播放| 制服丝袜日韩国产| 综合在线影院|