婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Docker 搭建集群MongoDB的實(shí)現(xiàn)步驟

Docker 搭建集群MongoDB的實(shí)現(xiàn)步驟

熱門標(biāo)簽:江蘇自動外呼系統(tǒng)一般多少錢 信貸電銷機(jī)器人系統(tǒng) 400 電話 申請費(fèi)用 山東電信外呼系統(tǒng)靠譜嗎 長沙回?fù)芡夂粝到y(tǒng) 鸚鵡螺號航海地圖標(biāo)注時間 ai電話機(jī)器人營銷 比較穩(wěn)定的外呼系統(tǒng) 云南云電銷機(jī)器人招商

前言

由于公司業(yè)務(wù)需要,我們打算自己搭建 MongoDB 的服務(wù),因為 MongoDB 的云數(shù)據(jù)庫好貴,我們這次采用副本集的方式來搭建集群,三臺服務(wù)器,一主、一副、一仲裁

基本概念

Replica Set 副本集:一個副本集就是一組 MongoDB 實(shí)例組成的集群,由一個主(Primary)服務(wù)器和多個備份(Secondary)服務(wù)器構(gòu)成

  • 主節(jié)點(diǎn)(master):主節(jié)點(diǎn)接收所有寫入操作。主節(jié)點(diǎn)將對其數(shù)據(jù)集所做的所有更改記錄到其 oplog。
  • 副節(jié)點(diǎn)(secondary):復(fù)制主節(jié)點(diǎn)的 oplog 并將操作應(yīng)用到其數(shù)據(jù)集,如果主節(jié)點(diǎn)不可用,一個合格的副節(jié)點(diǎn)將被選為新的主節(jié)點(diǎn)。
  • 仲裁節(jié)點(diǎn)(arbiter):負(fù)載選舉,當(dāng)主節(jié)點(diǎn)不可用,它將從副節(jié)點(diǎn)中選一個作為主節(jié)點(diǎn)。

Sharding 分片:

Master-slave 主備

  • MongoDB 4.0 以上版本運(yùn)行時提示:[main] Master/slave replication is no longer supported,也就是 MongoDB 4.0 后不在支持主從復(fù)制

一、環(huán)境準(zhǔn)備

使用 CentOS 7.6 64bit 系統(tǒng),安裝 Docker、Docker-compose、Docker-Swarm

二、生成 KeyFile

  • MongoDB 使用 KeyFile 認(rèn)證,副本集中的每個 MongoDB 實(shí)例使用 KeyFile 內(nèi)容作為認(rèn)證其他成員的共享密碼。MongoDB 實(shí)例只有擁有正確的 KeyFile 才可以加入副本集。
  • keyFile 的內(nèi)容必須是 6 到 1024 個字符的長度,且副本集所有成員的 KeyFile 內(nèi)容必須相同。
  • 有一點(diǎn)要注意是的:在 UNIX 系統(tǒng)中,KeyFile 必須沒有組權(quán)限或完全權(quán)限(也就是權(quán)限要設(shè)置成 X00 的形式)。Windows 系統(tǒng)中,keyFile 權(quán)限沒有被檢查。
  • 可以使用任意方法生成 keyFile。例如,如下操作使用 openssl 生成復(fù)雜的隨機(jī)的 1024 個字符串。然后使用 chmod 修改文件權(quán)限,只給文件擁有者提供讀權(quán)限。
  • 這是 MongoDB 官方推薦 keyFile 的生成方式:
# 400權(quán)限是要保證安全性,否則mongod啟動會報錯
openssl rand -base64 756 > mongodb.key
chmod 400 mongodb.key

二、創(chuàng)建跨主機(jī)網(wǎng)絡(luò)

搭建集群我們肯定是跨主機(jī)通訊,要搭建 Overlay Network 網(wǎng)絡(luò),我們就要用到 Docker Swarm 這個工具了。Docker Swarm 是 Docker 內(nèi)置的集群工具,它能夠幫助我們更輕松地將服務(wù)部署到 Docker daemon 的集群之中。

