日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

iOS之深入解析CocoaPods的GitLab CI与组件自动化构建与发布

發布時間:2024/5/28 编程问答 57 豆豆
生活随笔 收集整理的這篇文章主要介紹了 iOS之深入解析CocoaPods的GitLab CI与组件自动化构建与发布 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一、Gitlab CI/CD 簡介

① GitLab

  • GitLab 是一個利用 Ruby on Rails 開發的開源應用程序,實現一個自托管的 Git 項目倉庫,可通過 Web 界面進行訪問公開的或者私有的項目。
  • GitLab 擁有與 GitHub 類似的功能,能夠瀏覽源代碼,管理缺陷和注釋。
  • GitLab 可以管理團隊對倉庫的訪問,它非常易于瀏覽提交過的版本并提供一個文件歷史庫。

② GitLab CI/CD

  • Gitlab CI/CD 是一個內置在 GitLab 中的工具,用于通過持續方法進行軟件開發:
    • 持續集成(Continuous Integration):頻繁地(一天多次)將代碼集成到主干,讓產品可以快速迭代,同時還能保持高質量,它的核心措施是,代碼集成到主干之前,必須通過自動化測試;
    • 持續交付(Continuous Delivery):頻繁地將軟件的新版本,交付給質量團隊或者用戶,以供評審,如果評審通過,代碼就進入生產階段,持續交付可以看作持續集成的下一步,它強調的是,不管怎么更新,軟件是隨時隨地可以交付的;
    • 持續部署(continuous Deployment):代碼通過評審以后,自動部署到生產環境,是持續部署是持續交付的下一步,持續部署的目標是,代碼在任何時刻都是可部署的,可以進入生產階段。

③ GitLab Runner

  • GitLab Runner 用于執行 Gitlab CI/CD 觸發的一系列作業,并將結果發送回 Gitlab。
  • GitLab Runner 可以在 Docker 容器內運行或部署到 Kubernetes 集群中。

④ Pipeline

  • Pipeline 中文稱為流水線,是分階段執行的構建任務。如:安裝依賴、運行測試、打包、部署開發服務器、部署生產服務器等流程,合起來稱為 Pipeline。

  • Stage表示構建階段,可以理解為上面所說安裝依賴、運行測試等環節的流程。我們可以在一次 Pipeline 中定義多個 Stage。
  • Job 表示構建的作業(或稱之為任務),表示某個 Stage 里面執行的具體任務,可以在 Stages 里面定義多個 Jobs。
  • Pipeline,Stage 和 Job 的關系如下所示:

⑤ 整體流程

  • CI/CD 是一種通過在應用開發階段引入自動化來頻繁向客戶交付應用的方法,CI/CD 的核心概念是持續集成、持續交付和持續部署。
  • 整個流程將分為幾個部分:
    • 首先開發人員在本地完成項目的開發之后,將代碼推送到 Gitlab 倉庫中;
    • 當代碼提交到 Gitlab 倉庫時,會觸發 Pipeline,Gitlab Runner 會根據 .gitlab-ci.yml 配置文件運行 Pipeline 中各階段的任務,總共定義 3 個階段:compile,build,deploy;
    • 在 compile 階段,Gitlab Runner 將項目編譯成 jar 包,使用 MinIO 作為緩存,首次編譯項目時會從 Maven 官網拉取依賴,之后會將依賴壓縮后上傳至 MinIo,在下一次編譯時就可以直接從 MinIO 下載依賴文件;
    • 在 build 階段,Gitlab Runner 使用在 compile 階段編譯生成的 jar 包構建 Docker 鏡像,并將鏡像推送至鏡像倉庫;
    • 在 deploy 階段,Gitlab Runner 使用構建好 Docker 鏡像在 Kubernetes 集群中部署應用。

二、背景分析

  • 在實施業務組件化后,大部分沒有組件化工具鏈支撐的團隊一般都會遇到組件發布效率問題,如果遇到多個特性一起上線時,發布的組件數量可能達到幾十個,手動發布這些組件的話,費時費力,非常影響開發體驗。雖然可以通過 CI 簡化單個組件的發布,只需要根據 Podfile 中的版本提交相應 tag 即可觸發發布動作,但是 CI 并沒有解決多個關聯組件發布的前后順序問題。如果下層組件還未發布就發布上層組件,此組件的 CI 很可能會因為缺少下層組件的某些接口而執行失敗。
  • 基于 GitFlow 工作流進行日常項目的開發,項目在進入預發階段時,關聯的組件都需要拉取 release 分支,當某次發版的所有關聯項目都預發測試完畢時,此次發版的負責人(通常是其中某個項目的負責人)會通知團隊內部成員對組件進行封板,然后組件的負責人會去合并 release 分支到 master & develop,并且發布一個新版本,等所有組件都發布完成后,發版負責人再去更新主工程 Podfile。
  • 整個發版過程,組件負責人除了需要重復若干次以下操作,還需要知悉是否有下層組件還未發布:
>>>> 查看組件應升級版本,更新 podspec 版本并 commit>>>> 合并 release 分支 ,gitflow finish release>>>> 打 tag 并 push >>>> CI 執行完畢,組件發布完成,可能需要通知上層組件的負責人
  • 可以看到如果需要發布多個組件,其過程還是非常繁瑣的。再單獨說下發布順序的問題,假設當前有需要發布的組件 A、B、C、D,其依賴關系如下:

  • 在遵守 CocoaPods 發布規則的前提下,發布先后順序應依次為 A、B-C、D ,其中 B 和 C 組件可同時發布,D 則需要等 B、C 都發布完成后才可以發布,也就是說只有當前組件的依賴沒有包含未發布組件,此組件才可發布。
  • 我們以前的發布情況常常是這樣的:下層組件 A 由于 lint 不通過,導致依賴 A 的 B、C 都 lint 失敗,由于沒有限制開發者對私有源倉庫的 push 權限,B、C 組件的負責人這時候可能就會選擇向私有源倉庫強推 podspec,導致出現 lint 失敗的連鎖反應,越來越多的組件本身代碼沒問題,卻因為下層組件而 lint 失敗,只能選擇強推 podspec。遇到這種情況,除了強調發布規則,從根本上還是要減少發版操作給組件負責人帶來的工作量。
  • labor 就是為了能在一定程度上解決以上問題而創建的,在 labor 上執行發版操作時,組件負責人只需要關注 lint 的錯誤信息即可,剩余發布操作,包括上下層組件的發布順序都由 labor 進行管理。

