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

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

基于Mongodb分布式存儲(chǔ)物理文件

2023-06-23 14:40:21
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

在之前的文章中介紹了如何對(duì)關(guān)系型數(shù)據(jù)數(shù)據(jù)通過(guò)auto-sharding進(jìn)行分布式數(shù)據(jù)存儲(chǔ),今天介紹如何對(duì)物理文件(小文件,基本小于100K)進(jìn)行分布式存儲(chǔ)。

 接著看一下要配置的測(cè)試環(huán)境(與前一篇中類(lèi)似):

模擬2個(gè)shard服務(wù)和一個(gè)config服務(wù), 均運(yùn)行在10.0.4.85機(jī)器上,只是端口不同:

Shard1:27020
       Shard2:27021
       Config:27022

Mongos啟動(dòng)時(shí)默認(rèn)使用的27017端口

在C,D,E磁盤(pán)下分別建立如下文件夾:

mongodb/bin

mongodb/db

然后用CMDming令行依次打開(kāi)相應(yīng)文件夾下的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配置服務(wù)器)

啟動(dòng)mongos時(shí),默認(rèn)開(kāi)啟了27017端口

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

然后打開(kāi)mongo:

E:/mongodb/bin>mongo   回車(chē)  (有時(shí)加端口會(huì)造成下面的addshardming令出問(wèn)題)

> use admin
          switched to db admin
      > db.runCommand( { addshard : "10.0.4.85:27020", allowLocal : 1, maxSize:2 , minKey:1, maxKey:10} ) 

--添加sharding,maxsize單位是M,此處設(shè)置比較小的數(shù)值只為演示sharding效果

 { "shardAdded" : "shard0000", "ok" : 1 }
      > db.runCommand( { addshard : "10.0.4.85:27021", allowLocal : 1, minKey:1000} )
         { "shardAdded" : "shard0001", "ok" : 1 }     

注:如果要移除sharding,可用下面寫(xiě)法

db.runCommand( { removeshard : "localhost:10000" } );

> db.runCommand({listshards:1});   --查看shard節(jié)點(diǎn)列表

> config = connect("10.0.4.85:27022")
      > config = config.getSisterDB("config")
      > dnt_mongodb=db.getSisterDB("dnt_mongodb");
          dnt_mongodb
      > db.runCommand({enablesharding:"dnt_mongodb"})
          { "ok" : 1 }

> db.printShardingStatus()

--- Sharding Status ---
  sharding version: { "_id" : 1, "version" : 3 }
  shards:
      {
        "_id" : "shard0000",
        "host" : "10.0.4.85:27020",
        "maxSize" : NumberLong( 2 )
      }
      { "_id" : "shard0001", "host" : "10.0.4.85:27021" }
  databases:
        { "_id" : "admin", "partitioned" : false, "primary" : "config" }
        { "_id" : "dnt_mongodb", "partitioned" : true, "primary" : "shard0001" }
 
      > db.runCommand( { shardcollection : "dnt_mongodb.attach_gfstream.chunks", key : { files_id : 1 } } )  --此處與之前的數(shù)據(jù)存儲(chǔ)方式有些不同,目前shard似乎僅支持files_id
       { "collectionsharded" : "dnt_mongodb.attach_gfstream.chunks", "ok" : 1 }
      
       注:運(yùn)行上面ming令之前需要設(shè)置files_id為唯一索引[unique index]。        
       
       創(chuàng)建完sharding和設(shè)置相應(yīng)信息后,我們加載一下測(cè)試數(shù)據(jù),我用下面代碼來(lái)讀取要本地文件,然后批量向mongodb中添加(通過(guò)循環(huán)修改文件名來(lái)添加相同大小的文件)。       
        
 
/// <summary>
        /// 上傳文件到mongodb
        
