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

云原生小技巧 : 如何自動化發布 CLI 工具?

云計算 云原生
在自動化構建的世界中,編寫一個穩定且跨平臺兼容的構建腳本是關鍵。Golang 提供了強大的跨平臺構建能力,而 go build 命令是實現這一目標的核心。

在云原生時代,CLI 工具已成為開發者日常工作中不可或缺的一部分。然而,將開發好的 CLI 工具分享給大家使用,如果僅依賴手動發布,不僅效率低,且易出錯,特別是在處理多架構和多平臺兼容性時尤為明顯。

那么,我們如何才能實現 CLI 工具的自動化發布呢?本文旨在探討這一問題,并提出一套實用的解決方案。

在接下來的分享中,我將主要以 Golang 舉例。需要指出的是,我們將討論的自動化構建和發布的原則是通用的,適用于所有編程語言。因此,無論大家使用哪種語言編寫工具,這些實踐都將具有重要的參考價值。

編寫構建腳本

在自動化構建的世界中,編寫一個穩定且跨平臺兼容的構建腳本是關鍵。Golang 提供了強大的跨平臺構建能力,而 go build 命令是實現這一目標的核心。例如:

CGO_ENABLED=0 GOOS=darwin GOARCH=amd64 go build -o fooctl-darwin-amd64 -v

這個命令示例突顯了 Golang 在生成特定平臺和架構二進制文件方面的靈活性。在構建腳本中,我們需要進一步擴展這種靈活性,以支持多平臺構建需求。

  1. 參數化和默認值設置:

OUTPUT_DIR 和 BINARY_NAME 的設定允許用戶自定義輸出目錄和二進制文件的名稱,加強了腳本的通用性。

BUILDPATH 變量用于指定構建路徑,是腳本運行的必需參數,保證了構建過程的穩定性。

  1. 跨平臺和架構支持:
  • 通過設置 BUILD_GOOS 和 BUILD_GOARCH 變量,腳本能夠靈活地處理不同操作系統和架構的構建需求,增加了適用性。
  • 這些變量的默認值通過 go env 獲取,但也可以通過參數覆蓋,提供了靈活性。
  1. 動態輸出路徑:
  • OUT 變量根據是否為發布版(IS_RELEASE),動態調整輸出文件的命名和路徑。這樣的設計使得腳本能夠根據不同的使用場景(如開發測試或正式發布)輸出不同格式的文件名。
  1. 特殊情況處理:
  • 對 Windows 平臺的特殊處理(.exe 擴展名)是必要的,因為 Windows 系統下的可執行文件通常需要這個擴展名。

gobuild.sh 腳本

下面的 gobuild.sh 腳本是對上述原則的實踐,將跨平臺構建的復雜性轉化為簡單的命令行操作:

OUTPUT_DIR=${4:-"bin"}
BINARY_NAME=$(basename ${1})
BUILDPATH=./${1:?"path to build"}

BUILD_GOOS=${GOOS:-$(go env GOOS)}
BUILD_GOARCH=${GOARCH:-$(go env GOARCH)}
GOBINARY=${GOBINARY:-go}
LDFLAGS=$(version::ldflags)

