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

排查構(gòu)建鏡像時(shí) IO 慢問題

存儲 數(shù)據(jù)管理
通過設(shè)計(jì)各種測試案例排查問題,對各個(gè)要素進(jìn)行一一驗(yàn)證,需要極大耐心,也特別容易走錯(cuò)方向,得出錯(cuò)誤結(jié)論。

?1. 遇到的問題

項(xiàng)目介紹:

  • 文件大小 5.6 GB
  • 文件數(shù)量 529352

Dockerfile

FROM golang:1.13

COPY ./ /go/src/code

構(gòu)建命令及輸入如下:

time DOCKER_BUILDKIT=1 docker build --no-cache -t test:v3 -f Dockerfile .  --progress=plain

#1 [internal] load build definition from Dockerfile
#1 sha256:2a154d4ad813d1ef3355d055345ad0e7c5e14923755cea703d980ecc1c576ce7
#1 transferring dockerfile: 37B done
#1 DONE 0.1s

#2 [internal] load .dockerignore
#2 sha256:9598c0ddacf682f2cac2be6caedf6786888ec68f009c197523f8b1c2b5257b34
#2 transferring context: 2B done
#2 DONE 0.2s

#3 [internal] load metadata for golang:1.13
#3 sha256:0c7952f0b4e5d57d371191fa036da65d51f4c4195e1f4e1b080eb561c3930497
#3 DONE 0.0s

#4 [1/2] FROM golang:1.13
#4 sha256:692ef5b58e708635d7cbe3bf133ba934336d80cde9e2fdf24f6d1af56d5469ed
#4 CACHED

#5 [internal] load build context
#5 sha256:f87f36fa1dc9c0557ebc53645f7ffe404ed3cfa3332535260e5a4a1d7285be3c
#5 transferring context: 18.73MB 4.8s
#5 transferring context: 38.21MB 9.8s done
#5 DONE 10.5s

#6 [2/2] COPY ./ /go/src/code
#6 sha256:2c63806741b84767def3d7cebea3872b91d7ef00bd3d524f48976077cce3849a
#6 DONE 26.8s

#7 exporting to image
#7 sha256:e8c613e07b0b7ff33893b694f7759a10d42e180f2b4dc349fb57dc6b71dcab00
#7 exporting layers
#7 exporting layers 67.5s done
#7 writing image sha256:03b278543ab0f920f5af0540d93c5e5340f5e1f0de2d389ec21a2dc82af96754 done
#7 naming to docker.io/library/test:v3 done
#7 DONE 67.6s

real 1m45.411s
user 0m18.374s
sys 0m7.344s

其中比較花時(shí)間的是:

  • 10s,load build context
  • 26s,執(zhí)行 COPY 操作
  • 67s,導(dǎo)出鏡像,鏡像大小 5.79GB

以下也是按照這個(gè)思路進(jìn)行逐一排查,測試驗(yàn)證,尋找構(gòu)建時(shí)的 IO 瓶頸。

2. 自制 go client 直接提交給 Dockerd 構(gòu)建效果不佳

工程 https://github.com/shaowenchen/demo/tree/master/buidl-cli 實(shí)現(xiàn)的功能就是將本地的 Dockerfile 及上下文提交給 Dockerd 進(jìn)行構(gòu)建,從而測試 Docker CLI 是否有提交文件上的瓶頸。

2.1 編譯生成二進(jìn)制文件

GOOS=linux GOARCH=amd64 go build  -o build main.go

2.2 自制二進(jìn)制提交構(gòu)建任務(wù)

time ./build ./ test:v3

real 5m12.758s
user 0m2.182s
sys 0m14.169s

使用 Go 寫的 cli 工具,將構(gòu)建上下文提交給 Dockerd 進(jìn)行構(gòu)建,時(shí)長急劇增加;與此同時(shí),構(gòu)建機(jī)的負(fù)載飆升。

也可能還有其他優(yōu)化點(diǎn),需要慢慢調(diào)試。而 Docker CLI 其實(shí)也有相關(guān)的參數(shù)可以用于減少 IO 占用時(shí)間。