三、效果演示

  • 以上述的 A、B、C、D 組件為例,在 labor 上添加發布并分析依賴后,可以看到組件發布頁:

  • 在發布頁中,使用者可以查看依賴發布的組件,也可以修改發布組件的版本,labor 會在組件發布時同步到倉庫的 podspec 文件中。執行自動發布后,labor 會和 GitLab 進行一系列交互。
  • 以組件 A 為例,labor 會先創建所有發布組件目標分支的 MR:

  • 然后觸發對應 release 分支的 pipeline:

  • 這里省去的 code review 這一步驟,如果需要的話,可以在 web 上設置入口,組件負責人設置為 review 完成后,才觸發 pipeline。如果 pipeline 執行成功,那么 GitLab 會自動合并 MR,如果沖突的話,需要負責人在此 MR 下解決:

  • MR 合并成功后,組件會更新狀態為發布中(假如組件還有依賴未發布,那么這里的狀態為已合并,等待依賴發布完成,狀態才為發布中):

  • 然后 labor 會給組件打 tag,并且觸發 tag 的 pipeline:

  • 在 tag 的 pipeline 執行成功后,就視 A 組件發布成功。A 發布成功后,labor 會查看 B、C 對應 MR 狀態執行后續操作:
    • MR pipeline 已經執行成功,并且對應的分支已經合并到 master (組件狀態:已合并);
    • MR pipeline 由于 A 沒發布,lint 失敗,分支沒有合并到 master(組件狀態:等待中);
  • 如果是 1 狀態,則直接創建 tag 發布,如果是 2 狀態,則觸發 MR 對應分支的 pipeline,假如此 MR 是因為 A 組件未發布導致合并失敗的,那么在 A 發布后,重新觸發的 MR pipeline 一般都能執行成功,當 MR 合并成功后,后續步驟與 1 一致。受益于 GitLab 分布式的 runner,可以通過 CI 同時發布多個組件。
  • 當所有組件發布完成后,labor 會根據使用者輸入的組件版本,更新發版工程的 Podfile:

  • 以上就是 labor 的主要工作步驟,可以看到,使用 labor 發版后,組件負責人只需要確保 MR 能順利合并即可,不需要等待下層組件負責人發布完成的通知,也省去了繁瑣的發布操作。
  • 截止到目前為止,labor 已經幫助團隊執行了近 30 次自動發布,每次發布的組件個數平均在 15 個左右,節省了很多組員溝通與操作時間。

四、labor 結構與發布類型

  • labor 由如下幾個服務構成:

  • 其中 web 端主要專注于發版交互與組件發布數據的展示,后端負責發版信息采集、組件發布任務調度以及和 GitLab 進行通信,websocket server 主要負責實時更新 web 中組件的發布狀態。server 中很多操作都是與 GitLab 進行交互,耗時較多,所以 server 中的大部分 service 都是交給 sidekiq(后臺任務處理系統)執行的。
  • 依據發布性質,labor 把發布分為兩種:
    • 主發布 (main deploy);
    • 子發布 (pod deploy)。
  • 這里主發布的主體是發版工程,子發布的主體是組件,其中主發布主要負責發版工程信息的獲取和更新,比如依賴的分析、最后目標分支 Podfile 的更新等。主發布經過分析后,會創建若干子發布,子發布則負責組件發布的所有流程,包括組件 MR 的創建,組件 tag 的創建,發布 CI 的觸發等。
  • 主發布和子發布涉及的所有狀態如下:
created: '待分析', analyzing: '分析中', preparing: '準備中', pending: '等待中', waiting: '待發布', skipped: '已忽略', merged: '已合并', deploying: '發布中', success: '發布成功', failed: '發布失敗', canceled: '已取消',
  • 使用 state_machines-activerecord 以狀態機的形式對發布狀態進行管理,狀態發生變更之后,都會通過 websocket 同步到 web 端。
  • 分析目標工程的組件依賴是發版的第一步,對應主發布的 analyzing 狀態,如下是 labor 分析步驟的序列圖:

  • 首先,web 向 server 端發起分析依賴請求,server 接收到請求后,使用 gitlab 向 GitLab 請求 Podfile 文件內容。由于 Podfile 可能在倉庫的根目錄或者 Example 文件夾下,使用 5 層深度的遞歸查詢來獲取文件路徑。
  • 獲取到 Podfile 路徑后,再根據文件內容創建 Podfile 對象:
# Labor::RemoteFile::Base def file_contents@file_contents ||= gitlab.file_contents(@project_id, @path, @ref) rescue Gitlab::Error::NotFound => error# self.class.name.demodulize# [2..-1]raise Labor::Error::NotFound.new("Can't find #{self.class.name.split('::').drop(2).join('')} with error #{error.message}") end# Labor::RemoteFile::Podfile def podfile@podfile ||= begincontent = file_contentspodfile = Pod::Podfile.from_ruby(Pathname.new(path), content)podfileend end
  • 生成 Podfile 對象后就可以分析發版信息,可以先過濾出需要發版的依賴:
podfile.dependencies.select { |dependency| dependency.external? && dependency.external_source[:tag].nil?}
  • 然后通過同樣的方式循環獲取這些依賴的 podspec 文件,并且構建 Specification 對象:
untagged_specs = Parallel.map(untagged_git_dependencies, in_threads: 5) do |dep| git = dep.external_source[:git]ref = dep.external_source[:branch]component_project = gitlab.project(git)remote_file = Labor::RemoteFile::Specification.new(component_project.id, ref)remote_file.specification end
  • 這里可以利用多線程加快執行效率,不過線程數不要過多,不然容易造成 GitLab 返回數據失敗。獲取到所有需要發布的 spec 后,可以結合組件與其依賴、間接依賴創建發布結構,然后保存至數據庫。
  • 同樣以 A、B、C、D 組件為例,它們的 podspec 依賴如下:
# podspec AB > AC > AD > B > C
  • 最終生成的發布結構如下:
# 發布結構 AB > AC > AD > A > B > C
  • 當 A 發布完成后,發布結構轉變為:
# 發布結構 ABCD > B > C
  • B、C 組件會在需要發布的依賴清空之后,繼續執行組件發布的后續操作。

五、發布組件

① 組件發布核心過程

  • 組件的發布是整個服務的核心功能,順利發布單個組件時的序列圖如下:

  • 上圖中省略了部分和 websocket server 相關的邏輯,實際上其右邊的狀態發生變更時,都會進行 12、13 步驟的消息流動。
  • 如果是自動發布所有組件,而不是發布單個組件,labor 會對主發布分析出的所有組件執行發布操作,這樣相關負責人就可以選擇提前去 review MR 上需要合并的代碼,而不是等依賴的組件發布完成。
  • 對于已知 lint 不通過,短時間無法解決錯誤的組件,labor 提供了手動標志組件發布成功的功能,使用者需要手動發布組件,再設置發布成功。添加這個功能主要是考慮到發版工程會接入其他業務線的組件,而我們并不想讓這些組件影響發版進程。
  • 組件發布過程中,根據處理對象的不同,又可分為以下兩個階段:
    • 準備階段(preparing ~ pending);
    • 正式發布階段(merged ~ success)。

② 準備階段

  • 首先,server 會給還未配置過的組件工程添加 webhook ,GitLab 很多任務都是放到 sidekiq 的,要想獲取任務的執行信息,只能通過 webhook 讓 GitLab 主動發送,所以這一步是組件能自動發布的重要前提。
  • 接著,server 會校驗創建 MR 的必要條件:
    • 組件倉庫必須要有 CI 配置文件,并且文件中包含發布 stage;
    • 組件倉庫的 default 分支必須為 master。
  • 如果滿足以上條件,我們會繼續處理目標組件的 podspec 版本。labor 在分析依賴時,默認會使用 release 分支名中或者 podspec 中較高的版本號作為發布版本,如果實際發布時,組件發布版本比倉庫中的 podspec 高,就需要更新 GitLab 倉庫中 podspec 的 version 字段。
  • 更新 podspec 版本的代碼:
def update_podspec_content(podspec_content, version)require_variable_prefix = trueversion_var_name = 'version'variable_prefix = require_variable_prefix ? /\w\./ : //version_regex = /^(?<begin>[^#]*#{variable_prefix}#{version_var_name}\s*=\s*['"])(?<value>(?<major>[0-9]+)(\.(?<minor>[0-9]+))?(\.(?<patch>[0-9]+))?(?<appendix>(\.[0-9]+)*)?(-(?<prerelease>(.+)))?)(?<end>['"])/iversion_match = version_regex.match(podspec_content)updated_podspec_content = podspec_content.gsub(version_regex, "#{version_match[:begin]}#{version}#{version_match[:end]}")updated_podspec_content end
  • 更新字符串后,同步至 GitLab:
gitlab.edit_file(@project_id, @path, @ref, content, "更正 podspec 版本 #{version}".ci_skip)
  • 這里 commit 信息以 [ci skip] 作為前綴,以減少觸發不必要的 pipeline。最后,會校驗目標分支是否為 master 或者已經合并到 master ,如果是的話 server 會直接標記此發布為 merged ,等待正式發布,否則 server 會給組件倉庫創建 MR ,發布進入 pending 狀態,等依賴的組件都發布完成后,如果此 MR 還未合并,server 會重新觸發 MR 關聯的 pipeline,pipeline 運行成功,目標分支合入 master 后,再執行正式發布。

③ 正式發布階段

  • 由于 tag 觸發的 pipeline 包含二進制打包、源碼及二進制版本發布的 stage,因此在這個階段只需要管理 tag 及關聯的 pipeline 就可以實現發布功能。這時候如果 tag 版本已經存在,GitLab 會返回創建失敗,雖然 GitLab 提供了刪除 tag 的功能,但還是不建議這么做的,我們會在 web 端提示發布失敗,并且注明 tag 已存在,讓組件負責人修改版本后重試發布此組件。
  • GitLab 創建 tag 操作是異步的,因此我們會在 webhook 中監聽 tag 創建結果,創建成功之后,就可以處理 pipeline。上文提到過 以 [ci skip] 開頭 commit 不會觸發 pipeline,所以需要在這里做下判斷,如果已經有 pipeline,那么只更新對應數據庫條目,否則就需要創建新的 pipeline。

六、更新依賴

  • 在所有組件發布完成后,我們會把變更的組件版本,同步到發版工程對應分支的 Podfile 中。受限于目前的工作流程和有限的工具鏈,在開發時,還是避免不了手動修改 Podfile,所以依舊使用 ruby 來編寫 Podfile,沒有使用 YAML 或者 JSON 格式 (pod ipc podfile/podfile-json 可查看)。
  • 過于靈活的編寫方式,使得對其執行正則匹配需要以先推行編寫規范為基礎,因此不使用正則,而是讓開發者提供 Podfile 模版,比如正常的 Podfile 為:
# 一些 ruby 語法的配置 target 'E' dopod 'A', git: 'xxxx', branch: 'release/0.1.0'pod 'J' end # 一些 ruby 語法的配置
  • 那么開發者可以在同級目錄下,添加 PodfileTemplate :
# 一些 ruby 語法的配置 target 'E' do :TRIPLECCREPLACEME end # 一些 ruby 語法的配置
  • labor 會先獲取原 Podfile,解析其依賴之后,再根據數據庫中的組件及其發布版本號,更新這些依賴,然后將 PodfileTemplate 文件的 :TRIPLECCREPLACEME 替換成更新后的依賴,以生成新的 Podfile:
# 一些 ruby 語法的配置 target 'E' dopod 'A', '= 0.1.0'pod 'J' end # 一些 ruby 語法的配置
  • 當然,在工具鏈成熟的情況下,使用 JSON 或者 YAML 格式編寫的 Podfile,更易于自動化處理,所以個人推薦前期最好不要在 Podfile 中添加過多 ruby 自定義代碼,如果需要的話,可以以 cocoapods 插件的形式集成。