/// </summary>
        /// <param name="uploadDir">要上傳文件所在路徑</param>
        /// <param name="fileName">要上傳的文件名</param>
        /// <returns></returns>
        public bool UploadFile(string uploadDir, string fileName)
        {
            
for (int i = 1; i < 10000; i++)
            {
                
try
                {
                    Mongo mongo 
= mongoDB;
                    mongo.Connect();
                    IMongoDatabase DB 
= mongo["dnt_mongodb"];

                    
using (FileStream fileStream = new FileStream(uploadDir + fileName, FileMode.Open))
                    {
                        
int nFileLen = (int)fileStream.Length;

                        
byte[] myData = new Byte[nFileLen];
                        fileStream.Read(myData, 
0, nFileLen);

                        GridFile fs 
= new GridFile(DB, "attach_gfstream");
                        
using (GridFileStream gfs = fs.Create(fileName + i))
                        {
                            gfs.Write(myData, 
0, nFileLen);
                        }
                    }
                    mongo.Disconnect();
                }
                
catch { }                
            }
            
return true;
        }

        
        在批量添加約10000次(約10000個(gè)文件)之后,mongodb開(kāi)始把sharding出來(lái)的chunk從shard0000分布到shard0001上,我們可以用下面指令來(lái)進(jìn)行驗(yàn)證:       
      
       > db.printShardingStatus()

 