3. 構(gòu)建參數(shù) compress、stream 參數(shù)優(yōu)化效果不佳

compress 會將上下文壓縮為 gzip 格式進(jìn)行傳輸,而 stream 會以流的形式傳輸上下文。

3.1 使用 compress 優(yōu)化

time DOCKER_BUILDKIT=1 docker build --no-cache -t test:v3 -f Dockerfile . --compress

real 1m46.117s
user 0m18.551s
sys 0m7.803s

3.2 使用 stream 優(yōu)化

time DOCKER_BUILDKIT=1 docker build --no-cache -t test:v3 -f Dockerfile . --stream

real 1m51.825s
user 0m19.399s
sys 0m7.657s

這兩個(gè)參數(shù)對縮短構(gòu)建時(shí)間,并沒有什么效果。但需要注意的是測試項(xiàng)目的文件大而且數(shù)量多,如果測試用例發(fā)生變化,可能產(chǎn)生不同的效果。接著,我們一起看看文件數(shù)量、文件大小對 Dockerd 構(gòu)建鏡像的影響。

4. 文件數(shù)量對 COPY 影響遠(yuǎn)不及文件大小

4.1 準(zhǔn)備測試文件

du -h --max-depth=1

119M ./data
119M .

在 data 目錄下放置了一個(gè) 119MB 的文件,通過復(fù)制該文件不斷增加 build context 的大小。

4.2 測試 Dockerfile

FROM golang:1.13

COPY ./ /go/src/code

4.3 構(gòu)建命令

DOCKER_BUILDKIT=1 docker build --no-cache -t test:v3 -f Dockerfile .

4.4 測試文件大小對 COPY 影響明顯

文件大小

構(gòu)建時(shí)長

文件個(gè)數(shù)

119M

0.3s

1個(gè)

237M

0.4s

2個(gè)

355M

0.5s

3個(gè)

473M

0.6s

4個(gè)

1.3G

3.7s

11個(gè)

2.6G

9.0s

22個(gè)

文件大小對 COPY 影響明顯,接近線性增長。

4.5 測試文件數(shù)量對 COPY 影響甚微

文件大小

構(gòu)建時(shí)長

文件個(gè)數(shù)

2.9G

13.8s

264724個(gè)

5.6G

37.1s

529341個(gè)

文件數(shù)量對 COPY 影響不大。這是由于在 Docker CLI 將 build context 發(fā)送給 Dockerd 時(shí),會對 context 進(jìn)行 tar 打包,并不是一個(gè)一個(gè)文件傳輸。

4.6 構(gòu)建并發(fā)數(shù)的瓶頸在磁盤IO

5.6G 529341個(gè)

并發(fā)量

構(gòu)建時(shí)長

1

37.1s

2

46s

3

81s

通過 iotop 可以實(shí)時(shí)觀測到磁盤寫速度,最快能達(dá)到 200MB/s,與文件系統(tǒng) 4K 隨機(jī)寫速度最接近。

Rand_Write_Testing: (groupid=0, jobs=1): err= 0: pid=30436
write: IOPS=37.9k, BW=148MiB/s (155MB/s)(3072MiB/20752msec); 0 zone resets

由于公用一個(gè) Dockerd,并發(fā)時(shí) Dockerd 吞吐會有瓶頸,系統(tǒng)磁盤 IO 也會成為瓶頸。

5. 不清理 Buildkit 緩存對新的構(gòu)建影響甚微

如果提示找不到 docker build?,則需要開啟EXPERIMENTAL? 或者沒有 buildx,需要下載 docker-buildx? 到 /usr/libexec/docker/cli-plugins/ 目錄。

  • 查看 build 緩存
docker system df  -v
  • 清理全部 build 緩存
DOCKER_BUILDKIT=1 docker builder prune -f

僅當(dāng)開啟 BuildKit 時(shí),才會產(chǎn)生 Build cache。生產(chǎn)環(huán)境的緩存大小達(dá)到 1.408TB,但比較清理前后,對于新項(xiàng)目的構(gòu)建并沒有發(fā)現(xiàn)明顯構(gòu)建速度變化;對于老項(xiàng)目,如果沒有變動,命中緩存后速度很快。可能的原因是緩存雖大但條目不多,查詢是否有緩存的時(shí)間開銷很小。