七、總結

  • 由于 labor 只是個人在開發維護,所以制定流程和細節處理上可能不是非常合理,但就目前成果來看,labor 還是初步實現了發版時的組件自動化發布。本文更多的是展示了正常發布流程,實際上整個發布過程中,還是要處理挺多異常流程的。
  • 不過在發版本時才統一對需要發布的組件進行驗證,容易出現解決組件 lint 錯誤時間過長影響發版問題,所以可能還是需要添加組件準入規則,將這部分驗證往前移,比如約束主工程的分支權限,在預發提測前讓開發者預先打 rc 版本,確保 rc 版本驗證成功之后,再以 web 操作的方式接入主工程,預發階段修復組件 bug 后,重新走接入流程,這樣應該就能保證發版時,需要發布組件的正確性(關于 rc 版本的 lint ,可能還需要變更下 CocoaPods 查找版本的默認方式,畢竟 Semantic Versioning 優先采用正式版本)。

總結

以上是生活随笔為你收集整理的iOS之深入解析CocoaPods的GitLab CI与组件自动化构建与发布的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

97碰在线 | 久久高清精品 | 久久精品一级片 | 四虎免费在线观看视频 | 国产成人精品av在线 | 亚洲毛片视频 | 91综合色 | 免费成人黄色av | 五月婷婷综合久久 | 日韩精品三区四区 | 日韩资源在线播放 | 综合色爱 | 婷婷av电影 | 亚洲免费av电影 | 美腿丝袜一区二区三区 | 亚洲高清色综合 | 97成人精品视频在线观看 | 91视频在线免费看 | 婷婷六月久久 | 久久久久久久久久久久久国产精品 | 国产一级大片在线观看 | 最新中文字幕在线观看视频 | 日韩特黄一级欧美毛片特黄 | 亚洲午夜av久久乱码 | 丁香激情综合国产 | 99视频免费 | 国产精品久久久久久久久久不蜜月 | 天天射天天操天天干 | av成人在线观看 | 久久综合精品国产一区二区三区 | 日韩一区精品 | 国产少妇在线观看 | 手机av永久免费 | 久久99国产综合精品 | 日韩免费视频在线观看 | 亚洲一级特黄 | 久久精品久久99 | 亚洲国产人午在线一二区 | 国产精品黑丝在线观看 | 久久国产色 | 五月婷婷综合久久 | 顶级bbw搡bbbb搡bbbb | 在线看国产精品 | 中文字幕在线免费播放 | 激情视频一区 | 91经典在线| 激情动态 | 超碰人人草人人 | 久久久免费精品国产一区二区 | 国产高清在线a视频大全 | 五月婷婷伊人网 | 国产一卡久久电影永久 | 国产夫妻性生活自拍 | 91porny九色91啦中文 | 99久久精品国产亚洲 | 久久9999久久 | 亚洲va综合va国产va中文 | 亚洲精品九九 | 一级淫片在线观看 | 成人午夜精品福利免费 | 五月天堂网 | 九色视频网站 | 久久永久免费 | 国产精品久久久久久吹潮天美传媒 | av大片免费在线观看 | 人人澡澡人人 | 欧美作爱视频 | 在线国产精品一区 | 又黄又爽的视频在线观看网站 | 国产美女在线免费观看 | 国产精品久久在线观看 | 国产精品一区二区久久精品爱微奶 | 久久久99精品免费观看app | www.夜夜| www·22com天天操 | 天天搞天天 | 精品国产一区二区三区av性色 | 欧美亚洲免费在线一区 | 人人干97| 日韩午夜av电影 | 香蕉视频在线观看免费 | 视频成人永久免费视频 | 丝袜美腿亚洲 | 久久99久久久久久 | 日韩免费三区 | 91精品国产一区二区三区 | 天天综合网入口 | 免费观看黄 | 久久午夜网 | 日韩狠狠操 | 99久精品视频 | 国产麻豆精品一区 | 97超碰网| 一级特黄aaa大片在线观看 | 国产精品精品视频 | 91人人澡人人爽人人精品 | 中文字幕欧美激情 | 狠狠做六月爱婷婷综合aⅴ 日本高清免费中文字幕 | 日韩在线视频二区 | av高清免费在线 | 精品国产免费人成在线观看 | 狠狠操导航 | 欧美激精品 | 日日操操操 | 91麻豆精品国产自产在线游戏 | 91av手机在线观看 | 高清一区二区 | 婷婷六月色 | 亚洲精品中文字幕视频 | 99精品国产高清在线观看 | 色婷婷狠狠五月综合天色拍 | 免费网站v| 精品久久久久久久 | 亚洲国产午夜视频 | 久久www免费视频 | 欧美性色网站 | 欧美精品视 | 日韩激情免费视频 | 亚洲成a人片在线www | 国产精品原创av片国产免费 | 91电影福利| 天天做天天爱夜夜爽 | 欧美福利精品 | 人人射人人插 | 亚洲午夜久久久久久久久久久 | 国内精品久久久精品电影院 | 日韩电影在线一区二区 | 在线电影日韩 | 国产久草在线 | 在线一级片 | 一本色道久久精品 | 国产夫妻av在线 | 日本亚洲国产 | 91精品网站 | 超碰在线人人艹 | 97干com| av电影免费在线看 | 日本免费一二三区 | 一级一片免费观看 | 免费黄色在线网址 | 国产91综合一区在线观看 | 久久私人影院 | 在线观看中文字幕2021 | 国产成人一级电影 | 国产成人黄色av | 国产精品黄 | 国产一区在线看 | 中文字幕国产视频 | 黄色大片视频网站 | 成人精品一区二区三区中文字幕 | 国产精品小视频网站 | 国产精品久久久久久久久大全 | 精品视频成人 | 五月婷香 | 精品视频久久久久久 | 亚洲精品国产成人 | 日韩精品在线视频 | av免费网 | 欧美aa一级片 | 操久| 91九色成人 | 国产裸体永久免费视频网站 | 日本中文字幕在线免费观看 | 在线观看视频你懂的 | 久久久精品在线观看 | 三级黄色大片在线观看 | 婷婷av资源 | 欧美日韩精品在线观看视频 | 国内久久精品 | 超碰人人在线观看 | 日本99干网| 久久久久久麻豆 | 久久综合99 | 韩国一区二区三区在线观看 | 日本精品视频在线播放 | 四虎成人精品在永久免费 | 午夜骚影 | 在线观看视频免费大全 | 黄色小说视频在线 | 91麻豆精品国产91久久久久久 | 成人黄色片免费 | 亚洲一区网站 | 九九热视频在线播放 | 亚洲精品综合久久 | 99高清视频有精品视频 | 日韩av三区| 91天堂在线观看 | 免费视频色 | 国产中文字幕视频在线观看 | 99热最新在线 | 国产精品aⅴ | 中文字幕在线观看2018 | 在线欧美最极品的av | 国产精品九九久久99视频 | 999久久久精品视频 日韩高清www | 天天躁日日 | 久久国际影院 | 国产一级高清 | 久草电影免费在线观看 | 日本久久高清视频 | 国产91丝袜在线播放动漫 | 日日日日日 | 手机看片久久 | 欧美日韩在线免费观看 | 国产成人一区二区三区在线观看 | 成在人线av | 国产高清永久免费 | 色九九影院 | 成人全视频免费观看在线看 | 91一区啪爱嗯打偷拍欧美 | 精品视频专区 | 蜜臀aⅴ国产精品久久久国产 | 日韩av资源站 | av色一区| 国产精品乱码一区二三区 | www.伊人色.com | 亚洲国产成人精品电影在线观看 | 91精品国产91久久久久福利 | 激情五月看片 | 免费观看一级特黄欧美大片 | 色婷五月天 | 日日干干夜夜 | www.黄色在线 | av三级av| 国产精品日韩久久久久 | 欧美人人爱 | 99视频在线精品国自产拍免费观看 | 黄p在线播放 | 国产精品美女久久久免费 | 激情五月综合网 | 手机在线小视频 | 视频在线91 | 亚洲国产av精品毛片鲁大师 | www.亚洲在线 | 亚洲精品tv | 国产日韩欧美在线观看视频 | 国产精品国产三级国产不产一地 | 91片在线观看 | 午夜av激情 | 五月天激情电影 | 日本中文在线观看 | 亚洲免费观看在线视频 | 黄色小说视频网站 | 日韩精品一区二区免费视频 | 日韩视频在线播放 | 人人澡人人添人人爽一区二区 | 欧美不卡视频在线 | 久久久国产精品人人片99精片欧美一 | 国产日韩在线看 | 亚洲精品成人网 | 久久久精品视频网站 | 最近最新中文字幕视频 | 操少妇视频 | 97在线看 | 国产精品欧美久久久久三级 | 免费在线观看视频a | 伊人伊成久久人综合网站 | 91精品国产自产91精品 | 黄色片免费在线 | 国产精品亚洲片在线播放 | av片子在线观看 | 欧美一级片免费播放 | 午夜色场| 91最新在线视频 | 婷婷丁香花五月天 | 国产精品久久久一区二区三区网站 | 国产精品入口麻豆 | 6080yy精品一区二区三区 | 色网站国产精品 | 日本久热| 日本特黄特色aaa大片免费 | 亚洲一二区视频 | 91在线蜜桃臀 | av无限看 | 色婷婷综合视频在线观看 | 国产精品免费观看视频 | 国产美女在线精品免费观看 | 久久久国产精品人人片99精片欧美一 | 日批视频 | 亚洲精品一区二区在线观看 | 亚洲黄色片在线 | 在线观看免费av网 | 久久这里只有精品视频首页 | 免费a级毛片在线看 | 最新国产中文字幕 | 成年人免费在线 | 久草资源在线 | 久久免费在线观看 | 中字幕视频在线永久在线观看免费 | 久99热| 国产中文字幕视频 | 色夜影院 | 亚洲性少妇性猛交wwww乱大交 | 91视频免费看网站 | 欧美a视频 | 日本中文字幕在线播放 | 日本特黄特色aaa大片免费 | 亚洲二区精品 | 中文字幕免费观看全部电影 | 国产精品av免费观看 | 日韩欧美高清在线 | 国产黑丝一区二区三区 | 国产亚洲综合精品 | 日韩激情免费视频 | 免费观看性生交 | 久久九九影视 | 在线免费观看视频一区 | 国产一级黄色片免费看 | 欧美一二三在线 | 久久精品国产亚洲精品 | 久艹在线免费观看 | 日韩电影黄色 | 日韩91av | 四虎视频| 91福利试看| 97免费| 五月婷婷影院 | 成人免费毛片aaaaaa片 | 久久免费毛片视频 | 国产一区二区精品91 | 日韩欧美精品在线 | 成人精品久久久 | 国产99区 | 一级黄网 | 91成人精品一区在线播放 | 天天插天天干天天操 | 激情婷婷网 | 日韩av片免费在线观看 | 亚洲天天草 | 九九激情视频 | 黄污视频大全 | 天天综合五月天 | 国产精品激情 | 亚洲精品黄色 | 91欧美在线 | 中文字幕在线视频精品 | 亚洲国产精久久久久久久 | 国产精品一区二区三区在线播放 | 99精品视频在线 | 日本在线观看一区二区 | 久久久精品福利视频 | 国产伦精品一区二区三区高清 | 91丨九色丨蝌蚪丨老版 | 在线观看av网 | 久热免费在线观看 | 日韩欧美国产成人 | 人人干天天干 | 99久久久久久久久久 | 国产色影院| 日韩欧美精品在线观看视频 | 欧美极品在线播放 | 久久久久成人精品免费播放动漫 | 欧美在线视频二区 | 欧美成人va | 蜜臀av网址 | 日韩免费观看一区二区 | 97天天干 | 国产一区欧美二区 | 亚洲国产精品一区二区久久hs | 色噜噜日韩精品欧美一区二区 | 视频在线观看亚洲 | 最新国产精品拍自在线播放 | 久久视频在线观看 | 激情欧美一区二区免费视频 | 国产成年人av | 国产精品久久久久久吹潮天美传媒 | av888.com| 国产精品久久久久久久久费观看 | 色视频网站免费观看 | 免费看一级特黄a大片 | 国产小视频免费在线网址 | 成人片在线播放 | 国产高清不卡av | 精品一二| 最近高清中文字幕在线国语5 | 色噜噜狠狠狠狠色综合 | 国产精品久久久久久久99 | 国产亚洲精品久久久久动 | 久久久久黄 | 久久99在线观看 | 日日日日日 | 精品久久久久一区二区国产 | 成人午夜电影在线播放 | 国产免费一区二区三区网站免费 | 在线成人免费 | 91刺激视频 | 免费黄色在线网站 | 久久久国产精品一区二区三区 | 亚洲区精品 | 欧美一二三四在线 | 狠狠干狠狠久久 | 午夜精品一区二区三区免费视频 | 久久艹人人 | 东方av在| 色噜噜在线观看视频 | 美女免费视频黄 | 麻豆视频在线免费观看 | 精品中文字幕在线 | 精品高清美女精品国产区 | 九九热免费精品视频 | 人人干人人艹 | 国产成人精品在线播放 | 中文字幕永久在线 | 黄色日批网站 | 黄色三级av | 808电影| 国模视频一区二区 | 亚洲精品国产精品国自产在线 | 韩国av一区 | 东方av免费在线观看 | 久久久99精品免费观看乱色 | 中文字幕国产一区 | 国产美女被啪进深处喷白浆视频 | 日韩精品亚洲专区在线观看 | 欧洲亚洲激情 | 操操操夜夜操 | 美女免费视频一区 | 国产成人精品一区二区三区网站观看 | 免费一级片观看 | 成人在线免费观看网站 | 91成人在线免费观看 | 久久国产品 | 在线观看免费一级片 | 成人毛片一区二区三区 | 日本久久久亚洲精品 | 三级黄色欧美 | 久草在线观看资源 | 欧美精品做受xxx性少妇 | 一区二区视频电影在线观看 | 国产一级在线免费观看 | 999国内精品永久免费视频 | 国产视频精品久久 | 欧美激情综合五月色丁香小说 | 亚洲精品综合一二三区在线观看 | 日韩高清片 | 天天操天天射天天添 | 午夜精品久久久久久久久久久久久久 | 国产不卡在线观看视频 | 日韩免费av在线 | 久久久久久久福利 | 婷婷综合伊人 | 亚洲高清视频在线观看免费 | av电影在线观看 | 国产99久久精品一区二区300 | 天天草夜夜 | 久久国产热视频 | 97在线精品视频 | 色综合人人 | 啪啪动态视频 | 亚洲精品国产精品久久99 | 久久精品视频在线免费观看 | 狠狠亚洲 | 九九九九热精品免费视频点播观看 | 亚洲黄色av | 婷婷中文字幕在线观看 | 爱av在线网 | 国产色婷婷精品综合在线手机播放 | 亚洲高清av | 国产精品白浆视频 | 97免费在线观看视频 | 久久伦理电影网 | 免费又黄又爽 | 久久视频一区 | 精品国产电影 | 婷婷六月天丁香 | 狠狠狠色丁香婷婷综合久久88 | 五月婷视频 | 国产精品免费看久久久8精臀av | 久久影视网 | 午夜12点 | 黄在线免费观看 | 激情综合五月婷婷 | 国产精品99久久久精品 | 亚洲精品视频免费在线观看 | 久久久国产99久久国产一 | 天天爽夜夜爽精品视频婷婷 | 婷婷色狠狠 | 国产综合激情 | 国产成人精品国内自产拍免费看 | 久久久人人人 | www视频免费在线观看 | 亚洲v欧美v国产v在线观看 | 精品久久久久亚洲 | 亚洲最大av在线播放 | 国产精品久久久久aaaa九色 | 在线看欧美 | 国产片免费在线观看视频 | 99电影| 午夜久久影院 | 日韩网站在线看片你懂的 | 黄色av电影 | 制服丝袜在线 | 中文字幕在线不卡国产视频 | 中文字幕一二三区 | 黄色aaaaa | 永久免费的av电影 | 国产精品视频免费在线观看 | 黄色tv视频| 欧美日韩二三区 | 日韩精品2区 | 成人av中文字幕在线观看 | 精品国自产在线观看 | 夜夜夜夜猛噜噜噜噜噜初音未来 | 97香蕉超级碰碰久久免费软件 | 激情网站网址 | 日韩午夜电影网 | 精品国产伦一区二区三区免费 | 亚洲精品国产精品乱码不99热 | 色综合 久久精品 | 久久在线视频精品 | 高清精品在线 | 午夜精品婷婷 | 亚洲精品国产综合99久久夜夜嗨 | 一区二区丝袜 | av免费在线播放 | 99产精品成人啪免费网站 | 人人爱天天操 | 亚州国产精品视频 | 一区二区三区四区在线免费观看 | 香蕉视频在线视频 | 国产黄色视 | 成人小电影在线看 | 中文字幕在线视频一区二区 | 人人插人人插 | 99久免费精品视频在线观看 | 亚洲综合在线一区二区三区 | 91精品91 | 91精品久久久久 | 国产午夜精品理论片在线 | 色精品视频 | 射射色| 国产综合精品一区二区三区 | 国产精品美女久久久久久久 | 人九九精品 | 久久夜色网 | 午夜国产一区二区 | 最近最新mv字幕免费观看 | 黄色a级片在线观看 | 国产xxxxx在线观看 | 日韩免费av片 | 中文字幕网站视频在线 | 九九色综合 | 日韩精品一区不卡 | 西西www444| 日韩资源在线播放 | 中文字幕在线看视频国产 | 狠狠狠色丁香婷婷综合久久88 | 91九色视频国产 | 久久综合久久八八 | 亚洲永久精品在线 | 日韩字幕 | 国产精品资源在线观看 | 色综合天天视频在线观看 | 亚洲免费专区 | 日韩免费av网址 | 亚洲综合射 | 国产手机av在线 | 欧美一级免费在线 | 欧美日韩在线视频观看 | 免费av小说 | 一级欧美日韩 | 亚洲精品视频在线 | 激情中文在线 | 九九九九热精品免费视频点播观看 | 亚洲成av人电影 | 国产精品视频永久免费播放 | 久操操| 九九爱免费视频 | 国产 日韩 欧美 中文 在线播放 | 97视频免费在线 | 超碰97人人射妻 | 午夜性盈盈 | 黄色大片入口 | 中文字幕在线网 | 免费99精品国产自在在线 | 久久精品二区 | 一二区精品 | 99在线热播精品免费 | 欧美一区二区三区在线视频观看 | 国产精品视频地址 | 亚洲蜜桃在线 | 国产精品久久久久久久av电影 | 亚洲一级黄色av | 视频国产精品 | 黄色在线小网站 | 日日干 天天干 | 国产精品观看 | 91亚洲精品久久久久图片蜜桃 | 91免费观看网站 | 久久久精华网 | 欧美在线观看视频 | 久久艹久久 | 国产日韩精品在线 | 麻豆传媒视频在线播放 | 国产香蕉视频在线观看 | 中文字幕在线精品 | 毛片.com | 波多野结衣久久精品 | 久久久久久久综合色一本 | 黄色小说在线观看视频 | 亚洲不卡123| 久久激情影院 | 超碰97在线人人 | 6080yy精品一区二区三区 | 色香蕉网 | 992tv在线成人免费观看 | 天天综合操| 日本在线中文在线 | 久久国产精品第一页 | 日韩欧美精品一区 | 久久久精品日本 | 婷婷婷国产在线视频 | 日韩欧美在线不卡 | av片在线看| 中文字幕成人在线 | 99久久夜色精品国产亚洲 | 国产精品五月天 | 久久久美女 | 日韩在线视频观看 | 九九在线精品视频 | 在线电影av | 超碰日韩 | 97超碰伊人 | 青青久视频 | 国产成人区 | 黄色亚洲片 | 色综合夜色一区 | 在线天堂视频 | 色综合天天狠天天透天天伊人 | 免费在线观看日韩欧美 | 美女视频免费一区二区 | 91精品一区二区三区久久久久久 | 五月天综合激情 | 久久免费在线观看视频 | 少妇bbw搡bbbb搡bbbb | 国产高清第一页 | 亚洲欧洲中文日韩久久av乱码 | 国产精品第一页在线观看 | 日韩三级.com | 国产男女免费完整视频 | 久久刺激视频 | 韩日精品在线 | 国产偷在线 | 亚洲午夜精品久久久 | 久久精品一区二区三区国产主播 | 国产亚洲精品久久19p | 国产视频观看 | 国产精品夜夜夜一区二区三区尤 | 91在线超碰 | 亚洲精品在线资源 | 日韩欧美精品在线观看视频 | 在线观看色视频 | 正在播放五月婷婷狠狠干 | 国产综合在线观看视频 | 亚洲欧美日韩国产 | 国产精品麻豆99久久久久久 | 亚洲综合在线播放 | 久久精品人人做人人综合老师 | 亚洲 在线 | 99久e精品热线免费 99国产精品久久久久久久久久 | 黄色亚洲大片免费在线观看 | 丁香六月激情 | 久久理伦片 | 日韩精品一卡 | 成人啊 v | 久久国产精品视频免费看 | 麻豆网站免费观看 | 亚洲在线日韩 | 999久久精品| 麻豆一二三精选视频 | 久久中国精品 | 中文字幕亚洲高清 | 亚洲乱码中文字幕综合 | 久久久久久久99 | 中文字幕一区二区三区久久 | 久久综合久久综合久久 | 国色天香在线 | 免费亚洲精品 | 亚洲综合视频网 | 天天操天天操天天操天天 | 韩国av在线 | 韩国av一区| 久草在线视频首页 | 亚洲涩涩涩涩涩涩 | 国产成人精品av | 欧美精品中文在线免费观看 | 美女免费黄视频网站 | 国产色在线 | 欧美成人黄色 | 91亚洲欧美 | 欧美成人理伦片 | 婷婷5月激情5月 | 午夜精品视频一区 | 麻豆精品国产传媒 | 久久精品亚洲一区二区三区观看模式 | 最近中文字幕视频完整版 | 免费在线观看国产精品 | 69国产盗摄一区二区三区五区 | 国产精品久久久久久久久费观看 | 久草99 | 玖玖国产精品视频 | 91精品视频播放 | 999视频网站 | 韩国av在线播放 | www.久草.com | 日韩av中文在线观看 | 一区免费视频 | 国内免费久久久久久久久久久 | 国产成人在线观看免费 | 激情丁香在线 | 人人添人人澡人人澡人人人爽 | 久久免费视频在线 | 国产老太婆免费交性大片 | 亚洲第一中文网 | 国产盗摄精品一区二区 | 精品综合久久久 | 中文字幕在线日 | 月下香电影 | 国内成人精品2018免费看 | 免费视频一区二区 | 中文国产字幕 | 麻豆国产精品永久免费视频 | 嫩草av在线| 久久成人在线视频 | 九九精品久久久 | 视频在线一区二区三区 | 成人h在线播放 | 精品不卡av | 久久国产精品99国产 | 国产91影视 | 一区在线播放 | 激情五月***国产精品 | 99热精品国产一区二区在线观看 | 国产资源在线视频 | 亚洲精品男人天堂 | 国产视频97 | 久久开心激情 | 国产精品久久99综合免费观看尤物 | 亚洲欧洲日韩 | 久久国语露脸国产精品电影 | 69国产成人综合久久精品欧美 | 色综合天天射 | 91av官网 | 97av视频 | av网站大全免费 | 九九综合九九 | 中文字幕欲求不满 | 婷婷日日| 精品久久久久免费极品大片 | 久久国产精品一国产精品 | 免费成人在线电影 | 欧美日韩在线精品一区二区 | 亚洲日本va中文字幕 | 中文高清av | 五月精品 | 夜又临在线观看 | 日本视频高清 | 亚洲成人在线免费 | av电影av在线| 91麻豆精品国产91久久久无限制版 | 免费国产在线精品 | 精品超碰 | 亚洲一级黄色片 | 国产精品成久久久久三级 | 亚洲电影一区二区 | 日本精品中文字幕在线观看 | 色综合久久88色综合天天6 | 九九九九九九精品任你躁 | 最近的中文字幕大全免费版 | 国产专区一 | 91精品国产综合久久福利不卡 | 亚洲一区日韩精品 | 中文字幕大全 | 久久久91精品国产 | 伊人永久在线 | 操操综合网| 人人干干人人 | 在线观看mv的中文字幕网站 | 久久久久高清毛片一级 | 黄色软件视频大全免费下载 | 另类五月激情 | 亚洲精品五月天 | 国产精品成人一区二区 | 日韩在线高清免费视频 | 麻豆高清免费国产一区 | 国产免费一区二区三区网站免费 | 国产成人一区二区三区免费看 | 亚洲午夜激情网 | 国产精品美女久久久免费 | 92av视频 | 亚洲美女视频在线观看 | 精品久久网 | 久草视频观看 | 精品不卡视频 | 国产精品久久久久久久久久久久午夜片 | 久久久久 免费视频 | 免费在线看成人av | 国产精品久久久久久麻豆一区 | av九九| 国产1区在线观看 | 免费一级特黄毛大片 | 亚洲精品视频在线观看免费视频 | 又黄又爽又色无遮挡免费 | 日韩成人在线一区二区 | 91九色老| 婷婷久久综合九色综合 | 在线观看国产成人av片 | 美女久久久久久久 | 国产中文伊人 | 91超在线 | 国产中文字幕在线视频 | 97成人精品视频在线观看 | 热re99久久精品国产66热 | 99精品99| 久久久久综合网 | 亚洲日韩精品欧美一区二区 | 欧美成人亚洲 | 国产精品久久久久久久午夜片 | 日韩精品中文字幕在线不卡尤物 | 青青视频一区 | 国产精品女同一区二区三区久久夜 | 中文字幕在线一区观看 | 亚洲高清视频在线 | 狠狠干干 | 免费a级观看 | 色婷五月 | 久久字幕精品一区 | 亚洲理论电影 | 黄色aaa级片 | 日韩电影中文字幕在线观看 | 国产麻豆成人传媒免费观看 | 91av在线不卡 | 9久久精品 | 九月婷婷综合网 | 亚洲免费视频在线观看 | 不卡电影一区二区三区 | 欧美韩日视频 | 在线观看中文字幕av | 久久99精品一区二区三区三区 | 精品在线观看视频 | 国产在线久久久 | 特级西西人体444是什么意思 | 黄网站免费大全入口 | 99久久久久久 | 日韩免费在线观看网站 | 黄色福利网站 | 国产香蕉久久 | 在线观看免费黄视频 | 九九热视频在线 | 久久久久一区二区三区四区 | 日韩在线激情 | 日本一区二区三区视频在线播放 | 91香蕉视频黄 | 亚洲视频 在线观看 | 91在线播放综合 | 黄色av网站在线观看 | 日韩av在线网站 | 狠狠色噜噜狠狠 | 日本在线精品视频 | 999精品在线| 亚洲精选视频免费看 | 中中文字幕av在线 | 99精彩视频在线观看免费 | 91精品福利在线 | 久久国产精品久久精品 | 亚洲精品美女久久 | 中文字幕在线播出 | 婷婷综合亚洲 | 久久xx视频 | 五月婷婷.com | 精品美女在线观看 | 最近免费观看的电影完整版 | 欧美色图一区 | 在线直播av| 久久黄色美女 | 91九色在线| 国产视频一区在线 | 91探花在线视频 | 精品国产乱码 | 欧美伦理电影一区二区 | 我要看黄色一级片 | 天天色天天操天天爽 | 成人av片在线观看 | 婷婷色在线 | 国产成人精品午夜在线播放 | 国产大尺度视频 | 91午夜精品 | 免费一级特黄录像 | 亚洲高清视频一区二区三区 | 亚洲午夜久久久综合37日本 | 国产啊v在线观看 | 丝袜美女在线观看 | 在线观看日韩国产 | 中文字幕在线不卡国产视频 | 久久精品亚洲精品国产欧美 | 国产精品无av码在线观看 | 久草9视频| 精品女同一区二区三区在线观看 | 欧美日韩国产成人 | 亚洲一区精品二人人爽久久 | 黄色小网站在线 | 精品久久久999 | 成人黄色中文字幕 | 国产精品大全 | 九九免费精品 | 久久久久久毛片精品免费不卡 | 人人澡人人爽欧一区 | 黄色片视频在线观看 | av电影 一区二区 | 亚洲精品久久久久久久不卡四虎 | 一区二区三区动漫 | 成人免费一区二区三区在线观看 | 日韩av电影手机在线观看 | 美女在线免费视频 | 天堂va在线高清一区 | 亚洲精品一区二区三区高潮 | 日韩欧美精品一区二区三区经典 | 91理论电影 | 亚洲欧洲国产日韩精品 | 中文字幕免费久久 | 久久久国产精品久久久 | 精品久久久久_ | 国产成视频在线观看 | 97超级碰碰碰视频在线观看 | 一区二区三区观看 | 麻豆一精品传二传媒短视频 | av888av.com | 亚洲欧美激情精品一区二区 | 91刺激视频 | av大片免费 | h视频在线看 | 中文字幕日韩无 | 国产成人在线网站 | 欧美精品一区二区性色 | 国产成人一区二区三区免费看 | 在线草 | 国产免费叼嘿网站免费 | 97精品国产手机 | 人人干人人艹 | 欧美一二三区在线观看 | 日韩久久网站 | 美女视频永久黄网站免费观看国产 | 国产在线精品福利 | 日日草天天干 | 成人全视频免费观看在线看 | www.激情五月.com | 在线高清av | 最新色站 | 夜夜操天天 | 在线日韩av | www国产亚洲精品久久网站 | 欧美大香线蕉线伊人久久 | 成人一区电影 | 成人毛片100免费观看 | 国产精品久久久久久久久久白浆 | 久草亚洲视频 | 在线天堂日本 | 免费看一及片 | 伊人天天干| 91av片| 国产亚洲精品免费 | 国产精品麻豆视频 | 婷婷在线免费视频 | 亚洲欧洲精品久久 | 三级a视频| 手机看片 | 在线导航福利 | 国产精品大尺度 | 亚欧洲精品视频在线观看 | 99国产情侣在线播放 | 久草久草在线 | 亚洲涩涩网 | 国产高清视频在线观看 | www.五月婷 | 美女免费视频网站 | 99热国产在线观看 | 色黄www小说 | www操操| 亚洲国产成人高清精品 | 欧美精品一区二区性色 | 天天爽人人爽 | 天天干天天拍天天操天天拍 | 中文字幕一区二区三区在线观看 | 日韩久久久久久久久久久久 | 欧美大片mv免费 | 亚洲另类xxxx | 99视频一区二区 | 粉嫩av一区二区三区四区在线观看 | 免费av网址大全 | 成人久久久久久久久久 | 久久久影院官网 | 麻豆久久久 | 四虎最新域名 | 国产99精品| 日日躁夜夜躁xxxxaaaa | av高清免费 | 日韩一区二区三区在线观看 | 成人理论在线观看 |