既然要將 Docker 加入到集群,我們就必須先有一個集群,我們在任意一個 Docker 實(shí)例上都可以通過 docker swarm init 來初始化集群。

$ sudo docker swarm init

Swarm initialized: current node (t4ydh2o5mwp5io2netepcauyl) is now a manager.

To add a worker to this swarm, run the following command:

  docker swarm join --token SWMTKN-1-4dvxvx4n7magy5zh0g0de0xoues9azekw308jlv6hlvqwpriwy-cb43z26n5jbadk024tx0cqz5r 192.168.1.5:2377

在集群初始化后,這個 Docker 實(shí)例就自動成為了集群的管理節(jié)點(diǎn),而其他 Docker 實(shí)例可以通過運(yùn)行這里所打印的 docker swarm join 命令來加入集群。

加入到集群的節(jié)點(diǎn)默認(rèn)為普通節(jié)點(diǎn),如果要以管理節(jié)點(diǎn)的身份加入到集群中,我們可以通過 docker swarm join-token 命令來獲得管理節(jié)點(diǎn)的加入命令。

$ sudo docker swarm join-token manager
To add a manager to this swarm, run the following command:

  docker swarm join --token SWMTKN-1-60am9y6axwot0angn1e5inxrpzrj5d6aa91gx72f8et94wztm1-7lz0dth35wywekjd1qn30jtes 192.168.1.5:2377

我們通過這些命令來建立用于我們服務(wù)開發(fā)的 Docker 集群,并將相關(guān)開發(fā)同事的 Docker 加入到這個集群里,就完成了搭建跨主機(jī)網(wǎng)絡(luò)的第一步。

建立跨主機(jī)網(wǎng)絡(luò)

接下來,我們就通過 docker network create 命令來建立 Overlay 網(wǎng)絡(luò)。

$ sudo docker network create --driver overlay --attachable mongodbs

在創(chuàng)建 Overlay 網(wǎng)絡(luò)時,我們要加入 --attachable 選項以便不同機(jī)器上的 Docker 容器能夠正常使用到它。

在創(chuàng)建了這個網(wǎng)絡(luò)之后,我們可以在任何一個加入到集群的 Docker 實(shí)例上使用 docker network ls 查看一下其下的網(wǎng)絡(luò)列表。我們會發(fā)現(xiàn)這個網(wǎng)絡(luò)定義已經(jīng)同步到了所有集群中的節(jié)點(diǎn)上。

$ sudo docker network ls
NETWORK ID     NAME        DRIVER       SCOPE
## ......
y89bt74ld9l8    mongodbs        overlay       swarm
## ......

接下來我們要修改 Docker Compose 的定義,讓它使用這個我們已經(jīng)定義好的網(wǎng)絡(luò),而不是再重新創(chuàng)建網(wǎng)絡(luò)。

我們只需要在 Docker Compose 配置文件的網(wǎng)絡(luò)定義部分,將網(wǎng)絡(luò)的 external 屬性設(shè)置為 true,就可以讓 Docker Compose 將其建立的容器都連接到這個不屬于 Docker Compose 的項目上了。

networks:
 mesh:
  external: true

通過這個實(shí)現(xiàn),我們在開發(fā)中就使整個服務(wù)都處于一個可以使用別名映射網(wǎng)絡(luò)中,避免了要對不同功能聯(lián)調(diào)時切換服務(wù) IP 的煩瑣流程。在這種結(jié)構(gòu)下,我們只需要讓我們開發(fā)的 Docker 退出和加入不同的集群,就能馬上做到切換不同聯(lián)調(diào)項目。

二、編寫 docker-compose 文件

主節(jié)點(diǎn)