但定期定理緩存,有利于預(yù)防磁盤被占滿的風(fēng)險(xiǎn)。

  • 定時(shí)清理遠(yuǎn)期的構(gòu)建緩存

清理掉 72h 之前的緩存

DOCKER_CLI_EXPERIMENTAL=enabled docker buildx prune --filter "until=72h" -f

6. 構(gòu)建不會限制 CPU 但 IO 速度很慢

6.1 測試 CPU 限制

Dockerfile 文件

FROM ubuntu
RUN apt-get update -y
RUN apt-get install -y stress
RUN stress -c 40
DOCKER_BUILDKIT=1 docker build --no-cache -t test:v3 -f Dockerfile .

構(gòu)建機(jī)有 40C,構(gòu)建時(shí)機(jī)器 CPU 負(fù)載能達(dá)到 95%,說明構(gòu)建時(shí),Dockerd 默認(rèn)不會對 CPU 消耗進(jìn)行限制。在生產(chǎn)環(huán)境下,出現(xiàn)過 npm run build 占用 十幾個(gè) GB 內(nèi)存的場景,因此我判斷 Dockerd 默認(rèn)也不會對內(nèi)存消耗進(jìn)行限制。

6.2 在 Dockerfile 中測試 IO

Dockerfile 文件

FROM ubuntu
RUN apt-get update -y
RUN apt-get install -y fio
RUN fio -direct=1 -iodepth=128 -rw=randwrite -ioengine=libaio -bs=4k -size=3G -numjobs=1 -runtime=1000 -group_reporting -filename=/tmp/test.file --allow_mounted_write=1 -name=Rand_Write_Testing
DOCKER_BUILDKIT=1 docker build --no-cache -t test:v3 -f Dockerfile . 

Rand_Write_Testing: (groupid=0, jobs=1): err= 0
write: IOPS=17.4k, BW=67.9MiB/s (71.2MB/s)(3072MiB/45241msec); 0 zone resets

6.3 在容器中測試 IO

docker run -it shaowenchen/demo-fio bash
Rand_Write_Testing: (groupid=0, jobs=1): err= 0
write: IOPS=17.4k, BW=68.1MiB/s (71.4MB/s)(3072MiB/45091msec); 0 zone resets

6.4 在容器的存儲卷中測試 IO

docker run -v /tmp:/tmp -it shaowenchen/demo-fio bash
Rand_Write_Testing: (groupid=0, jobs=1): err= 0
write: IOPS=39.0k, BW=152MiB/s (160MB/s)(3072MiB/20162msec); 0 zone resets

6.5 在主機(jī)上試 IO

Rand_Write_Testing: (groupid=0, jobs=1): err= 0
write: IOPS=38.6k, BW=151MiB/s (158MB/s)(3072MiB/20366msec); 0 zone resets

Dockerd 在構(gòu)建 Dockerfile 時(shí),遇到 Run 命令會啟動一個(gè)容器運(yùn)行,然后提交鏡像。從測試結(jié)果,可以看到 Dockerfile 中的 IO 速度遠(yuǎn)達(dá)不到主機(jī)的,與容器中的 IO 速度一致;主機(jī)存儲卷的 IO 速度與主機(jī)的 IO 速度一致。

7. 直接使用 buildkitd 構(gòu)建效果不佳

雖然可以通過 DOCKER_BUILDKIT=1 開啟 Buildkit 構(gòu)建,但如果直接使用 buildkitd 效果不錯(cuò),用于替換 Dockerd 構(gòu)建也是一個(gè)不錯(cuò)的選擇。

7.1 安裝 buildkit