if [ $# -ge 2 ] && [ -n $2 ]; then
  BUILD_GOOS=$2
fi

if [ $# -ge 3 ] && [ -n $3 ]; then
  BUILD_GOARCH=$3
fi

OUT=${OUTPUT_DIR}/${1:?"output path"}
if [ "${IS_RELEASE:-0}" == "1" ]; then
    OUT="${OUTPUT_DIR}/${BINARY_NAME}-${BUILD_GOOS}-${BUILD_GOARCH}"
    if [ "${BUILD_GOOS}" == "windows" ]; then
        OUT="${OUTPUT_DIR}/${BINARY_NAME}-${BUILD_GOOS}-${BUILD_GOARCH}.exe"
    fi
fi

CGO_ENABLED=0 GOOS=${BUILD_GOOS} GOARCH=${BUILD_GOARCH}${GOBINARY} build \
    -ldflags="${LDFLAGS}" \
    -o "${OUT}" \
    "${BUILDPATH}"

這個腳本不僅適應了多平臺和多架構的需要,還提供了足夠的靈活性和可配置性,以適應不同的構建場景。

配合 Makefile 實現全自動化構建

進一步的,結合 Makefile 可以將構建過程自動化,提升效率:

.PHONY: build-binaries

BUILD_SCRIPT_PATH := ./hack/gobuild/gobuild.sh
# 列出了需要構建的所有二進制文件,可管理多個項目的構建過程
BINARIES := cmd/fooctl cmd/barctl

# 通過 ALLPLATFORMS 變量,我們定義了一系列目標平臺和架構組合
ALLPLATFORMS := linux/amd64 linux/arm64 darwin/amd64 darwin/arm64 windows/amd64 windows/arm64

# 構建所有組合
build-binaries: $(foreach bin,$(BINARIES),$(foreach plat,$(ALLPLATFORMS),build-$(bin)-$(plat)))

# 構建規則模板
# 這個模板可以生成特定于每個二進制文件和平臺組合的構建規則。
define BUILD_template
build-$(1)-$(2):
    IS_RELEASE=1 $$(BUILD_SCRIPT_PATH) $(1) $$(subst /, ,$$(word 1,$$(subst -, ,$(2)))) $$(subst /, ,$$(word 2,$$(subst -, ,$(2))))
endef

# 生成構建規則
# 我們自動為每個二進制文件和平臺組合生成了具體的構建規則。
$(foreach bin,$(BINARIES),$(foreach plat,$(ALLPLATFORMS),$(eval $(call BUILD_template,$(bin),$(plat)))))

通過這個 Makefile,即使同時構建 fooctl 和 barctl 這兩個 CLI Tool 也變得異常簡單。一條簡單的命令 make build-binaries 就能觸發整個構建流程,大大減少了人工干預,確保了構建過程的一致性和可靠性。

小結

通過上述詳細的構建腳本和 Makefile 配置,我們可以看到,現代軟件開發中自動化構建的強大功能和必要性。這種方法不僅提升了構建效率,也增強了軟件的質量和穩定性。在云原生時代,自動化構建已成為提高開發團隊效率和產品可靠性的關鍵策略。

Release CLI tool on GitLab CI/CD

在構建腳本準備完畢后,接下來我們就可以將其集成到 CI 系統了,下面我以 GitLab CI/CD 為例。

在 GitLab CI/CD 的核心,是一系列定義明確的作業(Jobs),它們在代碼提交時自動執行。對于完整的持續集成來說,這些作業通常包括構建(build)、測試(test)、代碼審查(lint)等步驟。但在本文中,我們將重點關注自動發布流程。

觸發自動發布的條件

自動發布流程是基于 Git 標簽創建的。當開發者推送一個新標簽到倉庫時,GitLab CI/CD 會捕捉到這一事件,并啟動預定義的發布流程。

rules:
  - if: $CI_COMMIT_TAG

這個條件確保只有在創建新標簽時,才會啟動后續的構建、上傳和發布作業。

Release Jobs

步驟一:構建二進制文件,在 build-binaries 階段,CI 會構建針對不同平臺和架構的 CLI 工具二進制文件,確保構建過程的一致性和可重復性。

步驟二:上傳構建產物,待構建完成后,upload 階段負責將二進制文件上傳到 GitLab 的包管理器或其他存儲位置。這為后續的發布提供了必要的資源。

步驟三: 發布到 GitLab,最后,在 release 階段,CI 使用 release-cli 工具自動創建發布,并將構建的二進制文件作為發布的資產。

Create releases from .gitlab-ci.yml

下面的 .gitlab-ci.yml 腳本是對上述發布流程的實踐:

stages:
  ...
  - build-binaries
  - upload
  - release
  
build-binaries:
  stage: build-binaries
  image: golang:1.21.1
  rules:
    - if: $CI_COMMIT_TAG
  script:
    - echo "Building binaries for all platforms and architectures..."
    - make build-binaries
  artifacts:
    paths:
      - bin

upload:
  stage: upload
  image: curlimages/curl:latest
  rules:
    - if: $CI_COMMIT_TAG
  script:
    - echo "Uploading binaries..."
    - >
      for binary in ./bin/*; do
        curl --header "JOB-TOKEN: $CI_JOB_TOKEN" \
             --upload-file $binary \
             "${PACKAGE_REGISTRY_URL}/$(basename $binary)";
      done
    
release:
  stage: release
  image: registry.gitlab.com/gitlab-org/release-cli:latest
  rules:
    - if: $CI_COMMIT_TAG
  script:
    - echo "Creating a release for $CI_COMMIT_TAG"
    - |
      ASSET_LINKS=""
      for binary in ./bin/*; do
        LINK="{\"name\":\"$(basename $binary)\", \"url\":\"${PACKAGE_REGISTRY_URL}/$(basename $binary)\"}"
        ASSET_LINKS="${ASSET_LINKS},${LINK}"
      done
      ASSET_LINKS="[${ASSET_LINKS:1}]"
    - >
      release-cli create \
        --name "Release $CI_COMMIT_TAG" \
        --tag-name $CI_COMMIT_TAG \
        --description "Created using the release-cli: $CI_COMMIT_REF_NAME-$CI_JOB_ID" \
        --ref $CI_COMMIT_SHA \
        --assets-link "$ASSET_LINKS"

以上示例將會構建 CLI 工具二進制文件,并將其上傳到 Gitlab Release 頁面。用戶從 Gitlab  Release 頁面查找并下載適合其平臺的二進制包即可。

圖片圖片

有關詳細的 GitLab CI 流程,可以參考項目:https://gitlab.com/lqshow/clireleaseautomator

小結

這個流程大大簡化了 CLI 工具的發布過程,使得開發者能夠專注于代碼開發,而不是后續的構建和發布環節。自動化這些步驟意味著每次發布都是快速、一致且無誤的,從而提高了軟件的整體質量和可靠性。

Release CLI tool use GoReleaser

不難發現,上述整個流程相對來說還是比較繁瑣的,準備腳本的過程也比較復雜,現在我將介紹一個讓這個過程不那么痛苦的工具 GoReleaser[1]。

它是一個變革性的工具,特別是對于以 Golang 編寫的項目。相比于傳統的手動配置和腳本編寫,GoReleaser 提供了一種更高效和簡潔的自動化發布方法。

GoReleaser 的優勢

GoReleaser 的設計理念是“一次配置,處處運行”,它通過一個單一的配置文件,即可控制整個發布流程。這個配置文件定義了如何構建二進制文件、如何打包它們、如何處理版本信息以及如何發布到各種平臺。具體來說,GoReleaser 的優勢包括:

  1. 簡化的構建過程:通過預定義的模板,GoReleaser 能夠自動構建針對不同平臺和架構的二進制文件,無需編寫復雜的腳本。
  2. 靈活的打包和發布:支持多種格式的打包選項,以及與主要代碼托管平臺的無縫集成。
  3. 高度可配置:從構建選項到發布設置,GoReleaser 允許高度定制化,以滿足不同項目的需求。

配置和使用 GoReleaser

使用 GoReleaser 的第一步是在項目的根目錄下創建 .goreleaser.yml 配置文件。通過 goreleaser init 命令可快速生成初始配置。這個文件涵蓋了構建、打包和發布的全過程。

在配置好 .goreleaser.yml 之后,我們需要調整 .gitignore 加上 dist,因為 goreleaser 會默認把編譯編譯好的文件輸出到 dist 目錄中。

接下來我們看個例子:

# .goreleaser.yml 示例
builds:
  - id: fooctl
    binary: fooctl
    main: ./cmd/fooctl
    ldflags:
    - -s -w
    - -X gitlab.com/lqshow/clireleaseautomator-with-goreleaser/version.gitVersinotallow={{.Version}}
    - -X gitlab.com/lqshow/clireleaseautomator-with-goreleaser/version.gitCommit={{.ShortCommit}}
    goos:
      - linux
      - darwin
      - windows
    goarch:
      - amd64
      - arm64
  - id: barctl
    binary: barctl
    main: ./cmd/barctl
    ldflags:
    - -s -w
    - -X gitlab.com/lqshow/clireleaseautomator-with-goreleaser/version.gitVersinotallow={{.Version}}
    - -X gitlab.com/lqshow/clireleaseautomator-with-goreleaser/version.gitCommit={{.ShortCommit}}
    goos:
      - linux
      - darwin
      - windows
    goarch:
      - amd64
      - arm64

這個簡單清晰的配置文件,事實上包含了我之前介紹的兩個模塊,相當于省去了寫 shell 腳本和 Makefile 文件,使整個過程更加靈活和高效。

GitLab CI 中的 GoReleaser 集成

在 .gitlab-ci.yml 文件中,我們只需要定義一個簡單的 release 作業,對了,別忘了還需要在 CI/CD 里配置一個 GTILAB_TOKEN  變量:

stages:
  - release

release:
  stage: release
  image:
    name: goreleaser/goreleaser
    entrypoint: ['']
  only:
    - tags
  variables:
    GIT_DEPTH: 0
    GITLAB_TOKEN: $GITLAB_TOKEN
  script:
    - goreleaserrelease--clean

只要查看運行日志,其實我們就會發現,GoReleaser 自動執行后,它包含了構建、上傳和發布的整個流程。

具體詳情:https://gitlab.com/lqshow/clireleaseautomator-with-goreleaser/-/jobs/5669211977

責任編輯:武曉燕 來源: Cloud Native 101
相關推薦

2013-07-23 09:19:53

云服務器遷移云遷移云遷移工具

2023-11-27 13:41:00

Kubernete本地調試

2022-11-24 13:43:40

2023-02-07 08:11:15

2024-02-04 09:53:27

2018-08-27 07:52:03

云計算工具云遷移

2012-06-25 09:35:19

云計算自動化

2022-08-08 07:35:37

云測試工具云存儲云計算

2021-06-22 10:31:38

云計算自動化云原生

2019-08-22 09:25:54

云安全云原生Fortinet

2019-10-30 14:47:05

工具代碼開發

2020-03-10 10:06:08

小程序微信開發

2013-07-02 10:45:38

2020-08-31 22:05:53

Kubernetes微服務系統

2012-09-17 13:21:22

iOSAndroid自動化測試工具

2017-11-07 12:33:39

云自動化公有云編排

2020-07-24 09:52:55

自動化ITCIO

2020-02-27 10:11:11

自動化IT安全

2017-12-17 21:58:18

2014-11-12 09:24:00

點贊
收藏

51CTO技術棧公眾號

中文字幕欧美精品在线| 欧美日韩免费在线观看| y111111国产精品久久婷婷| 中文字幕一区二区三区手机版| 欧美1区二区| 欧美日韩大陆一区二区| 中国丰满熟妇xxxx性| 国产人成在线观看| 国产精品白丝jk白祙喷水网站 | 狠狠人妻久久久久久综合蜜桃| 日韩网站中文字幕| 亚洲国产视频在线| 日韩免费电影一区二区三区| 精品久久久无码中文字幕| 美女爽到呻吟久久久久| 欧美韩日一区二区| 国产视频不卡在线| 久久99国产精品久久99大师| 欧美日韩精品免费观看视频| www.日本在线播放| h片在线免费观看| 国产日韩v精品一区二区| 成人三级在线| 一区二区三区黄色片| 国产精品久久777777毛茸茸| 色综合导航网站| 99久久99久久精品免费| 久久视频在线观看| 欧美一级一区二区| 国产aⅴ爽av久久久久| 亚洲成人不卡| 福利视频导航一区| 丁香六月激情婷婷| 欧美hdxxxx| 亚洲乱码日产精品bd| 亚洲一区二区在线免费观看| 国产原创av在线| 久久一区二区三区国产精品| 99re视频在线| av在线资源观看| 精品一区免费av| 国产精品美女在线| 少妇又紧又色又爽又刺激视频| 亚洲一区视频| 热门国产精品亚洲第一区在线| 日韩三级小视频| 亚洲欧洲午夜| 8050国产精品久久久久久| 国产性70yerg老太| 影音先锋在线一区| 国内精品久久久久| 日韩乱码一区二区| 亚洲欧洲另类| 欧美在线亚洲在线| 69成人免费视频| 日韩av电影天堂| 国产精品男女猛烈高潮激情| 在线播放一级片| 久久99精品久久久久久久久久久久 | 欧美成人免费看| 欧美激情无毛| 久久久久久伊人| 好吊操这里只有精品| 国产日韩精品视频一区二区三区| 2019中文字幕免费视频| 国产成人精品777777| 青青草伊人久久| 91亚洲国产成人久久精品网站| 国产伦精品一区二区三区四区| 国产一区二区三区日韩| 99国产高清| 日本大片在线观看| 国产精品色哟哟| 国产高潮呻吟久久久| 一色桃子av在线| 香蕉久久一区二区不卡无毒影院| 黄色片网址在线观看| 中文字幕这里只有精品| 欧美日韩亚州综合| 国产精品19p| 亚洲另类春色校园小说| 在线成人激情黄色| 日本妇女毛茸茸| 亚洲欧美久久久| 国产裸体写真av一区二区| 精品人妻伦一区二区三区久久| 成人三级在线视频| 亚欧精品在线| 七七成人影院| 欧洲一区二区av| 午夜性福利视频| 精品国精品国产自在久国产应用| y97精品国产97久久久久久| 日韩黄色三级视频| 蜜乳av一区二区| 国产亚洲精品久久飘花| 在线免费观看黄色网址| 亚洲成人免费在线观看| 第四色婷婷基地| 久久资源综合| 久久伊人91精品综合网站| 日本视频免费在线| 精品制服美女丁香| 欧美成人一区二区在线| 色女人在线视频| 欧美性大战久久久久久久| 美国黄色一级视频| 国产精品毛片一区二区在线看| 欧美黄色三级网站| 亚洲天堂视频网| 久久蜜桃一区二区| 免费视频爱爱太爽了| 成人激情视屏| 日韩毛片中文字幕| 久久免费精彩视频| 麻豆成人在线观看| 日韩不卡av| 人在线成免费视频| 欧美不卡123| 久久国产高清视频| 免费在线视频一区| 日韩免费av一区二区三区| 色在线免费观看| 91精品国产高清一区二区三区蜜臀| 精品人妻无码一区二区三区| 好看的av在线不卡观看| 96pao国产成视频永久免费| 国产理论电影在线观看| 欧美日韩国产一区二区| av地址在线观看| 99久久久久国产精品| 国产999精品视频| 久久精品a一级国产免视看成人| 偷拍日韩校园综合在线| 国产艳妇疯狂做爰视频| 欧美国产高清| 动漫一区二区在线| 羞羞视频在线免费国产| 7777精品久久久大香线蕉| 久久嫩草捆绑紧缚| 看国产成人h片视频| 一区二区高清视频| 日韩精品一级毛片在线播放| 中文字幕日韩免费视频| 最新在线中文字幕| 欧美激情在线看| 亚洲一区日韩精品| 999久久久亚洲| 国产免费一区二区三区在线能观看 | 欧美视频免费看| 俺去了亚洲欧美日韩| 91精品在线视频观看| 国产精品久久久久久久久免费丝袜| 婷婷丁香激情网| 日韩理论电影| 亚洲www在线| 日本在线视频网址| 亚洲成人免费在线视频| 亚洲精品1区2区3区| 91蜜桃婷婷狠狠久久综合9色| 18岁网站在线观看| 精品在线播放| 国产精品男人的天堂| 日韩毛片久久久| 欧美一区中文字幕| 麻豆changesxxx国产| 成人激情av网| 日韩精品在线观看av| 久久婷婷国产| 国产国产精品人在线视| 欧美孕妇孕交| 欧美色综合网站| 美国美女黄色片| 国产成人在线视频播放| 国产精品一区二区免费在线观看| 少妇精品久久久一区二区| 国产精品视频xxx| 欧洲在线视频| 亚洲丝袜av一区| 国产成人三级在线播放| 黄色成人在线播放| 99久久99久久精品免费| 成人亚洲一区二区一| 茄子视频成人免费观看| 香蕉久久网站| 久久偷看各类wc女厕嘘嘘偷窃| 99久久久国产精品免费调教网站| 久久久av网站| 欧洲毛片在线| 日韩欧美一区二区免费| 欧产日产国产69| 亚洲伦理在线精品| 尤物网站在线观看| 久草中文综合在线| 色欲av无码一区二区人妻| 欧美aaaa视频| 久久99精品久久久久久秒播放器 | 国产成人av电影在线| 久草青青在线观看| 欧美黄色精品| 亚洲国产精品一区二区第一页 | 日韩一区二区三区三四区视频在线观看 | 肥臀熟女一区二区三区| 欧美日韩亚洲综合一区二区三区 | 污污影院在线观看| 国产亚洲精品久久久久久| 精品久久无码中文字幕| 欧美日韩综合一区| 久久亚洲精品国产| 亚洲制服丝袜一区| 日韩在线一卡二卡| 久久香蕉国产线看观看99| 成人做爰69片免费| 精品亚洲成a人| 在线观看的毛片| 国产精品一区毛片| 少妇大叫太大太粗太爽了a片小说| 精品av一区二区| 精品蜜桃传媒| 成人涩涩网站| 99久久99久久| vam成人资源在线观看| 国产精品1区2区在线观看| 色戒汤唯在线观看| 高清欧美性猛交xxxx| 成人在线app| 久久亚洲精品毛片| 在线免费观看黄色网址| 一区二区三区精品99久久| 亚洲色欧美另类| 亚洲黄在线观看| 日批视频免费播放| 精品国产a毛片| 欧美熟妇乱码在线一区 | 亚洲日本国产精品| 日韩成人在线视频观看| 黄色片网站免费在线观看| 日韩一区二区三区视频在线观看| 97成人在线观看| 欧美精品在线一区二区| 一级黄色录像大片| 欧美日韩亚洲国产综合| 一级片视频免费| 欧美精品xxxxbbbb| 国产精品探花视频| 欧美一级在线免费| 丰满少妇被猛烈进入| 精品国免费一区二区三区| 亚洲国产www| 亚洲成人xxx| 亚洲人成色777777老人头| 国产午夜精品麻豆| 国产精品一区在线看| 一区二区三区视频免费在线观看| 九色视频在线播放| 中文字幕欧美国内| av色综合久久天堂av色综合在| 久久av红桃一区二区小说| 1stkiss在线漫画| 欧美精品久久久久久久久久| а√在线天堂官网| 欧美专区日韩视频| 午夜精品久久久久久毛片| 91久久国产精品91久久性色| 一区二区三区国产好| 国产伦精品一区二区三区在线| 女同另类激情重口| 视频一区二区三区免费观看| 91视频一区| 97中文字幕在线| 久久综合九色| 日韩精品aaa| 91香蕉视频污| 激情无码人妻又粗又大| 一区二区三区不卡视频在线观看| 日韩福利片在线观看| 欧美视频精品在线| 亚洲国产综合网| 亚洲女成人图区| 精品麻豆一区二区三区| 国模私拍一区二区三区| 成人午夜sm精品久久久久久久| 亚洲在线观看视频网站| 日韩欧美影院| 宅男av一区二区三区| 精品91在线| 日本 片 成人 在线| 成人手机在线视频| 快灬快灬一下爽蜜桃在线观看| 玉米视频成人免费看| 中文字字幕在线中文| 91精品国产色综合久久| 你懂的视频在线观看| 美女视频久久黄| 欧美日韩精品一区二区三区视频| 91成人免费视频| 国产欧美日韩精品一区二区免费 | 精品国产乱码久久久久久免费| 国产在线91| 国内外成人免费激情在线视频| 欧美性www| 青青成人在线| 精品动漫一区| 天天干天天色天天干| 26uuu色噜噜精品一区二区| 一区视频免费观看| 欧美最猛性xxxxx直播| 黄色片一区二区| 美女性感视频久久久| 成人精品三级| 久久久久高清| 欧美影院一区| 国产欧美一区二| 国产三级一区二区三区| 日韩成人在线免费视频| 日韩三区在线观看| 在线观看美女网站大全免费| 欧美亚洲另类视频| 成人性生交大片免费看96| 中文字幕精品—区二区日日骚| 男女精品视频| 一级特级黄色片| 亚洲国产一二三| 亚洲AV无码精品国产| 日韩中文字幕视频在线观看| 国产 日韩 欧美一区| 久久精品第九区免费观看| 在线精品亚洲| 亚洲天堂av网站| 亚洲综合男人的天堂| 国产伦一区二区| 久久亚洲欧美日韩精品专区| 欧美97人人模人人爽人人喊视频| 日韩精品久久久| 日韩国产在线一| 人成免费在线视频| 精品视频999| 69xxxx欧美| 国产精品丝袜一区二区三区| 欧美日韩第一| 亚洲一区二区三区四区五区xx| 久久久久久久精| 久久久精品毛片| 亚洲欧美中文字幕| 日韩久久一区二区三区| 日本黑人久久| 蜜桃视频一区二区三区在线观看| 亚洲一级黄色录像| 欧美美女黄视频| 性欧美video高清bbw| 成人片在线免费看| 国产精品久久久久久模特| 人妻体内射精一区二区| 在线观看成人免费视频| 日本在线天堂| 国产激情一区二区三区在线观看| 红桃视频欧美| 日本黄色录像片| 日韩欧美在线免费观看| yiren22综合网成人| 成人精品在线视频| 国产精品www.| 粉嫩av懂色av蜜臀av分享| 欧美性xxxxxx| 午夜免费播放观看在线视频| 亚洲a中文字幕| 亚洲毛片播放| 国产午夜福利一区| 欧美一区二区三级| 91福利在线免费| 欧美一区观看| 国产一区二区美女诱惑| 日本三级片在线观看| 亚洲一区二区久久| 国产精品久久免费视频| 三上悠亚久久精品| 国产午夜亚洲精品午夜鲁丝片| 一级黄色片在线观看| 久久免费视频在线| 国产精品一区二区av交换| 男人的天堂最新网址| 亚洲福利一区二区三区| 蜜桃视频在线免费| 91一区二区三区| 久久亚洲图片| 青青操国产视频| 亚洲天堂男人天堂| 一区二区三区在线资源| 成人在线观看黄| 一区二区三区日本| 高清国产福利在线观看| 高清视频在线观看一区| 日欧美一区二区| 国产主播在线观看| 中文字幕欧美在线| 牛牛影视久久网| 在线成人精品视频| 欧美三级在线播放| www.youjizz.com在线| 国产精品波多野结衣|