version: "3"
services: 
 master:
  image: mongo:4.1
  container_name: master
  environment:
   MONGO_INITDB_ROOT_USERNAME: root
   MONGO_INITDB_ROOT_PASSWORD: 123456
   TZ: "Asia/Shanghai"
  volumes:
   # 掛載 MongoDB 數(shù)據(jù)目錄
   - "/data/docker/mongodb/data/mongo:/data/db:rw"
   # 掛載 KeyFile
   - "/data/docker/mongodb/data/mongodb.key:/data/mongodb.key"
  ports:
   - "27018:27017"
  networks:
   - mongodbs
  command:
   # 密碼
   --auth
   # 副本集名稱
   --replSet testSet 
   --oplogSize 128
   --keyFile /data/mongodb.key
# Swarm 跨主機(jī)網(wǎng)絡(luò)網(wǎng)絡(luò)
networks:
 mongodbs:
  external: true

副節(jié)點(diǎn)

version: "3"
services: 
secondary:
 image: mongo:4.1
 container_name: secondary
 environment:
  MONGO_INITDB_ROOT_USERNAME: root
  MONGO_INITDB_ROOT_PASSWORD: 123456
  TZ: "Asia/Shanghai"
 volumes:
  - "/data/docker/mongodb/data/mongo:/data/db:rw"
  - "/data/docker/mongodb/data/mongodb.key:/data/mongodb.key"
 ports:
  - "27018:27017"
 networks:
  - mongodbs
 command:
  --auth
  --replSet testSet 
  --oplogSize 128
  --keyFile /data/mongodb.key
networks:
mongodbs:
 external: true

仲裁節(jié)點(diǎn),因為仲裁節(jié)點(diǎn)不需要存儲數(shù)據(jù),他只是用來當(dāng)主節(jié)點(diǎn)掛掉后選舉新的主節(jié)點(diǎn),所以不需要密碼、映射端口等操作

version: "3"
services:
arbiter:
 image: mongo:4.1
 container_name: arbiter
 restart: always
 volumes:
  - "/data/docker/mongodb/data/mongo:/data/db:rw"
  - "/data/docker/mongodb/data/mongo_key:/mongo:rw"
 networks:
  - mongodbs
 command:
  mongod --replSet testSet --smallfiles --oplogSize 128
networks:
mongodbs:
 external: true

三、啟動容器

接下來我們分別在三臺服務(wù)器中使用容器編排啟動容器

docker-compose up -d

四、配置副本集

進(jìn)入主節(jié)點(diǎn)容器內(nèi)部

docker exec -it master mongo

在 mongo shell 里執(zhí)行:

> rs.initiate()
{
   "info2" : "no configuration specified. Using a default configuration for the set",
   "me" : "7abd89794aa7:27017",
   "ok" : 1
}

繼續(xù)執(zhí)行:

testSet:SECONDARY> rs.add('secondary:27017')
{
   "ok" : 1,
   "$clusterTime" : {
       "clusterTime" : Timestamp(1599562800, 1),
       "signature" : {
           "hash" : BinData(0,"wrxMUIX/0bEyLgCVoQqdLvH59T0="),
           "keyId" : NumberLong("6870069879538450434")
       }
   },
   "operationTime" : Timestamp(1599562800, 1)
}

繼續(xù)執(zhí)行,其中 true 表示這個節(jié)點(diǎn)是仲裁節(jié)點(diǎn)

testSet:PRIMARY> rs.add('arbiter:27017',true)
{
   "ok" : 1,
   "$clusterTime" : {
       "clusterTime" : Timestamp(1599562838, 1),
       "signature" : {
           "hash" : BinData(0,"p9ub49lLD8ij8nkxpfu2l/AvRRY="),
           "keyId" : NumberLong("6870069879538450434")
       }
   },
   "operationTime" : Timestamp(1599562838, 1)
}

查看配置