wget https://github.com/moby/buildkit/releases/download/v0.11.2/buildkit-v0.11.2.linux-amd64.tar.gz
tar xvf buildkit-v0.11.2.linux-amd64.tar.gz
mv bin/* /usr/local/bin/

7.2 部署 buildkitd

cat > /usr/lib/systemd/system/buildkitd.service <<EOF
[Unit]
Description=/usr/local/bin/buildkitd
ConditionPathExists=/usr/local/bin/buildkitd
After=containerd.service

[Service]
Type=simple
ExecStart=/usr/local/bin/buildkitd
User=root
Restart=on-failure
RestartSec=1500ms

[Install]
WantedBy=multi-user.target
EOF
systemctl daemon-reload
systemctl restart buildkitd
systemctl enable buildkitd
systemctl status buildkitd

查看到 buildkitd 正常運(yùn)行即可。

7.3 測試 buildctl 提交構(gòu)建

buildctl build --frontend=dockerfile.v0 --local context=. --local dockerfile=. --no-cache --output type=docker,name=test:v4 | docker load

[+] Building 240.8s (7/7) FINISHED

使用 buildctl 提交給 buildkitd 進(jìn)行構(gòu)建,需要的時(shí)間更多,達(dá)到 4min,較之前增加一倍。

8. 當(dāng)前存儲驅(qū)動下讀寫鏡像有瓶頸

8.1 查看 Dockerd 處理邏輯

在代碼 https://github.com/moby/moby/blob/8d193d81af9cbbe800475d4bb8c529d67a6d8f14/builder/dockerfile/dispatchers.go 可以找到處理 Dockerfile 的邏輯。

1,Add 和 Copy 都是調(diào)用 performCopy 函數(shù) 2,performCopy 中調(diào)用 NewRWLayer() 新建層,調(diào)用 exportImage 寫入數(shù)據(jù)

因此,懷疑的是 Dockerd 寫鏡像層速度慢。

8.2 測試鏡像層寫入速度

準(zhǔn)備一個(gè)鏡像,大小 16GB,一共 18 層。

  • 導(dǎo)入鏡像
time docker load < /tmp/16GB.tar

real 2m43.288s
  • 保存鏡像
time docker save 0d08de176b9f > /tmp/16GB.tar

real 2m48.497s

docker load? 和 docker save 速度差不多,對鏡像層的處理速度大約為 100 MB/s。這個(gè)速度比磁盤 4K 隨機(jī)寫速度少了近 30%。在我看來,如果是個(gè)人使用勉強(qiáng)接受;如果用于對外提供構(gòu)建服務(wù)的平臺產(chǎn)品,這塊磁盤顯然是不合適的。

8.3 存儲驅(qū)動怎么選

下面是從 https://docs.docker.com/storage/storagedriver/select-storage-driver/ 整理得出的一個(gè)比較表格:

存儲驅(qū)動

文件系統(tǒng)要求

高頻寫入性能

穩(wěn)定性

其他

overlay2

xfs、ext4



當(dāng)前首選

fuse-overlayfs

無限制

-

-

適用 rootless 場景

btrfs

btrfs


-

-

zfs

zfs


-

-

vfs

無限制

-

-

不建議生產(chǎn)

aufs

xfs、ext4

-


Docker 18.06 及之前版本首選,不維護(hù)

devicemapper

direct-lvm



不維護(hù)

overlay

xfs、ext4

差,但好于 overlay2

-

不維護(hù)

排除不維護(hù)和非生產(chǎn)適用的,可選項(xiàng)其實(shí)沒幾個(gè)。正好有一臺機(jī)器,前段時(shí)間初始化時(shí),將磁盤格式化成 Btrfs 文件格式,可以用于測試。zfs 存儲驅(qū)動推薦用于高密度 PaaS 系統(tǒng)。

8.4 測試 Btrfs 存儲驅(qū)動

  • 在主機(jī)上
Rand_Write_Testing: (groupid=0, jobs=1): err= 0
write: IOPS=40.0k, BW=160MiB/s (168MB/s)(3072MiB/19191msec); 0 zone resets
  • 容器下的測試命令

運(yùn)行容器

docker run -it shaowenchen/demo-fio bash

執(zhí)行測試

fio -direct=1 -iodepth=128 -rw=randwrite -ioengine=libaio -bs=4k -size=3G -numjobs=1 -runtime=1000 -group_reporting -filename=/data/test.file --allow_mounted_write=1 -name=Rand_Write_Testing
  • 測試 overlay2 存儲驅(qū)動
docker info

Server Version: 20.10.12
Storage Driver: overlay2
Backing Filesystem: btrfs
Rand_Write_Testing: (groupid=0, jobs=1): err= 0: pid=78: Thu Feb  2 02:41:48 2023
write: IOPS=21.5k, BW=84.1MiB/s (88.2MB/s)(3072MiB/36512msec); 0 zone resets
  • 測試 btrfs 存儲驅(qū)動
docker info

Server Version: 20.10.12
Storage Driver: btrfs
Build Version: Btrfs v5.4.1
Rand_Write_Testing: (groupid=0, jobs=1): err= 0
write: IOPS=39.8k, BW=156MiB/s (163MB/s)(3072MiB/19750msec); 0 zone resets

可以明顯看到 btrfs 存儲驅(qū)動在速度上優(yōu)于 overlay2。

9. 總結(jié)

本篇主要是記錄在生產(chǎn)環(huán)境下碰到的 Dockerfile 構(gòu)建 IO 慢問題排查過程。

通過設(shè)計(jì)各種測試案例排查問題,對各個(gè)要素進(jìn)行一一驗(yàn)證,需要極大耐心,也特別容易走錯(cuò)方向,得出錯(cuò)誤結(jié)論。

本篇主要觀點(diǎn)如下:

  • compress、stream 參數(shù)對構(gòu)建速度不一定有效
  • 減少構(gòu)建上下文大小,有利于緩解構(gòu)建 IO 壓力
  • Buildkit 的緩存可以不用頻繁清理
  • 構(gòu)建 Dockerfile 執(zhí)行命令時(shí),CPU、Mem 不會受到限制,但 IO 速度慢
  • 使用 buildkitd 構(gòu)建速度不如 Dockerd 開啟 DOCKER_BUILDKIT
  • 使用 Btrfs 存儲有利于獲得更好的 IO 速度

但最簡單的還是使用 4K 隨機(jī)讀寫快的磁盤,在拿到新的環(huán)境用于生產(chǎn)之前,務(wù)必先進(jìn)行測試,僅當(dāng)滿足需求時(shí),再執(zhí)行后續(xù)計(jì)劃。

10. 參考

  • https://docs.docker.com/engine/reference/commandline/build/
  • https://docs.docker.com/build/install-buildx/
  • https://flyer103.com/2022/08/20220806-buildkitd-usage/
  • https://pepa.holla.cz/2019/11/18/how-build-own-docker-image-in-golang/
責(zé)任編輯:武曉燕 來源: 陳少文
相關(guān)推薦

2022-03-11 10:21:30

IO系統(tǒng)日志

2021-07-15 23:16:09

IO異常排查

2023-10-20 13:30:36

代碼接口

2023-07-10 09:48:30

Nginx反向代理

2019-11-25 15:32:30

虛擬化IO故障

2024-08-14 14:20:00

2025-03-18 08:10:00

iodump開源I/O

2025-11-03 13:00:00

SQL慢SQL數(shù)據(jù)庫

2024-01-15 08:59:31

Docker優(yōu)化

2021-11-14 05:00:56

排查Sdk方式

2021-06-01 07:55:42

DockerEOFk8s

2022-01-26 19:42:05

MySQL亂碼排查

2021-12-01 15:03:56

Java開發(fā)代碼

2024-09-25 14:25:47

API接口

2019-09-10 13:34:30

Linux操作系統(tǒng)軟件

2024-12-02 09:10:15

Redis性能優(yōu)化

2021-03-25 16:15:24

SQL工具慢查詢

2022-11-30 21:32:23

開源buildah工具

2023-07-26 07:18:54

死鎖線程池

2021-06-28 08:00:00

Python開發(fā)編程語言
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

美女黄色片视频| 99一区二区| 手机在线免费看毛片| 亚洲啊v在线免费视频| 香蕉影视欧美成人| 亚洲精美视频| 深爱激情五月婷婷| 久久精品国产亚洲aⅴ | 奇米网一区二区| 日韩中文在线| 欧美在线小视频| 日韩一级片免费视频| 国产私人尤物无码不卡| 国产乱码精品一区二区三区忘忧草| 97香蕉超级碰碰久久免费的优势| 亚洲欧美另类日本| 要久久电视剧全集免费| 欧美一区二区视频免费观看| 日韩精品免费播放| heyzo高清中文字幕在线| 国产精品色呦呦| 蜜桃导航-精品导航| 亚洲AV无码一区二区三区性| 美女高潮久久久| 69影院欧美专区视频| 裸体裸乳免费看| 污污网站免费在线观看| 国产在线日韩欧美| 国产精品女人久久久久久| 国产精品99精品| 中文字幕免费精品| 中文字幕亚洲精品| 中文字幕免费高清| 日韩母乳在线| 欧美mv日韩mv亚洲| 无套内谢丰满少妇中文字幕| 久久夜夜久久| 在线精品视频一区二区| 免费看一级大黄情大片| 成年网站在线视频网站| 亚洲欧美精品午睡沙发| 中文字幕久精品免| 午夜视频在线免费观看| 欧美激情一区二区在线| 日本高清不卡三区| 国产美女性感在线观看懂色av| 成人黄色网址在线观看| 97se视频在线观看| 精品人妻一区二区三区含羞草| 蜜臀va亚洲va欧美va天堂 | 国产精品一区二区三区四| 欧美在线免费| 美女性感视频久久久| 欧美风情第一页| 66视频精品| 久久福利视频网| 我家有个日本女人| 欧美区国产区| 88国产精品欧美一区二区三区| 日本一区二区三区四区五区| 亚洲精品色图| 日韩美女视频免费看| 中文字幕在线观看视频免费| 丝袜亚洲精品中文字幕一区| 国产精品 欧美在线| 成人毛片一区二区三区| 麻豆中文一区二区| 91系列在线播放| 亚洲高清视频网站| 99久久99久久精品免费观看| 精品一区二区国产| 激情小说 在线视频| 欧美国产激情二区三区| 伊甸园精品99久久久久久| 国产激情在线视频| 亚洲电影一区二区三区| 97国产精东麻豆人妻电影| 精品欧美一区二区三区在线观看 | 肉丝美足丝袜一区二区三区四| 一区中文字幕| 国产婷婷成人久久av免费高清| 少妇真人直播免费视频| 日韩在线第七页| 欧美成人一二三| 欧美激情亚洲综合| 蜜臀av性久久久久蜜臀aⅴ四虎 | 精品毛片在线观看| 91欧美一区二区| 亚洲午夜精品国产| 国产色婷婷在线| 色999日韩国产欧美一区二区| 最新天堂中文在线| 久久男人av| 少妇高潮 亚洲精品| www.av视频在线观看| 日韩av不卡一区二区| 91免费看网站| 国产三级视频在线看| 一区二区三区**美女毛片| 日韩精品综合在线| 国产成人免费| 亚洲精品v天堂中文字幕| 国产黄色录像视频| 日韩一级精品| 91久久久久久久久久久| 免费国产在线观看| 亚洲国产成人tv| 亚洲美女爱爱视频| 日韩精选在线| 久久久爽爽爽美女图片| 夜夜狠狠擅视频| 91性感美女视频| 超薄肉色丝袜足j调教99| free欧美| 日韩精品日韩在线观看| 国产盗摄x88av| 久久电影国产免费久久电影 | 久久久久亚洲av片无码v| 免费国产自久久久久三四区久久| 欧美成人sm免费视频| 99成人精品视频| 91丨porny丨国产入口| 久久久久久av无码免费网站下载| 国产综合色在线观看| 国产婷婷成人久久av免费高清| 黄色一级视频免费| 国模无码大尺度一区二区三区| 日本最新一区二区三区视频观看| gogo高清午夜人体在线| 欧美一区二视频| 三级黄色录像视频| 青青草91视频| 日韩精品无码一区二区三区| 欧美a级在线观看| 精品久久久久一区二区国产| 国语对白在线播放| 精品一区二区在线看| 亚洲欧美日韩不卡一区二区三区| 高潮一区二区| 亚洲色图15p| 日韩欧美在线观看免费| 久久一夜天堂av一区二区三区| 久久久久99精品成人片| 91精品久久久久久综合五月天| 欧美成人亚洲成人| 亚洲精品国偷拍自产在线观看蜜桃| 国产精品国产自产拍在线| 欧美wwwwwww| 日韩系列欧美系列| 92看片淫黄大片看国产片| 久久精品视频免费看| 日韩一区二区精品在线观看| 亚洲av无码一区二区三区在线| 国产乱码精品1区2区3区| 黄色录像特级片| 亚洲欧美日本国产| 久久久女人电视剧免费播放下载| 凸凹人妻人人澡人人添| 黑人精品xxx一区| 男人的天堂官网 | www.美色吧.com| 亚洲人体大胆视频| 欧美1o一11sex性hdhd| 忘忧草在线www成人影院| 少妇高潮久久77777| 国产美女www爽爽爽视频| 亚洲女人****多毛耸耸8| 欧美一级大片免费看| 9国产精品视频| 欧美一区二区影视| 91另类视频| 欧美精品在线看| 天天射天天色天天干| 欧美日韩一区二区在线| 九九九视频在线观看| 国精品**一区二区三区在线蜜桃| 国产精品无码免费专区午夜| 亚洲婷婷丁香| 亚洲free性xxxx护士白浆| a'aaa级片在线观看| 亚洲午夜色婷婷在线| av一区二区三| 日韩欧美国产激情| 日韩精品一区二区三区在线视频| 成人免费av资源| 黄色一级免费大片| 欧美日韩免费| 日韩电影大全在线观看| 精品亚洲二区| 国产成人免费91av在线| 日本无删减在线| 在线观看欧美日韩国产| 亚洲第一色网站| 欧美亚洲日本国产| 日本三级黄色大片| 中文字幕一区二区三中文字幕| 蜜桃色一区二区三区| 日韩精品国产欧美| 美女黄色免费看| 久久综合电影| 免费久久99精品国产自| 国内不卡的一区二区三区中文字幕| 久久久久久欧美| 永久免费av片在线观看全网站| 精品久久久久久久一区二区蜜臀| 波多野结衣小视频| 亚洲国产精品一区二区www在线 | 国产精品视频999| jizzjizz中国精品麻豆| 一区二区欧美久久| 香蕉视频国产在线| 欧美一区二区三区在线看| 高潮毛片又色又爽免费| 亚洲超碰97人人做人人爱| 小泽玛利亚一区二区免费| 国产喂奶挤奶一区二区三区| 中文字幕18页| 国产在线精品一区二区三区不卡 | 高清不卡在线观看| 亚洲免费999| 奶水喷射视频一区| 欧美一级视频免费看| 亚洲经典一区| 一区二区视频在线播放| 蜜桃精品wwwmitaows| 国产精品区一区二区三含羞草| 久久青草视频| 国产精品爽爽爽| av资源亚洲| 97视频在线观看播放| 亚洲欧美成人影院| www.欧美精品一二三区| 草草影院在线观看| 国产婷婷色综合av蜜臀av| 天天操天天干天天爱| 日韩三级高清在线| 国产sm主人调教女m视频| 欧美日韩第一区日日骚| 中文字幕日本人妻久久久免费| 欧美性xxxxhd| 精品国产xxx| 大桥未久av一区二区三区| 日韩三级免费看| 亚洲成人在线观看视频| 久久久久久天堂| 亚洲最新在线观看| 国语对白一区二区| 亚洲午夜影视影院在线观看| 美女视频黄免费| 亚洲第一综合色| www.日本精品| 日韩欧美亚洲范冰冰与中字| 亚洲国产成人无码av在线| 色综合久久中文综合久久牛| 九九热在线免费观看| 色综合久久中文字幕综合网| 五月天婷婷导航| 在线看国产一区二区| 中文字字幕在线中文乱码| 欧美久久久久免费| 国产熟女一区二区三区四区| 日韩午夜中文字幕| 日韩一区二区三区在线观看视频| 亚洲高清久久久久久| 亚洲欧美综合一区二区| 亚洲欧美日韩区| 欧美黄色激情| 欧美大片在线看| 黄色在线免费观看网站| 国产成人精品在线视频| 亚洲精品大片| 高清国产一区| 久久av资源| 在线免费观看成人网| 狠狠色综合网| 国产黄色特级片| 国产一区二区调教| www.啪啪.com| 欧美激情综合网| 曰本女人与公拘交酡| 精品久久久久久久大神国产| 色老头一区二区| 日韩一二三区不卡| 三级av在线| 麻豆国产va免费精品高清在线| 精灵使的剑舞无删减版在线观看| 57pao成人国产永久免费| 久久亚洲国产精品尤物| 国产精品日韩一区二区 | 亚洲欧美在线第一页| 日本不卡在线| 91精品国产91久久久久福利| 国产亚洲欧美日韩精品一区二区三区 | 亚洲大尺度在线观看| 日韩视频免费观看高清在线视频| 四虎影院在线播放| 久久天天躁狠狠躁夜夜爽蜜月| 免费一二一二在线视频| 成人中心免费视频| 亚洲区小说区图片区qvod按摩| 国产91av视频在线观看| 夜夜嗨网站十八久久| av在线免费看片| 久久综合久久久久88| 黄色一级视频免费| 欧美日韩成人激情| 神马久久精品| 欧美黑人巨大xxx极品| 成人精品国产亚洲| 久久国产欧美精品| 午夜精品久久99蜜桃的功能介绍| 中文字幕欧美人妻精品一区| 成人免费视频播放| 91麻豆精品成人一区二区| 在线观看一区日韩| 五月天丁香视频| 久久国产精品久久久| 韩日一区二区| 免费久久久一本精品久久区| 伊人精品视频| 国产大学生av| 亚洲毛片av在线| 一级片视频播放| 中文日韩在线视频| 少妇一区视频| 久久精品日韩| 一区在线免费观看| 性农村xxxxx小树林| 亚洲美女视频在线观看| 一级黄在线观看| 日韩中文视频免费在线观看| 欧美日韩免费观看视频| 精品中文字幕一区| 一本久道久久综合婷婷鲸鱼| 国产精品一区二区在线免费观看| 亚洲伦理在线精品| 国产后入清纯学生妹| 久久天天躁狠狠躁夜夜躁| 欧美videos粗暴| 亚洲午夜久久久影院伊人| 蜜臀久久99精品久久久久宅男 | 午夜精品视频一区二区三区在线看| 中文字幕第80页| 国产日韩v精品一区二区| www.久久精品视频| 亚洲美女动态图120秒| 免费观看一级欧美片| 欧美乱偷一区二区三区在线| 香蕉久久夜色精品国产| 免费看黄色的视频| 欧美曰成人黄网| gogogo高清在线观看免费完整版| 国产精品久久久久久av下载红粉| 成人a'v在线播放| 欧美一级特黄aaa| 亚洲激情一二三区| 囯产精品一品二区三区| 97婷婷涩涩精品一区| 啪啪亚洲精品| 免费一区二区三区在线观看| 国产精品久久久久精k8| 国产精品一区二区黑人巨大| 萌白酱国产一区二区| 成人在线tv视频| 日本一区二区黄色| 亚洲国产精品黑人久久久 | 精品对白一区国产伦| 极品美鲍一区| 水蜜桃一区二区| 国产又黄又大久久| 国产精品30p| 亚洲色图综合网| 亚洲男人在线| 欧日韩免费视频| 国产视频一区不卡| 99国产精品久久久久久久成人| 欧美黑人巨大xxx极品| 欧美人与物videos另类xxxxx| 嫩草影院国产精品| 一区二区三区视频在线观看| 日韩在线无毛| 亚洲一区二区三区视频播放| 国产欧美69| 2017亚洲天堂| 亚洲缚视频在线观看| 欧美久久久网站| 日韩欧美不卡在线| 国产欧美日韩中文久久| 国内毛片毛片毛片毛片| 国产xxx69麻豆国语对白| 亚洲电影影音先锋| 中文字幕丰满孑伦无码专区| 欧美人与z0zoxxxx视频| 爱草tv视频在线观看992| 亚洲人成77777| k8久久久一区二区三区 | 日本一级黄色录像| www.日韩系列| 亚洲最好看的视频| 丰满少妇一区二区三区专区|