--- Sharding Status ---
  sharding version: { "_id" : 1, "version" : 3 }
  shards:
      {
        "_id" : "shard0000",
        "host" : "10.0.4.85:27020",
        "maxSize" : NumberLong( 2 )
      }
      { "_id" : "shard0001", "host" : "10.0.4.85:27021" }
  databases:
        { "_id" : "admin", "partitioned" : false, "primary" : "config" }
        { "_id" : "dnt_mongodb", "partitioned" : true, "primary" : "shard0000" }

                dnt_mongodb.attach_gfstream.chunks chunks:
                        { "files_id" : { $minKey : 1 } } -->> { "files_id" : ObjectId("4c85fd02145a9b1534010d89") } on : shard0001 { "t" : 2000, "i" : 0 }
                        { "files_id" : ObjectId("4c85fd02145a9b1534010d89") } -->> { "files_id" : ObjectId("4c85fdec145a9b0b340005a7") } on : shard0000 { "t" :3000, "i" : 1 }
                        { "files_id" : ObjectId("4c85fdec145a9b0b340005a7") } -->> { "files_id" : ObjectId("4c85fe08145a9b0b34000aaf") } on : shard0001 { "t" :3000, "i" : 4 }
                        { "files_id" : ObjectId("4c85fe08145a9b0b34000aaf") } -->> { "files_id" : ObjectId("4c85fe27145a9b0b34000fb7") } on : shard0001 { "t" :4000, "i" : 1 }
                        { "files_id" : ObjectId("4c85fe27145a9b0b34000fb7") } -->> { "files_id" : ObjectId("4c85fe43145a9b0b340014bf") } on : shard0000 { "t" :4000, "i" : 7 }
                        { "files_id" : ObjectId("4c85fe43145a9b0b340014bf") } -->> { "files_id" : ObjectId("4c85fe61145a9b0b340019c7") } on : shard0000 { "t" :4000, "i" : 8 }
                        { "files_id" : ObjectId("4c85fe61145a9b0b340019c7") } -->> { "files_id" : ObjectId("4c85fe7b145a9b0b34001ecf") } on : shard0000 { "t" :5000, "i" : 1 }
                        { "files_id" : ObjectId("4c85fe7b145a9b0b34001ecf") } -->> { "files_id" : ObjectId("4c85fe9a145a9b0b340023d7") } on : shard0001 { "t" :5000, "i" : 4 }
                        { "files_id" : ObjectId("4c85fe9a145a9b0b340023d7") } -->> { "files_id" : ObjectId("4c85feb7145a9b0b340028df") } on : shard0001 { "t" :6000, "i" : 1 }
                        { "files_id" : ObjectId("4c85feb7145a9b0b340028df") } -->> { "files_id" : ObjectId("4c85feea145a9b0b340032ef") } on : shard0000 { "t" :6000, "i" : 4 }
                        { "files_id" : ObjectId("4c85feea145a9b0b340032ef") } -->> { "files_id" : ObjectId("4c85ff25145a9b0b34003cff") } on : shard0000 { "t" :7000, "i" : 1 }
                        { "files_id" : ObjectId("4c85ff25145a9b0b34003cff") } -->> { "files_id" : ObjectId("4c85ff57145a9b0b3400470f") } on : shard0001 { "t" :7000, "i" : 4 }
                        { "files_id" : ObjectId("4c85ff57145a9b0b3400470f") } -->> { "files_id" : ObjectId("4c85ff87145a9b0b3400511f") } on : shard0001 { "t" :8000, "i" : 1 }
                        { "files_id" : ObjectId("4c85ff87145a9b0b3400511f") } -->> { "files_id" : ObjectId("4c85ffcd145a9b0b34005b2f") } on : shard0000 { "t" :8000, "i" : 16 }
                        { "files_id" : ObjectId("4c85ffcd145a9b0b34005b2f") } -->> { "files_id" : ObjectId("4c85fff7145a9b0b3400653f") } on : shard0000 { "t" :8000, "i" : 17 }
                        { "files_id" : ObjectId("4c85fff7145a9b0b3400653f") } -->> { "files_id" : ObjectId("4c860021145a9b0b34006f4f") } on : shard0000 { "t" :8000, "i" : 18 }
                        { "files_id" : ObjectId("4c860021145a9b0b34006f4f") } -->> { "files_id" : ObjectId("4c86004f145a9b0b3400795f") } on : shard0000 { "t" :8000, "i" : 19 }
                        { "files_id" : ObjectId("4c86004f145a9b0b3400795f") } -->> { "files_id" : ObjectId("4c860080145a9b0b3400836f") } on : shard0000 { "t" :9000, "i" : 1 }
                        { "files_id" : ObjectId("4c860080145a9b0b3400836f") } -->> { "files_id" : ObjectId("4c8600b5145a9b0b34008d7f") } on : shard0001 { "t" :9000, "i" : 7 }
                        { "files_id" : ObjectId("4c8600b5145a9b0b34008d7f") } -->> { "files_id" : ObjectId("4c860115145a9b0b3400a183") } on : shard0001 { "t" :9000, "i" : 8 }
                        { "files_id" : ObjectId("4c860115145a9b0b3400a183") } -->> { "files_id" : ObjectId("4c860198145a9b0b3400b587") } on : shard0001 { "t" :10000, "i" : 1 }
                        { "files_id" : ObjectId("4c860198145a9b0b3400b587") } -->> { "files_id" : ObjectId("4c8601fc145a9b0b3400c98b") } on : shard0000 { "t" :10000, "i" : 11 }
                        { "files_id" : ObjectId("4c8601fc145a9b0b3400c98b") } -->> { "files_id" : ObjectId("4c86025b145a9b0b3400dd8f") } on : shard0000 { "t" :10000, "i" : 12 }
                        { "files_id" : ObjectId("4c86025b145a9b0b3400dd8f") } -->> { "files_id" : ObjectId("4c8602ca145a9b0b3400f193") } on : shard0000 { "t" :10000, "i" : 13 }
                        { "files_id" : ObjectId("4c8602ca145a9b0b3400f193") } -->> { "files_id" : ObjectId("4c860330145a9b0b34010597") } on : shard0000 { "t" :10000, "i" : 14 }
                        { "files_id" : ObjectId("4c860330145a9b0b34010597") } -->> { "files_id" : { $maxKey : 1 } } on : shard0000 { "t" : 10000, "i" : 15 }

  
      當(dāng)前,綜合比較,發(fā)現(xiàn)還是chunks的值要遠(yuǎn)大于files集合所占用的磁盤(pán)空間(前者存儲(chǔ)文件二進(jìn)制流信息,后者存儲(chǔ)結(jié)構(gòu)化數(shù)據(jù)信息(如文件名稱(chēng)大小等):
      
      

    
  
     

      下面是一個(gè)測(cè)試,用于讀寫(xiě)shard0001(注意不是shard0000)上的圖片數(shù)據(jù),因?yàn)閙ongos可以很好的管理sharding下各分區(qū)下的數(shù)據(jù)chunk,所以我們只要告訴它要取的文件名稱(chēng)即可:)
     
      比如要獲取"2010/09/07/2/2856090617370.gif6243"這個(gè)文件(帶日期型文件路徑只是一種格式,因?yàn)槲覀兊漠a(chǎn)品會(huì)將上傳的附件放到相應(yīng)磁盤(pán)目錄下,這種帶路徑的命名方式會(huì)方便與磁盤(pán)路徑進(jìn)行對(duì)應(yīng)),其目前位于shard0001中,我們只要通過(guò)下面html代碼即可獲取圖文件信息:      
      

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

       
      相應(yīng)的getfile.aspx.cs 代碼參見(jiàn)如下:       
    

 