testSet:PRIMARY> rs.conf()
{
   "_id" : "testSet",
   "version" : 3,
   "protocolVersion" : NumberLong(1),
   "writeConcernMajorityJournalDefault" : true,
   "members" : [
       {
           "_id" : 0,
           "host" : "7abd89794aa7:27017",
           "arbiterOnly" : false,
           "buildIndexes" : true,
           "hidden" : false,
           "priority" : 1,
           "tags" : {

           },
           "slaveDelay" : NumberLong(0),
           "votes" : 1
       },
       {
           "_id" : 1,
           "host" : "secondary:27017",
           "arbiterOnly" : false,
           "buildIndexes" : true,
           "hidden" : false,
           "priority" : 1,
           "tags" : {

           },
           "slaveDelay" : NumberLong(0),
           "votes" : 1
       },
       {
           "_id" : 2,
           "host" : "arbiter:27017",
           "arbiterOnly" : true,
           "buildIndexes" : true,
           "hidden" : false,
           "priority" : 0,
           "tags" : {

           },
           "slaveDelay" : NumberLong(0),
           "votes" : 1
       }
   ],
   "settings" : {
       "chainingAllowed" : true,
       "heartbeatIntervalMillis" : 2000,
       "heartbeatTimeoutSecs" : 10,
       "electionTimeoutMillis" : 10000,
       "catchUpTimeoutMillis" : -1,
       "catchUpTakeoverDelayMillis" : 30000,
       "getLastErrorModes" : {

       },
       "getLastErrorDefaults" : {
           "w" : 1,
           "wtimeout" : 0
       },
       "replicaSetId" : ObjectId("5f576426fe90ef2dd8cd2700")
   }
}

查看狀態(tài)

testSet:PRIMARY> rs.status()
{
   "set" : "testSet",
   "date" : ISODate("2020-09-08T11:45:12.096Z"),
   "myState" : 1,
   "term" : NumberLong(1),
   "syncingTo" : "",
   "syncSourceHost" : "",
   "syncSourceId" : -1,
   "heartbeatIntervalMillis" : NumberLong(2000),
   "optimes" : {
       "lastCommittedOpTime" : {
           "ts" : Timestamp(1599565502, 1),
           "t" : NumberLong(1)
       },
       "lastCommittedWallTime" : ISODate("2020-09-08T11:45:02.775Z"),
       "readConcernMajorityOpTime" : {
           "ts" : Timestamp(1599565502, 1),
           "t" : NumberLong(1)
       },
       "readConcernMajorityWallTime" : ISODate("2020-09-08T11:45:02.775Z"),
       "appliedOpTime" : {
           "ts" : Timestamp(1599565502, 1),
           "t" : NumberLong(1)
       },
       "durableOpTime" : {
           "ts" : Timestamp(1599565502, 1),
           "t" : NumberLong(1)
       },
       "lastAppliedWallTime" : ISODate("2020-09-08T11:45:02.775Z"),
       "lastDurableWallTime" : ISODate("2020-09-08T11:45:02.775Z")
   },
   "lastStableRecoveryTimestamp" : Timestamp(1599565492, 1),
   "lastStableCheckpointTimestamp" : Timestamp(1599565492, 1),
   "members" : [
       {
           "_id" : 0,
           "name" : "7abd89794aa7:27017",
           "ip" : "10.0.1.41",
           "health" : 1,
           "state" : 1,
           "stateStr" : "PRIMARY",
           "uptime" : 2784,
           "optime" : {
               "ts" : Timestamp(1599565502, 1),
               "t" : NumberLong(1)
           },
           "optimeDate" : ISODate("2020-09-08T11:45:02Z"),
           "syncingTo" : "",
           "syncSourceHost" : "",
           "syncSourceId" : -1,
           "infoMessage" : "",
           "electionTime" : Timestamp(1599562790, 2),
           "electionDate" : ISODate("2020-09-08T10:59:50Z"),
           "configVersion" : 3,
           "self" : true,
           "lastHeartbeatMessage" : ""
       },
       {
           "_id" : 1,
           "name" : "secondary:27017",
           "ip" : "10.0.1.233",
           "health" : 1,
           "state" : 2,
           "stateStr" : "SECONDARY",
           "uptime" : 2711,
           "optime" : {
               "ts" : Timestamp(1599565502, 1),
               "t" : NumberLong(1)
           },
           "optimeDurable" : {
               "ts" : Timestamp(1599565502, 1),
               "t" : NumberLong(1)
           },
           "optimeDate" : ISODate("2020-09-08T11:45:02Z"),
           "optimeDurableDate" : ISODate("2020-09-08T11:45:02Z"),
           "lastHeartbeat" : ISODate("2020-09-08T11:45:11.494Z"),
           "lastHeartbeatRecv" : ISODate("2020-09-08T11:45:11.475Z"),
           "pingMs" : NumberLong(0),
           "lastHeartbeatMessage" : "",
           "syncingTo" : "7abd89794aa7:27017",
           "syncSourceHost" : "7abd89794aa7:27017",
           "syncSourceId" : 0,
           "infoMessage" : "",
           "configVersion" : 3
       },
       {
           "_id" : 2,
           "name" : "arbiter:27017",
           "ip" : null,
           "health" : 0,
           "state" : 8,
           "stateStr" : "(not reachable/healthy)",
           "uptime" : 0,
           "lastHeartbeat" : ISODate("2020-09-08T11:45:10.463Z"),
           "lastHeartbeatRecv" : ISODate("1970-01-01T00:00:00Z"),
           "pingMs" : NumberLong(0),
           "lastHeartbeatMessage" : "Error connecting to arbiter:27017 :: caused by :: Could not find address for arbiter SocketException: Host not found (authoritative)",
           "syncingTo" : "",
           "syncSourceHost" : "",
           "syncSourceId" : -1,
           "infoMessage" : "",
           "configVersion" : -1
       }
   ],
   "ok" : 1,
   "$clusterTime" : {
       "clusterTime" : Timestamp(1599565502, 1),
       "signature" : {
           "hash" : BinData(0,"7/ei+8UrhlpIny9zKeWuAFpn46c="),
           "keyId" : NumberLong("6870069879538450434")
       }
   },
   "operationTime" : Timestamp(1599565502, 1)
}

