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

成功優化!Java 基礎 Docker 鏡像從 674MB 縮減到 58MB 的經驗分享

開發 前端
本文將深入探討如何通過 jlink 工具生成更小的 Java 運行時環境(JRE)鏡像,并自動化整個過程。我們將分析不同模塊的依賴關系,確保僅包括運行應用程序所需的最小模塊。通過這樣的方法,不僅可以提高應用程序的效率,還能優化資源的使用,讓我們的微服務更加輕量、靈活。

在當今的軟件開發領域,微服務架構和容器化應用已成為常態。隨著應用程序的復雜性和規模不斷增加,開發者們面臨的一個主要挑戰是如何有效管理和優化應用程序的體積。尤其是在使用 Java 進行開發時,生成的 Docker 鏡像往往會相對較大,這不僅影響了部署速度,還增加了網絡傳輸的負擔和存儲成本。因此,如何精簡鏡像大小成為了每個開發者亟待解決的問題。

本文將深入探討如何通過 jlink 工具生成更小的 Java 運行時環境(JRE)鏡像,并自動化整個過程。我們將分析不同模塊的依賴關系,確保僅包括運行應用程序所需的最小模塊。通過這樣的方法,不僅可以提高應用程序的效率,還能優化資源的使用,讓我們的微服務更加輕量、靈活。

我們將使用之前文章中構建的Spring Web應用來演示這些技巧,該文章是關于使用RFC-9457規范進行錯誤處理。我們的應用僅包含兩個端點:

GET /users/

: 根據ID獲取用戶POST /users : 創建新用戶

@RestController
@RequestMapping("/api/users")
@RequiredArgsConstructor
public class UserController {
    private final UserService userService;

    @GetMapping("{id}")
    public User getUser(@PathVariable Long id) {
        return userService.getUserById(id)
                .orElseThrow(() -> new UserNotFoundException(id, "/api/users"));
    }

    @PostMapping
    public User createUser(@Valid @RequestBody User user) {
        return userService.createUser(user);
    }
}

看起來沒什么吧?但正如你將看到的,即使是最簡單的Docker鏡像(不進行任何優化)大小也可能相當大。

我們為什么要關心鏡像大小?

鏡像大小對你作為開發者或組織的性能有顯著影響。特別是在處理多個服務的大型項目時,鏡像的大小可能會相當龐大,這可能會讓你花費大量的金錢和時間。

一些避免大型鏡像的原因包括:

  • 磁盤空間:你在Docker注冊表和生產服務器上浪費了磁盤空間。
  • 構建時間延長:鏡像越大,構建和推送鏡像所需的時間越長。
  • 安全性:鏡像越大,依賴項越多,攻擊面也越大。
  • 帶寬:鏡像越大,從注冊表拉取和推送鏡像時的帶寬消耗越高。

使用簡單明了的Dockerfile

基礎鏡像 Matter ??? : 選擇合適的基礎鏡像

在考慮優化之前,你應該始終注意用于打包應用的基礎鏡像。你選擇的基礎鏡像可能對最終鏡像的大小產生顯著影響。

可以用來打包Java應用的基礎鏡像有幾種,包括:

  • JDK Alpine基礎鏡像:這些鏡像體積較小,但不適合所有應用,因此可能會面臨一些庫的兼容性問題。
  • JDK Slim基礎鏡像:這些鏡像基于Debian或Ubuntu,相較于完整的JDK鏡像來說體積較小,但仍然比較大。
  • JDK完整基礎鏡像:這些鏡像體積較大,包含運行應用所需的所有模塊和依賴項。

為了給你一個基礎鏡像大小的概念,以下是openjdk:17-jdk-slim(瘦身版)和eclipse-temurin:17-jdk-alpine鏡像大小的比較:

已知應用程序(jar)的大小約為20MB。

圖片圖片

為了在Docker鏡像中打包我們的工件,我們需要在應用根目錄中定義一個Dockerfile,如下所示:

FROM openjdk:17-jdk-slim

# 設置容器中的工作目錄
WORKDIR /app

# 創建用戶
RUN addgroup --system spring && adduser --system spring --ingroup spring

# 切換到用戶
USER spring:spring

COPY target/*.jar app.jar

EXPOSE 8080

CMD ["java", "-jar", "app.jar"]

定義好Dockerfile后,可以使用以下命令構建鏡像:

docker build -t user-service .

完成后,你應該會有一個名為user-service的Docker鏡像,正如你所看到的,與應用程序工件的大小相比,鏡像的大小相當大,約為674MB。

圖片圖片

等等,這只是一個只有兩個端點的小項目,沒有任何依賴項,那么對于一個有數十個依賴項和文件的應用來說,情況會如何呢?

使用 eclipse-temurin:17-jdk-alpine 作為基礎鏡像。

Dockerfile.base-temurin

FROM eclipse-temurin:17-jdk-alpine

ARG APPLICATION_USER=spring
# 創建一個用戶來運行應用,不以root用戶運行
RUN addgroup --system $APPLICATION_USER && adduser --system $APPLICATION_USER --ingroup $APPLICATION_USER

# 創建應用目錄
RUN mkdir /app && chown -R $APPLICATION_USER /app

# 設置運行應用的用戶
USER $APPLICATION_USER

# 將jar文件復制到容器中
COPY --chown=$APPLICATION_USER:$APPLICATION_USER target/*.jar /app/app.jar

# 設置工作目錄
WORKDIR /app

# 暴露端口
EXPOSE 8080

# 運行應用
ENTRYPOINT ["java", "-jar", "/app/app.jar"]

在使用以下命令構建鏡像后:

docker build -t user-service:alpine -f Dockerfile.base-alpine . --platform=linux/amd64

?? 附注

重要提示:如果你在Apple Silicon的MAC上構建鏡像,可能會遇到以下問題:

> [internal] load metadata for docker.io/library/eclipse-temurin:17-jdk-alpine:
Dockerfile:2
1 | # First stage, build the custom JRE
2 | >>> FROM eclipse-temurin:17-jdk-alpine AS jre-builder
3 |
4 | # Install binutils, required by jlink
ERROR: failed to solve: eclipse-temurin:17-jdk-alpine: no match for platform in manifest: not found

要解決此問題,你可以在Docker構建命令中添加:

--platform=linux/amd64

或者通過運行以下命令將默認平臺設置為 linux/amd64:

export DOCKER_DEFAULT_PLATFORM=linux/amd64

使用 eclipse-temurin:17-jdk-alpine 作為基礎鏡像構建完鏡像后,我們得到了這個結果:

圖片

看看兩個鏡像的大小,使用 eclipse-temurin:17-jdk-alpine 作為基礎鏡像的鏡像大小為180MB,比使用 openjdk:17-jdk-slim 作為基礎鏡像的674MB小73%。

實際優化

等一下,為什么我們不能使用JRE鏡像而使用JDK鏡像呢?

好問題!這是因為從Java 11開始,JRE不再可用。

最重要的注意事項是“用戶可以使用jlink創建更小的自定義運行時”。

圖片圖片

使用 jlink 構建自定義 JRE 鏡像

jlink 是一個工具,可用于創建僅包含運行應用所需模塊的自定義運行時鏡像。

?? 如果你的應用不與數據庫交互,則無需在鏡像中包含 java.sql 模塊。如果你不與桌面GUI交互,則無需在鏡像中包含 java.desktop 模塊,等等。

這有點像JRE鏡像的替代品,但可以更好地控制你想要在鏡像中使用的模塊。

因此,使用 jlink,我們的Dockerfile應該如下所示:

# 第一階段,構建自定義JRE
FROM eclipse-temurin:17-jdk-alpine AS jre-builder

# 安裝binutils,jlink所需
RUN apk update && apk add binutils

# 構建小型JRE鏡像
RUN $JAVA_HOME/bin/jlink \
         --verbose \
         --add-modules ALL-MODULE-PATH \
         --strip-debug \
         --no-man-pages \
         --no-header-files \
         --compress=2 \
         --output /optimized-jdk-17

# 第二階段,使用自定義JRE并構建應用鏡像
FROM alpine:latest
ENV JAVA_HOME=/opt/jdk/jdk-17
ENV PATH="${JAVA_HOME}/bin:${PATH}"

# 從基礎鏡像中復制JRE
COPY --from=jre-builder /optimized-jdk-17 $JAVA_HOME

# 添加應用用戶
ARG APPLICATION_USER=spring

# 創建一個用戶來運行應用,不以root用戶運行
RUN addgroup --system $APPLICATION_USER && adduser --system $APPLICATION_USER --ingroup $APPLICATION_USER

# 創建應用目錄
RUN mkdir /app && chown -R $APPLICATION_USER /app

COPY --chown=$APPLICATION_USER:$APPLICATION_USER target/*.jar /app/app.jar

WORKDIR /app

USER $APPLICATION_USER

EXPOSE 8080
ENTRYPOINT [ "java", "-jar", "/app/app.jar" ]

讓我們解釋一下我們在這里所做的事情:

我們有兩個階段,第一階段用于使用 jlink 構建自定義JRE鏡像,第二階段用于將應用打包在一個精簡的Alpine鏡像中。

在第一階段,我們使用 eclipse-temurin:17-jdk-alpine 鏡像來使用 jlink 構建自定義JRE鏡像。然后,我們安裝 binutils,這是 jlink 所需的,然后運行 jlink 來構建一個小型JRE鏡像,使用 --add-modules ALL-MODULE-PATH(目前)包含運行應用所需的所有模塊。

在第二階段,我們使用Alpine鏡像(其大小約為3MB)作為基礎鏡像來打包我們的應用,然后從第一階段獲取自定義JRE并將其用作 JAVA_HOME。

Dockerfile的其余部分與之前的相同,只是復制工件并使用自定義用戶(而不是root)設置入口點。

然后我們可以使用以下命令構建鏡像:

docker build -t user-service:jlink-all-modules-temurin -f Dockerfile.jlink-all-modules.temurin .

如果你運行命令:

docker images user-service

你會看到新Docker鏡像的大小現在為85.3MB,比基礎鏡像小約95MB ????

圖片圖片

為了確保鏡像按預期工作,你可以運行以下命令:

docker run -p 8080:8080 user-service:jlink-all-modules-temurin

你應該會看到應用按預期運行。

圖片圖片

這還不夠 ????作為優秀的開發者,我們總是希望改進我們的工作,讓我們看看如何進一步減少鏡像的大小。

目前鏡像的大小依然較大,這是因為在 jlink 命令中使用 --add-modules ALL-MODULE-PATH 時,我們包含了運行應用程序所需的所有模塊,但我們并不需要所有模塊。讓我們看看如何僅包含運行應用程序所需的模塊,從而獲得更小的鏡像大小。

如何確定運行應用程序所需的模塊?我們可以使用 JDK 附帶的 jdeps 工具。jdeps 是一個可以分析 jar 文件依賴關系并生成所需模塊列表的工具。

為此,我們可以在項目根目錄下運行以下命令:

jdeps --ignore-missing-deps -q \
      --recursive \
      --multi-release 17 \
      --print-module-deps \
      --class-path BOOT-INF/lib/* \
      target/spring-error-handling-rfc-9457-0.0.1-SNAPSHOT.jar

這將打印出運行應用程序所需的模塊列表,在我們的案例中為:

java.base,java.compiler,java.desktop,java.instrument,java.management,java.naming,java.net.http,java.prefs,java.rmi,java.scripting,java.security.jgss,java.sql,jdk.jfr,jdk.unsupported

我們可以簡單地將這些模塊替代 ALL-MODULE-PATH,修改 jlink 命令如下:

Dockerfile.jlink-known-modules.temurin

# 第一階段,構建自定義 JRE
FROM openjdk:17-jdk-slim AS jre-builder

# 安裝 jlink 所需的 binutils
RUN apt-get update -y &&  \
    apt-get install -y binutils

# 構建小型 JRE 鏡像
RUN $JAVA_HOME/bin/jlink \
         --verbose \
         --add-modules java.base,java.compiler,java.desktop,java.instrument,java.management,java.naming,java.net.http,java.prefs,java.rmi,java.scripting,java.security.jgss,java.sql,jdk.jfr,jdk.unsupported \
         --strip-debug \
         --no-man-pages \
         --no-header-files \
         --compress=2 \
         --output /optimized-jdk-17

# 第二階段,使用自定義 JRE 并構建應用鏡像
FROM alpine:latest
ENV JAVA_HOME=/opt/jdk/jdk-17
ENV PATH="${JAVA_HOME}/bin:${PATH}"

# 從基礎鏡像復制 JRE
COPY --from=jre-builder /optimized-jdk-17 $JAVA_HOME

# 添加應用用戶
ARG APPLICATION_USER=spring

# 創建用戶以運行應用程序,不以 root 身份運行
RUN addgroup --system $APPLICATION_USER &&  adduser --system $APPLICATION_USER --ingroup $APPLICATION_USER

# 創建應用程序目錄
RUN mkdir /app && chown -R $APPLICATION_USER /app

COPY --chown=$APPLICATION_USER:$APPLICATION_USER target/*.jar /app/app.jar

WORKDIR /app

USER $APPLICATION_USER

EXPOSE 8080
ENTRYPOINT [ "java", "-jar", "/app/app.jar" ]

然后我們可以使用以下命令構建鏡像:

docker build -t user-service:jlink-known-modules-temurin -f Dockerfile.jlink-known-modules.temurin .

這里是構建后的鏡像大小:

圖片圖片

我們得到了一個較小的鏡像,大小為 57.8MB,而不是 85.3MB。

這很好,但我們能否自動化這個過程,而不是手動運行 jdeps 命令然后將模塊復制到 jlink 命令中?

在 Dockerfile 中自動化該過程

Dockerfile.jlink-with-jdeps.temurin

# 第一階段,構建自定義 JRE
FROM eclipse-temurin:17-jdk-alpine AS jre-builder

RUN mkdir /opt/app
COPY . /opt/app

WORKDIR /opt/app

ENV MAVEN_VERSION 3.5.4
ENV MAVEN_HOME /usr/lib/mvn
ENV PATH $MAVEN_HOME/bin:$PATH

RUN apk update && \
    apk add --no-cache tar binutils

RUN wget http://archive.apache.org/dist/maven/maven-3/$MAVEN_VERSION/binaries/apache-maven-$MAVEN_VERSION-bin.tar.gz && \
  tar -zxvf apache-maven-$MAVEN_VERSION-bin.tar.gz && \
  rm apache-maven-$MAVEN_VERSION-bin.tar.gz && \
  mv apache-maven-$MAVEN_VERSION /usr/lib/mvn

RUN mvn package -DskipTests
RUN jar xvf target/spring-error-handling-rfc-9457-0.0.1-SNAPSHOT.jar
RUN jdeps --ignore-missing-deps -q  \
    --recursive  \
    --multi-release 17  \
    --print-module-deps  \
    --class-path 'BOOT-INF/lib/*'  \
    target/spring-error-handling-rfc-9457-0.0.1-SNAPSHOT.jar > modules.txt

# 構建小型 JRE 鏡像
RUN $JAVA_HOME/bin/jlink \
         --verbose \
         --add-modules $(cat modules.txt) \
         --strip-debug \
         --no-man-pages \
         --no-header-files \
         --compress=2 \
         --output /optimized-jdk-17

# 第二階段,使用自定義 JRE 并構建應用鏡像
FROM alpine:latest
ENV JAVA_HOME=/opt/jdk/jdk-17
ENV PATH="${JAVA_HOME}/bin:${PATH}"

# 從基礎鏡像復制 JRE
COPY --from=jre-builder /optimized-jdk-17 $JAVA_HOME

# 添加應用用戶
ARG APPLICATION_USER=spring

# 創建用戶以運行應用程序,不以 root 身份運行
RUN addgroup --system $APPLICATION_USER &&  adduser --system $APPLICATION_USER --ingroup $APPLICATION_USER

# 創建應用程序目錄
RUN mkdir /app && chown -R $APPLICATION_USER /app

COPY --chown=$APPLICATION_USER:$APPLICATION_USER target/*.jar /app/app.jar

WORKDIR /app

USER $APPLICATION_USER

EXPOSE 8080
ENTRYPOINT [ "java", "-jar", "/app/app.jar" ]

然后我們可以使用以下命令構建鏡像:

docker build -t user-service:jlink-with-jdeps.temurin -f Dockerfile.jlink-with-jdeps.temurin . --platform=linux/amd64

圖片圖片

額外提示在結束之前,請注意,您可以使用 .dockerignore 文件排除某些文件和目錄,以減少鏡像在中間階段的大小。

您還應該注意,選擇小型基礎鏡像是好的,但請確保它具備良好的安全策略,并與您的應用程序兼容。

結論

通過本文的探討,我們成功展示了如何利用 jlink 工具和 jdeps 工具來生成更加精簡的 Java 鏡像。我們不僅減少了鏡像的體積,從 85.3MB 降至 57.8MB,節省了大量的存儲和傳輸資源,而且還引入了自動化的過程,進一步提升了開發效率。

在持續追求優化的過程中,自動化工具和最佳實踐是每個開發者的得力助手。通過使用 .dockerignore 文件來排除不必要的文件和目錄,我們還可以在構建鏡像的中間階段進一步減少體積。選擇一個適合的基礎鏡像并確保其安全性和兼容性,也同樣重要。

最后,優化鏡像不僅能提升應用程序的性能,更能增強整體系統的可維護性和可擴展性。希望大家能夠在實際項目中應用這些技術,進一步推動軟件開發的高效化和現代化。

責任編輯:武曉燕 來源: 路條編程
相關推薦

2021-01-26 09:30:58

Docker運維命令

2024-11-01 12:10:57

2013-03-26 10:10:38

服務器RubyGo

2021-08-30 07:08:59

Docker鏡像服務器

2019-11-12 13:30:07

開源技術 軟件

2023-05-29 12:35:09

模型ChatGPT

2017-02-09 17:30:05

Android應用瘦身

2022-05-12 08:04:50

Docker鏡像Python

2012-03-08 21:41:10

App Store

2022-05-02 17:03:32

容器鏡像ReactJS

2009-11-27 09:30:58

PHP函數mb_str

2021-08-30 16:47:00

Firefox 93Chrome簡化

2016-05-18 13:23:38

58同城架構設計運維

2012-04-28 14:07:41

AMD數據中心

2011-05-16 17:36:05

SEO

2018-10-16 09:35:25

Facebook攻擊漏洞

2010-03-05 09:00:28

2018-09-10 17:41:15

智造數字化轉型智能工廠

2013-03-14 09:42:58

GoRuby

2009-12-18 17:01:37

Ruby基礎代碼
點贊
收藏

51CTO技術棧公眾號

泷泽萝拉在线播放| 免费一级特黄毛片| 国产女人18毛片水真多| 国模 一区 二区 三区| 亚洲成人性视频| 国产日韩一区二区在线观看| 免费网站成人| 99视频精品在线| 成人精品久久av网站| 日本三级中文字幕| 久久精品国内一区二区三区水蜜桃 | 欧美系列一区| 国产又黄又大又爽| 亚洲永久网站| 久久99精品久久久久久青青91| 亚洲天堂网一区二区| 在线视频成人| 色婷婷一区二区三区四区| 中文字幕在线亚洲三区| 神马久久久久| 国产.欧美.日韩| 国产精品视频区| www.av麻豆| 雨宫琴音一区二区三区| 国产亚洲一级高清| 亚洲の无码国产の无码步美| 日韩一级特黄| 色综合久久久久网| 黄页免费在线观看视频| 麻豆视频在线观看免费| 成人黄色a**站在线观看| 国产欧美在线播放| 无码人妻av一区二区三区波多野| 欧美日韩网站| 久久福利视频导航| 99在线视频免费| 日韩av影院| 精品国产乱码久久久久久夜甘婷婷 | 日韩在线导航| 久色视频在线| 久久综合av免费| 国产伦精品一区二区三区高清版| 99国产精品99| 国产一区二区精品久久91| 国产精品一区二区久久久久| 少妇久久久久久久| 首页亚洲欧美制服丝腿| 欧美最猛性xxxx| 日本在线免费观看| 1024成人| 91av在线精品| 在线能看的av| 亚洲一区欧美二区| 91av在线免费观看视频| 日本特黄特色aaa大片免费| 欧美午夜精品| 国语自产精品视频在线看| 精品视频在线观看免费| 欧美日韩在线大尺度| 欧美高清视频在线观看| 免费一级片在线观看| 欧美久久综合| 欧美精品久久久久久久免费观看 | 亚洲国产日本| 性色av一区二区三区免费| 日本最新中文字幕| 国产美女精品| 国产精品久久国产精品99gif| 国产99免费视频| 免费成人在线网站| 91在线免费观看网站| www.色呦呦| caoporm超碰国产精品| 欧美一级爽aaaaa大片| 成人影视在线播放| 亚洲欧洲综合另类在线| 无码熟妇人妻av在线电影| 国产传媒av在线| 欧美中文字幕一区二区三区| 色网站在线视频| 国产成人一二片| 亚洲视频第一页| 中国毛片直接看| 影音先锋中文字幕一区| 日本中文字幕不卡免费| 一区二区视频播放| 国产电影精品久久禁18| 鲁丝一区二区三区免费| 午夜不卡视频| 亚洲国产另类精品专区| 成人观看免费完整观看| 老司机亚洲精品一区二区| 亚洲第一免费网站| jizz日本在线播放| 欧美日韩国产亚洲一区| 国产成人精品一区二区在线| www.亚洲天堂.com| 国产性天天综合网| 一级黄色片播放| 污污视频网站在线| 免费视频观看成人| 精品少妇一区二区三区在线视频| 蜜臀av一区二区三区有限公司| 成人在线免费观看网站| 欧美国产日韩视频| 中文字幕你懂的| 不卡一区二区三区四区| 天堂精品一区二区三区| 成人女同在线观看| 欧美少妇性性性| 欧美xxxx×黑人性爽| 91影院成人| 8090成年在线看片午夜| 国产高清免费观看| 国产欧美视频在线观看| 久在线观看视频| 国产精品一级在线观看| 亚洲精品720p| 欧美精品色哟哟| 久久激情综合网| 日本成人黄色| 在线观看的黄色| 精品区一区二区| 欧美黑人性猛交xxx| 日日摸夜夜添夜夜添亚洲女人| 国产精品一区二区三区免费 | 欧美第一黄色网| 欧美 亚洲 另类 激情 另类| 97久久精品人人爽人人爽蜜臀| 成年丰满熟妇午夜免费视频| 91九色综合| 亚洲视频欧美视频| 99精品视频99| 不卡的av网站| 国产精品成人久久电影| 亚洲成人偷拍| 蜜臀久久99精品久久久久久宅男 | 激情五月婷婷综合网| 三区精品视频观看| 3d性欧美动漫精品xxxx软件| 日韩精品在线视频观看| 国产精品美女久久久久av爽| 高清不卡一区二区在线| japanese在线播放| 成人污污视频| 欧美成人精品影院| 精品人妻一区二区三区换脸明星| 亚洲天堂网中文字| 一二三级黄色片| 91久久久精品国产| 92国产精品久久久久首页| av毛片在线免费看| 日韩天堂在线观看| www.av视频在线观看| 国产经典欧美精品| 一二三四视频社区在线| 特黄特色欧美大片| 日本一区二区在线免费播放| freemovies性欧美| 欧美精品久久久久久久多人混战| 亚洲少妇xxx| 国产一区二区福利| 久久av综合网| 日韩三级毛片| 国产精品男人的天堂| 午夜视频在线观看网站| 日韩一区二区免费视频| www.youjizz.com亚洲| www.成人网.com| 国产精品涩涩涩视频网站| 欧美aaaaaaaaaaaa| 99在线观看视频| 日韩欧美一中文字暮专区| 亚洲视频在线看| 在线观看亚洲一区二区| 亚洲麻豆国产自偷在线| 亚洲av熟女高潮一区二区| 国产精品一级| 性欧美18一19内谢| 成人爽a毛片| 国产精品久久久久久久久久| 黄a在线观看| 亚洲精品二三区| 亚洲精品国产精品国自产网站按摩| 亚洲同性gay激情无套| www.555国产精品免费| 午夜亚洲精品| 国产av不卡一区二区| 国产精品毛片av| 国产精品日韩久久久久| 污片在线免费观看| 国产亚洲成精品久久| 国产男女猛烈无遮挡| 色偷偷久久一区二区三区| av最新在线观看| 久久女同精品一区二区| 天天av天天操| 日本视频一区二区| 2018日日夜夜| 伊人久久大香线蕉综合四虎小说| 欧美黄色直播| 97品白浆高清久久久久久 | 精品国产亚洲一区二区三区| 欧美专区第一页| 特级毛片在线| 中文字幕综合在线| 日韩av资源站| 亚洲成年人影院在线| 99久久精品无免国产免费| 色八戒一区二区三区| 国产在线观看99| 专区另类欧美日韩| 娇妻被老王脔到高潮失禁视频| 成人黄色av网站在线| 一级片黄色免费| 乱一区二区av| 国产日产欧美视频| 亚洲电影av| 成人av在线播放观看| 亚洲大全视频| 中国成人在线视频| 日本a级不卡| 日本在线免费观看一区| 欧美久久香蕉| 91久久精品www人人做人人爽| 亚洲www啪成人一区二区| 久久乐国产精品| 亚洲欧洲精品视频| 亚洲国产又黄又爽女人高潮的| 国产绿帽刺激高潮对白| 在线观看精品一区| 欧产日产国产69| 天天色综合成人网| 久草免费新视频| 亚洲一区二区3| 日韩精品一区二区亚洲av性色| 国产亚洲欧美日韩在线一区| 成人在线观看一区二区| 韩国av一区二区三区| 免费看污黄网站| 久久狠狠婷婷| 精品中文字幕av| 99成人精品| 亚洲色成人www永久在线观看| 亚洲无线视频| 久久精品xxx| 韩国欧美一区| 777av视频| 亚洲美女黄色| 少妇人妻在线视频| 国内精品嫩模av私拍在线观看| 激情五月六月婷婷| 欧美日韩国产探花| 日韩视频 中文字幕| 樱桃成人精品视频在线播放| 国产精品videossex国产高清| 自拍偷拍欧美| 激情五月婷婷六月| 亚洲国产国产亚洲一二三| 性一交一乱一伧国产女士spa| 国产精品激情电影| 国产freexxxx性播放麻豆| 国模吧视频一区| 免费一级特黄毛片| 狂野欧美性猛交xxxx巴西| 成年人在线看片| 日韩不卡一二三区| 天天色天天干天天色| 国产精品一卡二卡| 国产精九九网站漫画| 久久久青草青青国产亚洲免观| 亚洲成人网在线播放| 中文一区在线播放| 久草视频免费在线| 欧美视频一区二区三区…| 在线能看的av| 在线观看亚洲一区| 91精品国产色综合久久不8| 6080国产精品一区二区| 一级全黄裸体免费视频| 精品久久国产老人久久综合| 三级小视频在线观看| 亚洲欧美激情视频| 成年人黄视频在线观看| 久久久久免费精品国产| 美女高潮在线观看| 成人av.网址在线网站| 精品国产亚洲一区二区在线观看| 91手机在线播放| 欧美日韩在线播放视频| 中国老女人av| 亚洲欧美日韩专区| 久久精品亚洲天堂| 成人av资源在线| 非洲一级黄色片| 夜夜嗨av一区二区三区| 无码aⅴ精品一区二区三区| 欧美日韩激情一区| 色视频在线观看福利| 色七七影院综合| 成人免费高清观看| 国产啪精品视频| 日韩中文av| 国产精品99久久久久久大便| 国产精品一二| 伊人五月天婷婷| 久久久三级国产网站| 国产一级理论片| 欧美优质美女网站| www.色播.com| 久久九九有精品国产23| 亚洲v.com| 97碰碰视频| 久久在线视频| 亚洲国产精品久久久久婷蜜芽| 精品一二三四区| 免费黄在线观看| 午夜精品久久久久影视| 中文字幕激情视频| 亚洲人成在线观| sm久久捆绑调教精品一区| 成人xxxxx| 国内黄色精品| 无罩大乳的熟妇正在播放| 国产老女人精品毛片久久| 青青草自拍偷拍| 日韩欧美高清视频| 亚洲av成人无码久久精品老人 | 裸模一区二区三区免费| 国模大胆一区二区三区| 日韩av自拍偷拍| 国产精品护士白丝一区av| 日韩欧美在线观看免费| 91麻豆精品91久久久久同性| av在线日韩国产精品| 4438全国成人免费| 久久夜色电影| 欧美美女黄色网| 精品一二三四在线| 久久久久亚洲av片无码| 欧美在线免费观看视频| 日本v片在线免费观看| 欧美在线视频一二三| 全国精品免费看| 国产69精品久久久久久久| 99re这里只有精品首页| 国产网站在线看| 亚洲精品一区二区精华| 97超碰免费在线| 精品国产乱码久久久久久108| 国产精品黄色| 亚洲国产欧美视频| 欧美日韩精品中文字幕| 奇米影视888狠狠狠777不卡| 51ⅴ精品国产91久久久久久| 成人影院中文字幕| 国产精品欧美激情在线观看| 97精品视频在线观看自产线路二| 亚洲男人的天堂在线视频| 亚洲欧美成人在线| 欧美特大特白屁股xxxx| 精品欧美一区二区精品久久| 蜜乳av另类精品一区二区| 加勒比综合在线| 欧美丰满一区二区免费视频| 成人毛片av在线| 成人情视频高清免费观看电影| 野花国产精品入口| 波多野结衣一本| 欧美日韩一区二区三区四区| 黄页视频在线播放| 亚洲自拍偷拍一区| 国产精品久久国产愉拍| 欧美特级黄色录像| 亚洲永久免费视频| 欧美一区二区少妇| 国产精品欧美一区二区| 欧美日本国产| www.免费av| 色婷婷久久久综合中文字幕| 日本在线免费| 国产精品美女诱惑| 日韩成人av影视| 丰满少妇高潮久久三区| 91精品国产欧美一区二区| 中文字幕乱码中文乱码51精品| 日韩少妇中文字幕| 床上的激情91.| 日韩精品一区不卡| 丝袜亚洲欧美日韩综合| 国产香蕉精品| 人人干人人视频| 亚洲成人www| 国产精品一级伦理| 91免费精品视频| 噜噜噜躁狠狠躁狠狠精品视频| 午夜激情福利电影| 亚洲男人天堂古典| 精品视频在线播放一区二区三区| 成年人网站大全|