public partial class getfile : System.Web.UI.Page
    {

        
public Mongo Mongo { getset; }

        
public IMongoDatabase DB
        {
            
get
            {
                
return this.Mongo["dnt_mongodb"];
            }
        }

        
/// <summary>
        /// Sets up the test environment.  You can either override this OnInit to add custom initialization.
        
/// </summary>
        public virtual void Init()
        {
            
string ConnectionString = "Server=10.0.4.85:27017;ConnectTimeout=30000;ConnectionLifetime=300000;MinimumPoolSize=512;MaximumPoolSize=51200;Pooled=true";
            
if (String.IsNullOrEmpty(ConnectionString))
                
throw new ArgumentNullException("Connection string not found.");
            
this.Mongo = new Mongo(ConnectionString);
            
this.Mongo.Connect();         
        }        

        
protected void Page_Load(object sender, EventArgs e)
        {
            
if (!string.IsNullOrEmpty(Request.QueryString["filename"]))
            {
                
string filename = Request.QueryString["filename"];
                Init();
                String filesystem 
= "attach_gfstream";

                GridFile fs 
= new GridFile(DB, filesystem);
                GridFileStream gfs 
= fs.OpenRead(filename);

                Byte[] buffer 
= new Byte[gfs.Length];

                
//下面的Expires和Cache-Control設(shè)置主要用于squid反向加速,更多內(nèi)容參見(jiàn)  http://www.cnblogs.com/daizhj/archive/2010/08/19/1803454.html
                HttpContext.Current.Response.AddHeader("Expires", DateTime.Now.AddDays(20).ToString("r"));
                HttpContext.Current.Response.AddHeader(
"Cache-Control""public");
         
                
// 需要讀的數(shù)據(jù)長(zhǎng)度
                long dataToRead = gfs.Length;
                
int length;
                
while (dataToRead > 0)
                {
                    
// 檢查客戶(hù)端是否還處于連接狀態(tài)
                    if (HttpContext.Current.Response.IsClientConnected)
                    {
                        length 
= gfs.Read(buffer, 010000);
                        HttpContext.Current.Response.OutputStream.Write(buffer, 
0, length);
                        HttpContext.Current.Response.Flush();
                        buffer 
= new Byte[10000];
                        dataToRead 
= dataToRead - length;
                    }
                    
else
                    {
                        
// 如果不再連接則跳出死循環(huán)
                        dataToRead = -1;
                    }
                }
                gfs.Dispose();
                
this.Mongo.Disconnect();
                HttpContext.Current.Response.End();                
            }
        }
    }

      
      
     當(dāng)然,上面只是對(duì)chunks進(jìn)行sharding,如果要對(duì)files集合分片時(shí),可以用下面ming令行:            
     > db.runCommand( { shardcollection : "dnt_mongodb.attach_gfstream.files", key : { _id : 1 } } ) 
    
     { "collectionsharded" : "dnt_mongodb.attach_gfstream.files", "ok" : 1 }
     
     在我添加了近50萬(wàn)記錄后,mongos開(kāi)始將新的文件信息保存到shard0001上,如下圖:

   

  可以使用如下ming令行來(lái)查看 shard上的信息:

    > db.printShardingStatus()

       .../省略之前files_id的shard信息

 
              { "filename" : { $minKey : 1 } } -->> { "filename" : "2010//09//08//2//1393993713076.gif1" } on : shard0000 { "t" : 1000, "i" : 6 }
              { "filename" : "2010//09//08//2//1393993713076.gif1" } -->> { "filename" : "2010//09//08//2//2396571814760.gif9999" } on : shard0000 { "t" : 1000, "i" : 7 }
              { "filename" : "2010//09//08//2//2396571814760.gif9999"} -->> { "filename" : "2010//09//08//2//2819270318096.gif25366" } on : shard0000 { "t" : 2000, "i" : 2 }
              { "filename" : "2010//09//08//2//2819270318096.gif25366" } -->> { "filename" : "2010//09//08//2//3100748419355.gif999" } on : shard0000{ "t" : 2000, "i" : 3 }
             { "filename" : "2010//09//08//2//3100748419355.gif999" } -->> { "filename" : { $maxKey : 1 } } on : shard0001 { "t" : 2000, "i" : 0 }

     下面是mongos上進(jìn)行sharding時(shí)的信息:

     Wed Sep 08 17:25:44 [conn5] ns: dnt_mongodb.attach_gfstream.files ClusteredCursor::query ShardConnection had to change attempt: 0
     Wed Sep 08 17:32:34 [conn6] ns: dnt_mongodb.attach_gfstream.files ClusteredCursor::query ShardConnection had to change attempt: 0
     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