五、驗證 MongoDB 可用性

先進(jìn)入主節(jié)點(diǎn)服務(wù)器添加一條數(shù)據(jù)

docker exec -it master mongo
use admin
db.auth('root', '123456')
use test
db.test.insert({name:"muyang",age:20})

在來副節(jié)點(diǎn)服務(wù)器查看是否已經(jīng)同步了這條數(shù)據(jù)

[root@linux secondary] docker exec -it secondary mongo
testSet:SECONDARY> use admin
testSet:SECONDARY> db.auth('root', '123456')
testSet:SECONDARY> use test
testSet:SECONDARY> db.test.find()
2020-09-08T19:03:02.295+0800 E QUERY  [js] uncaught exception: Error: listCollections failed: {
   "operationTime" : Timestamp(1599562972, 1),
   "ok" : 0,
   "errmsg" : "not master and slaveOk=false",
   "code" : 13435,
   "codeName" : "NotMasterNoSlaveOk",
   "$clusterTime" : {
       "clusterTime" : Timestamp(1599562972, 1),
       "signature" : {
           "hash" : BinData(0,"mhsrpGHRl7qZg2QOjyS3RbBb/Yc="),
           "keyId" : NumberLong("6870069879538450434")
       }
   }
} :
testSet:SECONDARY> rs.slaveOk()
testSet:SECONDARY> db.users.find()
{ "_id" : ObjectId("5f5764b1f909544b783696c2"), "name" : "muyang", "age" : 20 }

在 secondary 查詢時報如下錯誤:

not master and slaveok=false

這是正常的,因為 secondary 是不允許讀寫的,如果非要解決,方法如下:

testSet:SECONDARY> rs.slaveOk()

 到此這篇關(guān)于Docker 搭建集群MongoDB的實(shí)現(xiàn)步驟的文章就介紹到這了,更多相關(guān)Docker 搭建集群MongoDB內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

標(biāo)簽:拉薩 齊齊哈爾 烏海 衡陽 運(yùn)城 澳門 亳州 嘉興

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Docker 搭建集群MongoDB的實(shí)現(xiàn)步驟》,本文關(guān)鍵詞  Docker,搭建,集群,MongoDB,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Docker 搭建集群MongoDB的實(shí)現(xiàn)步驟》相關(guān)的同類信息!
  • 本頁收集關(guān)于Docker 搭建集群MongoDB的實(shí)現(xiàn)步驟的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美视频一二三区| 亚洲老妇xxxxxx| 欧美一级二级在线观看| 欧美日韩高清不卡| 91精品久久久久久久久99蜜臂| 日韩三级伦理片妻子的秘密按摩| 亚洲欧洲精品一区二区三区不卡 | 91视视频在线观看入口直接观看www| 精品在线视频一区| 亚洲一区二区三区爽爽爽爽爽| 久久成人羞羞网站| 91免费精品国自产拍在线不卡| 日韩精品一区在线| 亚洲h动漫在线| 99久久久免费精品国产一区二区| 日韩欧美美女一区二区三区| 亚洲二区视频在线| www.亚洲精品| 国产清纯美女被跳蛋高潮一区二区久久w| 亚洲成人免费观看| 色老汉一区二区三区| 国产亚洲精品免费| 国产在线视频精品一区| 日韩午夜在线观看视频| 丝袜亚洲另类欧美| 欧美视频一区二区三区| 亚洲黄色免费电影| 一本大道综合伊人精品热热| 国产精品久久久久久久久久免费看 | 日本怡春院一区二区| 日本国产一区二区| ...xxx性欧美| 色综合久久久久综合体桃花网| 国产精品全国免费观看高清| 国产美女主播视频一区| 久久蜜桃香蕉精品一区二区三区| 免费成人av在线| 日韩一区二区在线观看视频 | 爽爽淫人综合网网站| 色吊一区二区三区| 亚洲天堂福利av| 一本到三区不卡视频| 亚洲精品亚洲人成人网在线播放| 色成年激情久久综合| 亚洲国产日日夜夜| 91精品福利在线一区二区三区 | 久久久精品免费免费| 激情综合色综合久久| 久久久综合九色合综国产精品| 国产一区二区调教| 中文字幕欧美激情一区| 一本一道综合狠狠老| 亚洲黄色性网站| 欧美人体做爰大胆视频| 美女高潮久久久| 国产亚洲精久久久久久| 99精品国产热久久91蜜凸| 一区二区欧美视频| 日韩欧美一级二级三级| 成人午夜精品一区二区三区| 亚洲免费观看高清完整版在线| 91精品国产综合久久国产大片| 国产一区二区三区在线观看免费视频| 久久久久9999亚洲精品| 91亚洲国产成人精品一区二三| 亚洲成人一二三| 久久一夜天堂av一区二区三区| 色综合色综合色综合色综合色综合| 亚洲午夜精品在线| 日韩欧美一级二级三级| 国产suv精品一区二区883| 国产色一区二区| 欧美日韩中文一区| 蜜臀av性久久久久蜜臀aⅴ| 精品久久久三级丝袜| 不卡一区二区在线| 亚洲大型综合色站| 欧美一区二区三区四区视频| 韩国精品久久久| 国产精品国产三级国产aⅴ原创 | 亚洲最新在线观看| 欧美一级高清大全免费观看| 国产久卡久卡久卡久卡视频精品| 中文字幕精品—区二区四季| 色诱亚洲精品久久久久久| 国产一区二区免费在线| 亚洲欧美一区二区三区孕妇| 欧美日韩国产免费一区二区| 国产乱码精品一区二区三区av| 成人免费一区二区三区视频| 911精品国产一区二区在线| 国产成人精品综合在线观看| 亚洲自拍偷拍av| 久久老女人爱爱| 日本高清不卡一区| 精品制服美女丁香| 亚洲自拍与偷拍| 国产视频一区二区在线| 欧美日韩中文字幕一区| 91麻豆成人久久精品二区三区| 精品一区在线看| 亚洲美女一区二区三区| 26uuu精品一区二区| 欧美在线观看视频一区二区三区| 狠狠色丁香久久婷婷综合_中| 亚洲免费色视频| 日韩一区二区在线观看视频| 欧美日韩中文一区| 不卡的av电影| 国产成人精品在线看| 人人精品人人爱| 亚洲高清视频中文字幕| 国产精品久久久久久久久免费樱桃 | 久久久久久亚洲综合| 91在线国产观看| 国产成人亚洲综合色影视| 首页亚洲欧美制服丝腿| 亚洲精品欧美综合四区| 国产网红主播福利一区二区| 欧美一区二区三级| 欧美亚洲图片小说| 欧美日韩精品一区二区天天拍小说| 国产 日韩 欧美大片| 蜜桃在线一区二区三区| 日韩国产欧美在线播放| 亚洲一区二区美女| 亚洲免费成人av| 国产日本一区二区| 亚洲视频在线一区观看| 国产精品超碰97尤物18| 亚洲欧美综合在线精品| 亚洲国产精品国自产拍av| 久久久不卡影院| 久久久99久久| 亚洲自拍偷拍九九九| 亚洲v精品v日韩v欧美v专区| 亚洲综合丝袜美腿| 亚洲另类色综合网站| 亚洲一二三四在线| 午夜激情一区二区三区| 奇米777欧美一区二区| 美国三级日本三级久久99| 麻豆91精品91久久久的内涵| 激情丁香综合五月| 粉嫩高潮美女一区二区三区| 99re成人精品视频| 日本韩国精品在线| 欧美高清性hdvideosex| 日韩欧美成人一区| 久久久精品中文字幕麻豆发布| 国产欧美一区二区三区在线看蜜臀| 国产精品丝袜91| 亚洲成人高清在线| 激情成人午夜视频| 成人丝袜18视频在线观看| 色综合天天综合在线视频| 欧美无人高清视频在线观看| 欧美一区二区三区四区高清| 制服丝袜在线91| 18成人在线视频| 亚洲国产综合在线| 国产在线播放一区二区三区| 国产成人免费xxxxxxxx| 一本久久a久久精品亚洲 | 国产成人在线网站| 色美美综合视频| 在线不卡中文字幕| 亚洲色图在线视频| 亚洲国产成人91porn| 国产成人av资源| 欧美日韩视频在线观看一区二区三区| 精品久久一二三区| 国产精品久久久爽爽爽麻豆色哟哟 | 99久免费精品视频在线观看| 欧美伊人久久久久久久久影院 | 久久免费精品国产久精品久久久久| 国产欧美视频一区二区三区| 看电影不卡的网站| 色欧美片视频在线观看| 久久伊人蜜桃av一区二区| 亚洲综合自拍偷拍| 国产成人亚洲精品青草天美| 欧美日韩一区在线观看| 欧美国产成人在线| 麻豆国产精品777777在线| 色噜噜狠狠成人中文综合| 久久久国产精品麻豆| 亚洲3atv精品一区二区三区| 99久久综合色| 久久精品欧美一区二区三区不卡| 亚洲成人av中文| 99re成人在线| 日本一区二区三区久久久久久久久不 | 麻豆国产一区二区| 日本精品免费观看高清观看| 亚洲国产精品成人综合| 毛片av一区二区| 在线成人小视频| 久久99久久精品欧美| 欧美精品高清视频|