精品欧美一区二区三区在线观看 _久久久久国色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ù)棧公眾號

91视频在线视频| 国产偷人妻精品一区| 国产在线高潮| 成人av网站在线观看| 欧美在线一级视频| 毛片久久久久久| 成人av影音| 欧美三级视频在线| 精品一区二区三区无码视频| 免费在线一级视频| 国产综合色产在线精品| 韩国精品久久久999| 久久久视频6r| 91精品入口| 欧美日韩在线免费视频| 日韩黄色片在线| 丝袜视频国产在线播放| 国产综合久久久久久鬼色| 91高清在线免费观看| 日韩在线不卡av| 免费视频亚洲| 亚洲成人网久久久| xxxx在线免费观看| 亚洲成人人体| 午夜不卡av在线| 欧美日韩激情四射| 美女隐私在线观看| 久久免费视频一区| 国产乱人伦精品一区二区| 一级黄色大毛片| 丝袜脚交一区二区| 午夜欧美大片免费观看| 少妇影院在线观看| 97精品97| 最近2019中文免费高清视频观看www99 | 国产三级av在线播放 | 你懂的视频在线一区二区| 国产v在线观看| 久久99精品久久久久久动态图 | 国产综合精品视频| 狠久久av成人天堂| 欧美精品在线免费| 精品自拍偷拍视频| 91九色精品| xxx一区二区| 91久久久久久久久久久久久久| 国产99久久久国产精品成人免费| 亚洲国产毛片完整版| 国产伦理在线观看| 日韩一级淫片| 日韩女优视频免费观看| 亚洲综合20p| 欧美成人精品一级| 欧美一区二区三区小说| 伊人成人免费视频| 97精品久久| 亚洲黄色av女优在线观看| 亚洲一二区在线观看| 日韩成人综合网站| 欧美一区二区三区免费观看视频| 欧美第一页浮力影院| 欧美久久久网站| 欧美妇女性影城| 女女调教被c哭捆绑喷水百合| 日韩精品中文字幕吗一区二区| 91麻豆精品国产91久久久资源速度| 天天操,天天操| 成人短视频软件网站大全app| 欧美剧情电影在线观看完整版免费励志电影 | 图片一区二区| 日韩一卡二卡三卡| 国产女人18毛片水真多18| 欧美色图五月天| 一区二区欧美久久| 亚洲女人毛茸茸高潮| 天天av综合| 午夜精品美女自拍福到在线| 91国产丝袜播放在线| 久久福利影视| 成人国产精品av| 日韩在线视频观看免费| 久久亚洲一级片| 正义之心1992免费观看全集完整版| 久久日韩视频| 舔着乳尖日韩一区| 五月婷婷激情久久| 亚洲一区二区电影| 亚洲午夜激情免费视频| 亚洲av鲁丝一区二区三区| 99国产精品99久久久久久粉嫩| 国产成人精品亚洲精品| 国产精品久久久久久免费播放| 国产69精品久久777的优势| 久久精品ww人人做人人爽| 国产专区在线播放| 一区二区三区四区av| 男人揉女人奶房视频60分| 日韩三区四区| 亚洲精品成人免费| 永久免费未视频| 国产精品久久777777毛茸茸 | 国产精品videossex| 亚洲性生活视频在线观看| 国产在线一卡二卡| 久久青草久久| 成人在线免费观看一区| 97视频精彩视频在线观看| 五月婷婷色综合| 污污的视频免费观看| 天美av一区二区三区久久| 久久九九全国免费精品观看| 欧美三级一区二区三区| 国产在线国偷精品产拍免费yy| 乱一区二区三区在线播放| 黄色的网站在线观看| 日韩欧美高清视频| 久久久久久久久久久久国产精品| 欧美色女视频| 51精品国产黑色丝袜高跟鞋| 国产xxxxxx| 国产精品午夜春色av| 每日在线更新av| av毛片精品| 插插插亚洲综合网| 中文字幕一区二区人妻痴汉电车| 91在线国产观看| 中文字幕人妻熟女人妻洋洋| 男人天堂久久| 国产一区二区三区三区在线观看| 国产成人亚洲精品自产在线| 国产电影一区二区三区| 在线观看欧美激情| 亚洲高清国产拍精品26u| 国产亚洲欧美日韩一区二区| 黄网在线观看视频| gogo大胆日本视频一区| 欧美日韩中文字幕在线播放| 91精品一区| 久久精品视频在线| 一级特黄aaa大片在线观看| 国产偷v国产偷v亚洲高清| 尤物av无码色av无码| 欧美电影在线观看完整版| 欧美黑人又粗大| 亚洲成人第一区| 亚洲精品乱码久久久久久黑人| 成人av毛片在线观看| 99成人在线视频| 成人美女av在线直播| 亚洲成人三级| 在线不卡中文字幕播放| 亚洲熟女少妇一区二区| 精品一区二区三区久久| 五月天av影院| 色播一区二区| 久久久女女女女999久久| 亚洲av无码乱码国产麻豆| 亚洲最大的成人av| 中文字幕乱码在线| 香蕉成人久久| 亚洲不卡一卡2卡三卡4卡5卡精品| 女厕盗摄一区二区三区| 精品亚洲va在线va天堂资源站| 久久精品一二区| 久久免费看少妇高潮| 精品少妇无遮挡毛片| japanese国产精品| 91啪国产在线| 国产区美女在线| 日韩精品在线观看一区二区| 在线观看污污网站| 国产精品高潮呻吟| 中文字幕avav| 亚洲片区在线| 日韩三级电影| 国产精品欧美一区二区三区不卡| 欧美激情三级免费| 欧美视频免费一区二区三区| 在线精品国精品国产尤物884a| 国精产品久拍自产在线网站| 国产福利视频一区二区三区| 国产成人精品视频免费看| 国内精品伊人久久久| 亚洲影院高清在线| 捆绑调教日本一区二区三区| 国产亚洲精品日韩| 亚洲免费一级片| 色噜噜狠狠成人中文综合| 永久av免费网站| 99精品视频一区| 97超碰成人在线| 伊人激情综合| 亚洲人成人77777线观看| 视频在线亚洲| 国产欧美精品在线播放| av丝袜在线| www.亚洲成人| 深夜福利视频在线免费观看| 欧美男男青年gay1069videost | 成人欧美视频在线| 日本欧美一区| 久久久久久com| 午夜视频在线| 亚洲午夜久久久影院| 国产人妖在线播放| 在线观看三级视频欧美| 日韩av在线天堂| 日韩美女啊v在线免费观看| 国产精品一区二区入口九绯色| 韩国精品一区二区| 日韩亚洲在线视频| 亚洲香蕉网站| 国产成年人在线观看| 欧美美乳视频| 久久久久久精| av成人综合| 92福利视频午夜1000合集在线观看| 中文字幕资源网在线观看免费 | 婷婷综合六月| 97婷婷涩涩精品一区| 国产午夜精品久久久久免费视| 亚洲欧美在线免费| 婷婷在线观看视频| 欧美成人一区二区三区| 国产一区二区视频免费观看| 色婷婷久久久亚洲一区二区三区 | 国模吧视频一区| 正在播放国产精品| 精品一区二区三区中文字幕老牛| 国产伦精品一区二区三区在线| aa亚洲一区一区三区| 国产精品第3页| 欧美电影免费看| 欧美在线观看视频| 欧美xxx性| 日本亚洲欧洲色α| 日本不卡一二三| 欧美综合第一页| 水蜜桃在线视频| 欧美一区二区三区……| 欧美freesex黑人又粗又大| 久久免费成人精品视频| 婷婷色在线资源| 九九热这里只有精品免费看| 好吊日视频在线观看| 久久久av电影| 超碰在线网址| 欧美激情亚洲综合一区| 丰乳肥臀在线| 97精品视频在线播放| 九九色在线视频| 欧美精品电影在线| 国产不卡123| 欧美诱惑福利视频| 日韩性xxx| 国产精品夜间视频香蕉| 日本欧美在线| 成人精品一二区| 国产美女撒尿一区二区| 精品久久久久久中文字幕动漫| 综合国产视频| 亚洲春色在线视频| 欧美一区亚洲| 日韩欧美精品免费| 老司机久久99久久精品播放免费| 黑鬼大战白妞高潮喷白浆| 亚洲欧美日韩综合国产aⅴ| 日本一区二区黄色| 免费欧美日韩国产三级电影| 国产精品视频中文字幕| 国产精品白丝jk黑袜喷水| 久久人妻少妇嫩草av蜜桃| av网站免费线看精品| av网在线播放| 中文字幕一区二区在线播放| 激情五月婷婷在线| 福利视频导航一区| 中文字字幕在线观看| 欧美大胆一级视频| 九色在线视频蝌蚪| 久久资源免费视频| а√天堂中文资源在线bt| 国产精品第1页| 69精品国产久热在线观看| 欧洲一区二区在线观看| 亚洲精品中文字幕乱码| 国产精品网站免费| 另类人妖一区二区av| 东京热av一区| 国产精品视频免费| 国产精品成人网站| 欧美性受xxxx| 性插视频在线观看| 久久精品99久久久久久久久| 欧美aa免费在线| 亚洲一区国产精品| 国产精品一区高清| 久草免费福利在线| 精品一区二区三区在线播放| 免费黄色三级网站| 亚洲色图.com| 五月婷婷激情五月| 亚洲国产日韩欧美在线动漫| 午夜免费福利在线观看| 国产69久久精品成人看| 精品一区视频| 日本亚洲导航| 亚洲综合日本| 日批免费观看视频| 椎名由奈av一区二区三区| 欧美黄色一级大片| 亚洲缚视频在线观看| 国产三区视频在线观看| 国产精品久久99久久| 你懂的在线观看一区二区| 2022中文字幕| 国产又黄又大久久| 在线免费看视频| 91久久线看在观草草青青| 手机看片1024日韩| 九色成人免费视频| 国产精品亚洲四区在线观看| 亚洲精品国产精品国自产观看| 欧美专区在线| 国产熟妇搡bbbb搡bbbb| 天天色天天爱天天射综合| 欧美一级特黄aaaaaa| 久久91亚洲精品中文字幕奶水 | 日韩不卡在线观看日韩不卡视频| 好吊一区二区三区视频| 亚洲午夜久久久久久久久久久| 国产喷水吹潮视频www| 日韩视频在线免费| 日韩免费在线电影| 免费看av软件| 韩国欧美国产1区| 永久久久久久久| 欧美一级精品大片| caopen在线视频| 亚洲自拍欧美另类| 中文字幕亚洲综合久久五月天色无吗'' | 午夜伦理福利在线| 久久久久欧美| 久久尤物视频| 国产视频不卡在线| 欧美亚洲自拍偷拍| 尤物网址在线观看| 成人免费网站在线| 影视一区二区| 亚洲一区和二区| 亚洲成人免费av| 少妇av在线播放| 国产91精品黑色丝袜高跟鞋| 亚洲春色h网| 三年中国国语在线播放免费| 国产欧美日韩一区二区三区在线观看 | 在线播放不卡| 中文乱码人妻一区二区三区视频| 精品国产老师黑色丝袜高跟鞋| 青青草免费观看免费视频在线| 日韩免费在线看| 国产国产精品| 女同性αv亚洲女同志| 欧美日韩免费区域视频在线观看| 男操女在线观看| 成人精品一区二区三区电影免费| 综合日韩在线| 亚洲精品乱码久久久久久不卡| 色一区在线观看| 黄网站app在线观看| 风间由美一区二区三区| 国产精品亚洲欧美| www.99re6| 亚洲黄色有码视频| 向日葵视频成人app网址| 自拍偷拍一区二区三区| 成人丝袜高跟foot| 中国女人真人一级毛片| 久久国产精品电影| 亚洲图区在线| 一级黄色片在线免费观看| 精品福利在线视频| 三区四区在线视频| 韩国成人一区| 精品一区二区三区日韩| 日韩欧美a级片| 日韩在线小视频| 久久夜色电影| 在线视频一二区| 日韩欧美亚洲一二三区| 超碰在线网址| 日本视频一区二区在线观看| 国产美女精品在线| 国产日产精品一区二区三区| 中文字幕最新精品| 西瓜成人精品人成网站| 国产不卡的av| 日本精品一级二级| 成人一级福利| 久久久天堂国产精品|