ax: { files_id: MaxKey } on: { files_id: ObjectId('4c8759a5145a9b16d42300d7') }(splitThreshold 188743680)
     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
b3145a9b16d41d5dc9') }, max: { files_id: MaxKey } }, left: { min: { files_id: ObjectId('4c8755b3145a9b16d41d5dc9') }, max: { files_id: ObjectId('4c8759a5145a9b16d42300d7') } }, right: { min: { files_id: ObjectId('4c8759a5145a9b16d42300d7')
}, max: { files_id: MaxKey } } } }
     Wed Sep 08 17:38:49 [conn98] ns: dnt_mongodb.attach_gfstream.chunks ClusteredCursor::query ShardConnection had to change attempt: 0

如果訪(fǎng)問(wèn)的圖片分別位于shard0000和shard0001時(shí),mongos會(huì)自行將請(qǐng)求調(diào)度到相應(yīng)sharding上,比如下面的鏈接文件分別指定shard000和shard0001:

<img src="getfile.aspx?filename=2010/09/08/2/1393993713076.gif5"  width="30" /> 位于shard0000

<img src="getfile.aspx?filename=2010/09/08/2/3197962515515.gif9"  width="30" /> 位于shard0001

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

發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
zjzjzjzjzj亚洲女人| 国产婷婷97碰碰久久人人蜜臀| 日韩欧美国产一区二区| 日韩在线一区二区三区四区| 92国产精品观看| 91一区二区三区| 日本v片在线高清不卡在线观看| 国产精品久久久久久久久久三级| 色综合久久九月婷婷色综合| 一本久久a久久精品亚洲| 日韩亚洲欧美视频| 日韩在线观看电影完整版高清免费悬疑悬疑| 99久久一区三区四区免费| 狠狠综合久久久综合| 五月婷婷综合网| 亚洲国产精品久久人人爱潘金莲| 日韩视频在线一区二区| 亚洲午夜在线观看| 国产经典中年夫妇盗摄| 欧美精品一卡两卡| 野外性xxxxfreexxxxx欧美| 黄色的网站免费| 国产丝袜高跟一区| 97视频在线看| 精品毛片乱码1区2区3区| 麻豆久久精品| 国产91免费看片| 亚洲成av人影院在线观看网| 精品欧美久久| 日本性爱视频在线观看| 国产v综合ⅴ日韩v欧美大片| 香港一级纯黄大片| 五月天激情小说综合| 久久99精品国产麻豆不卡| 强迫凌虐淫辱の牝奴在线观看| 国产熟妇久久777777| 欧美精品三级| 亚洲三级欧美| 日韩中文字幕免费观看| 国产**成人网毛片九色| 国产喷水在线观看| 97超碰最新| 亚洲欧美自偷自拍另类| 欧美私密网站| 最新二区三区av| 亚洲精品中文字幕在线观看| 国内精品卡一卡二卡三新区| 午夜精品久久久久久久99樱桃| 国产欧美一区二区三区四区| 欧美老女人性生活| 最新国产成人在线观看| 欧美日韩国产三级| 欧美亚洲一区在线| 亚洲成av人片一区二区梦乃| 国产精品视频免费一区二区三区| 一区二区三区 在线观看视| 国产精品区在线观看| 亚洲一区激情| 天天综合色天天综合色hd| 免费在线观看a级片| 妺妺窝人体色www在线小说| 一区二区三区中文字幕精品精品| 国产精品久久久久婷婷二区次| 激情综合亚洲| 欧美大香线蕉线伊人久久| www.免费av| 欧美色手机在线观看| 色视频免费在线观看| 日本电影欧美片| 美女写真理伦片在线看| 日韩最新av| 国产一区二区三区不卡在线观看| 国产区二精品视| 国产精品无码一区二区三| 久久男女视频| 男人添女荫道口喷水视频| 色偷偷偷亚洲综合网另类| 97在线视频一区| 久久香蕉综合色一综合色88| 国产精品视频网站| 91成人福利视频| 久久九九免费| 欧美疯狂性受xxxxx另类| 欧美日韩亚洲一区二| 麻豆系列在线观看| 久久综合欧美| 黄色91av| 国产丝袜美腿一区二区三区| 91网站免费视频| 国产性色av一区二区| av大片在线播放| 波多野结衣av一区二区全免费观看| 亚洲精品福利网站| 亚洲美女黄网| 亚洲欧美日本一区二区三区| 中文字幕一区二区三区中文字幕| 野花视频免费在线观看| 亚洲精品在线观看网站| 国产精品久久久久久9999| 天天堂资源网在线观看免费视频| 999www人成免费视频| wwwav在线| 高清一区二区三区四区五区| 国产一区二区电影在线观看| 国产一精品一aⅴ一免费| 国产97色在线 | 日韩| 国产中文字幕精品| av免费观看网| 好吊的妞视频这里都有| 台湾佬中文娱乐网欧美电影| 欧美日韩国产精品一区二区三区| 国产精品麻豆久久| 在线看日韩av| 四虎4hu永久免费入口| 日本在线观看不卡视频| 免费污网站在线观看| 亚洲1区2区3区视频| 污版网站在线观看| 亚洲免费资源| 国产精品久久中文| 免费三级在线观看| 精品一区二区电影| 日韩av大片站长工具| 日日摸.com| 国产精品香蕉国产| 国产精品久久久久7777按摩| www免费视频| www.国产在线观看| 岛国av一区二区在线在线观看| 777久久精品一区二区三区无码| 欧美精品一区二区高清在线观看| 男人天堂视频网| 成人中心免费视频| 99re在线视频这里只有精品| 成年女人免费毛片视频永久| 国产激情久久久久| 国产精品国产精品国产专区蜜臀ah| 91高跟黑色丝袜呻吟在线观看| 日本网站在线播放| 国产精品一区二区女厕厕| 久久精品99久久久香蕉| 国产绳艺sm调教室论坛| 亚洲人成网7777777国产| aaa一区二区三区| 好妞色妞国产在线视频| 国产一区一区三区| 亚洲国产欧美在线成人app| 亚洲美女视频| 日本女人性视频| 久久91成人| 狂野欧美激情性xxxx| 国产理论电影在线| 日韩av电影在线观看| 免费网站在线观看黄| 爱爱视频网站| 99精品桃花视频在线观看| 538国产精品一区二区免费视频| 激情五月色婷婷| 亚洲一级二级三级在线免费观看| 四季av一区二区三区| 亚洲一级在线观看| 日本欧美色综合网站免费| 就爱干草视频| 中文字幕av在线| 999精品网| 综合欧美国产视频二区| 亚洲欧美亚洲| av高清资源| 免费网站在线观看视频| 500福利第一精品导航| 尤物yw193can在线观看| 日本护士做爰视频| 国产在线视频不卡二| 亚洲国产成人porn| 91极品尤物在线播放国产| 国产亚洲欧美在线| 天天干视频在线| 在线观看日韩www视频免费| 尤物yw午夜国产精品视频明星| 91麻豆精品国产91久久久平台| 日韩久久一级片| 日韩电影二区| 一本色道久久88精品综合| 欧美精品一区二区成人| 北条麻妃在线观看视频| 免费在线观看日韩欧美| 久久久精品久久| 原纱央莉成人av片| 亚洲黄色视屏| av在线播放资源| 中文字幕av影院| 国产精品一区二区久久精品| 成人动漫视频| 99久久国产综合精品五月天喷水| 高清hd写真福利在线播放| 中文字幕一区免费在线观看| 国产麻豆精品一区二区| 一区二区三区中文字幕精品精品| 成人免费福利在线| 波多野洁衣一区| 麻豆网站在线| 大黑人xxx| 国产不卡视频在线播放| 成人av免费| 亚洲欧美日韩第一区| 国产精品网站在线观看| 性chinese极品按摩| 第四色婷婷基地| 亚洲精品一区二区| 成人免费视频网站| 中文字幕欧美日韩在线| 一本一道久久a久久精品蜜桃| 91肉色超薄丝袜脚交一区二区| 亚洲青涩在线| 日本在线视频一区二区| 欧美韩国日本不卡| 久久久成人的性感天堂| 一级香蕉视频在线观看| 成人国产精品日本在线| 国产精品无码免费专区午夜| 日本韩国欧美在线观看| 日韩精品中文字幕一区二区三区| 亚洲欧美日韩中文在线| 妺妺窝人体色www婷婷| 成人情趣视频网站| 亚洲无在线观看| 亚洲人成电影网站色…| 国产欧美日韩一区二区三区四区| 精品国产一区二区三区麻豆免费观看完整版| 亚洲精品第一区二区三区| 国产资源在线视频| 草视频在线观看| 久久er热在这里只有精品66| 久久精品亚洲无码| 国产精品视频免费看| chinesegaysextube| av免费在线观看网站| 99久久精品免费观看| 中韩乱幕日产无线码一区| 久久一区亚洲| 新久草在线视频| 久久久久久黄| 精品黑人一区二区三区国语馆| 亚洲欧美日韩精品久久| 中文乱码人妻一区二区三区视频| 91成人免费视频| 在线观看视频污| 四虎4545www国产精品| aa免费在线观看| japanese国产在线观看| 日韩国产激情在线| 欧美成年人视频网站欧美| 久久av一区二区三区| 在线观看免费电影| 91免费视频污| 啪啪一区二区三区| 色噜噜狠狠一区二区| 精东影业在线观看| 91精品国产自产| 亚洲欧美另类人妖| 欧美午夜精品久久久久久蜜| 91精品国产91久久久久久青草| 999久久久国产999久久久| 色啪啪.com| 国产精品久久久久久久久妇女| 欧美系列日韩一区| www.狠狠色.com| 中文字幕中文字幕在线中心一区| 欧美亚洲午夜视频在线观看| 视频在线99re| 国产精品国产精品国产专区| 日韩黄色在线免费观看| 日韩在线视频免费观看高清中文| 久久久天天操| 国产精品日韩一区二区| 国产日韩欧美在线一区| 日韩乱码人妻无码中文字幕| 国产鲁鲁视频在线观看特色| 国产精品最新自拍| 天天精品视频| 亚洲播播91| 国产欧美精品久久久| 亚洲天堂黄色| 黄黄的网站在线观看| 丝袜美腿诱惑一区二区三区| 欧美三级不卡| 中文字幕欧美亚洲| 小说区图片区综合久久88| 开心激情综合网| 男女污污的视频| 波多野结衣作品集| 国产一级片免费视频| 久久看人人摘| 97超级碰碰碰久久久| 麻豆精品国产91久久久久久| 免费a级毛片在线观看| 欧美日韩久久久久久| 欧美色综合网站| 蜜桃网站成人| 久久精品国产精品亚洲红杏| 国产欧美久久久精品免费| 九色91偷拍| 日韩经典中文字幕一区| 99热在线精品观看| 国产精品爽爽久久久久久| 日本中文字幕在线2020| 我想看黄色大片| 亚洲精品一区在线观看香蕉| 久久久久久久97| 亚洲va欧美va国产综合剧情| 国产精品视频在线播放| 亚洲成人18| jizz视频播放器| 国产精品视频yy9299一区| 国产毛片在线看| 永久免费成人代码| 久久久久久久久久久91| 五月婷婷六月综合| 一区二区在线免费播放| 国产精品久久久久久久久久久久| 高清av不卡| 欧美激情啊啊啊| 亚洲综合在线一区| 91影院成人| 俺也去精品视频在线观看| 亚洲欧洲中文日韩久久av乱码| 欧美三级一级片| 另类图片综合电影|