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

持續(xù)測(cè)試基礎(chǔ)設(shè)施

開發(fā) 測(cè)試
持續(xù)測(cè)試不僅是持續(xù)交付高質(zhì)量軟件的必要保障,對(duì)于基礎(chǔ)設(shè)施而言,其價(jià)值和影響更為深遠(yuǎn)。本文來分享一下我們團(tuán)隊(duì)是如何對(duì)基礎(chǔ)設(shè)施進(jìn)行測(cè)試的。

作者 | 趙志佳

持續(xù)測(cè)試基礎(chǔ)設(shè)施的必要性

基礎(chǔ)設(shè)施作為應(yīng)用程序的支柱,為之提供關(guān)鍵的運(yùn)行環(huán)境、網(wǎng)絡(luò)連接和資源調(diào)度等支持。一旦基礎(chǔ)設(shè)施出現(xiàn)故障,整個(gè)應(yīng)用生態(tài)系統(tǒng)都可能面臨嚴(yán)重的連鎖反應(yīng),如性能降低、數(shù)據(jù)丟失乃至系統(tǒng)崩潰。因此,基礎(chǔ)設(shè)施的穩(wěn)定性和可靠性對(duì)于運(yùn)行在其上的應(yīng)用程序至關(guān)重要。

持續(xù)測(cè)試可以在基礎(chǔ)設(shè)施的整個(gè)生命周期中進(jìn)行檢查,確保一切運(yùn)行正常,盡早發(fā)現(xiàn)并解決潛在問題,減少影響擴(kuò)散。此外,持續(xù)測(cè)試通過為團(tuán)隊(duì)提供即時(shí)的狀態(tài)反饋,有助于提高基礎(chǔ)設(shè)施的可維護(hù)性和可擴(kuò)展性,進(jìn)而支持業(yè)務(wù)持續(xù)增長和變化的需求。

因此,持續(xù)測(cè)試不僅是持續(xù)交付高質(zhì)量軟件的必要保障,對(duì)于基礎(chǔ)設(shè)施而言,其價(jià)值和影響更為深遠(yuǎn)。

本文來分享一下我們團(tuán)隊(duì)是如何對(duì)基礎(chǔ)設(shè)施進(jìn)行測(cè)試的。

測(cè)試的范圍

首先我們要識(shí)別出需要測(cè)什么。在 IaC(基礎(chǔ)設(shè)施即代碼)的實(shí)踐中,我們以測(cè)試金字塔和敏捷測(cè)試四象限為指導(dǎo)原則,適用的測(cè)試方案包括:

  • 單元測(cè)試:對(duì)實(shí)現(xiàn)中的特殊邏輯,比如環(huán)境差異、批量處理等進(jìn)行部署前的驗(yàn)證。
  • 組件測(cè)試:對(duì)部署的獨(dú)立組件進(jìn)行驗(yàn)證,部署結(jié)果與預(yù)期一致。比如 S3 bucket 部署配置。
  • 功能測(cè)試:對(duì)多個(gè)需要串聯(lián)合作使用才能達(dá)成實(shí)現(xiàn)一個(gè)功能的組件進(jìn)行驗(yàn)證,保證組件間配置的正確性。比如通過公網(wǎng)域名可以訪問到 app。
  • 冒煙測(cè)試:在服務(wù)、組件部署完成之后進(jìn)行端到端驗(yàn)證,確保服務(wù)基本可用和出入口配置的正確性。
  • 安全性測(cè)試:驗(yàn)證各項(xiàng)安全配置是否已經(jīng)啟用。比如數(shù)據(jù)庫、域名是否采取了 TLS 且無法在不加密情況下進(jìn)行連接。其它的如權(quán)限控制、代碼漏洞等。
  • 可靠性測(cè)試:基礎(chǔ)設(shè)施的容災(zāi)耐力、數(shù)據(jù),混沌工程等。
  • 部署測(cè)試:確保應(yīng)用在發(fā)布的過程中,平臺(tái)提供了正確可用的部署能力。
  • 性能、可用性測(cè)試:服務(wù)的響應(yīng)時(shí)間、吞吐量、并發(fā)用戶數(shù)等指標(biāo)。由于平臺(tái)在服務(wù)間添加了一些基礎(chǔ)設(shè)施級(jí)組件和服務(wù),如 Service Mesh、Styra,所以也會(huì)受到影響。因此,平臺(tái)團(tuán)隊(duì)可以構(gòu)建一個(gè)覆蓋了影響范圍的簡(jiǎn)單應(yīng)用,對(duì)其進(jìn)行驗(yàn)證。

明確了測(cè)試方案,我們就需要識(shí)別測(cè)試優(yōu)先級(jí),在不同階段開展相應(yīng)的測(cè)試:

  • 首先覆蓋關(guān)鍵路徑和高價(jià)值,如單元測(cè)試、組件測(cè)試、功能測(cè)試。這些代碼變化而引發(fā)的測(cè)試在代碼變化時(shí)都應(yīng)該進(jìn)行。
  • 其次是覆蓋代碼變化之外由我們可控因素導(dǎo)致的問題,如證書到期、磁盤空間滿、token 失效等,保證運(yùn)行時(shí)環(huán)境相關(guān)組件和功能。如冒煙測(cè)試、部署測(cè)試、可用性測(cè)試等??梢栽谄脚_(tái)功能上了生產(chǎn)環(huán)境后,核心功能交付無壓力時(shí)進(jìn)行。
  • 最后是在平臺(tái)相較穩(wěn)定后(即被測(cè)功能不會(huì)有大的變動(dòng)時(shí)),以提高平臺(tái)可靠性為目的的測(cè)試。用來驗(yàn)證在面對(duì)代碼之外,不可控的因素導(dǎo)致的問題發(fā)生時(shí)我們的應(yīng)對(duì)能力。如外部依賴變化、數(shù)據(jù)恢復(fù)能力、容災(zāi)重建能力等。通常在平臺(tái)上的應(yīng)用服務(wù)在生產(chǎn)環(huán)境已有真實(shí)用戶投入使用后進(jìn)行。

測(cè)試工具的選擇

市面上有很多可以測(cè)試工具可以選擇:

  • 最基礎(chǔ)和單一的是 Shell 腳本語言,典型如 Bash。
  • 之后是應(yīng)用開發(fā)語言的測(cè)試框架,如 Bash 的 bats、Ruby 的 RSpec 和 JavaScript 的 Jest。
  1. 最后是在語言提供的能力上對(duì)三方 cli 和 API 進(jìn)行封裝的測(cè)試庫,如 Ruby 的 AWSpec,Go 的 Terratest 等。

比較來看,shell 優(yōu)點(diǎn)是原生,直接調(diào)用服務(wù)方提供的 CLI,如 AWS CLI, Kubectl;缺點(diǎn)是面對(duì)復(fù)雜場(chǎng)景編寫起來費(fèi)心費(fèi)力;

使用封裝起來的測(cè)試庫看起來很簡(jiǎn)單,但開發(fā)者日常就要使用 CLI/Curl 命令來進(jìn)行基礎(chǔ)驗(yàn)證,而用封裝庫進(jìn)行開發(fā)就需要多學(xué)習(xí)一套知識(shí);而且在被測(cè)服務(wù)發(fā)布新功能后,平臺(tái)想跟進(jìn)卻發(fā)現(xiàn)測(cè)試庫沒能跟進(jìn),導(dǎo)致最后還得用原生方式來寫。比如 AWSpec 支持 RDS,但是很長時(shí)間都沒有支持 Aurora。如果已經(jīng)寫了很多測(cè)試,就只能在 Aurora 這里使用其它方式驗(yàn)證,最后導(dǎo)致各處驗(yàn)證方式不統(tǒng)一。

所以我推薦選擇團(tuán)隊(duì)熟悉的應(yīng)用開發(fā)語言的測(cè)試框架,優(yōu)點(diǎn)如下:

  • 可以直接通過系統(tǒng)命令調(diào)用 CLI,開發(fā)者平常工作怎么驗(yàn)證,測(cè)試代碼就怎么寫,拷貝過來能用。
  • 相較 shell 來說,良好的測(cè)試框架支持。比如在多級(jí) JSON 中驗(yàn)證部分內(nèi)容,jq 驗(yàn)證起來就很麻煩。
  • 各種驗(yàn)證場(chǎng)景統(tǒng)一實(shí)現(xiàn),不用學(xué)習(xí)多框架或多語言。比如 Terratest 只適合驗(yàn)證 infra,如果需要想做冒煙測(cè)試,還要另起爐灶。
  • 如果確實(shí)有必要集成測(cè)試庫,也可以按需集成。

我的選擇則是 Ruby/RSpec,因?yàn)?Ruby 簡(jiǎn)潔自然的語法和 RSpec 的強(qiáng)大驗(yàn)證器,讓測(cè)試代碼中很少出現(xiàn)語言自身導(dǎo)致的難懂和多余的代碼。

如何測(cè)

組件測(cè)試加上人工驗(yàn)證是交付環(huán)境能夠成功部署的主要信心來源,而在有邏輯分支的時(shí)候,單元測(cè)試可以用來成為對(duì)組件測(cè)試的補(bǔ)充:組件測(cè)試驗(yàn)證代碼的主干,單元測(cè)試在部署前來驗(yàn)證分支,以實(shí)現(xiàn)對(duì)代碼的測(cè)試全覆蓋。

下面我們基于 Terraform 實(shí)現(xiàn),以單元測(cè)試和組件測(cè)試為例進(jìn)行測(cè)試。其它 IaC 實(shí)現(xiàn)和不依賴外部工具的測(cè)試都可以參考來實(shí)現(xiàn)。

注意這些由代碼變化產(chǎn)生的測(cè)試都應(yīng)在 Pipeline 的流水線中,而不是手動(dòng)觸發(fā)。任何不攔截在上線必經(jīng)之路的測(cè)試,最終都將無人理睬。

部署前

(1) 單元測(cè)試

在 Terraform 中,通常需要人工來驗(yàn)證 terraform plan 的結(jié)果,但是它只能覆蓋當(dāng)前 state 和配置參數(shù)下的結(jié)果。當(dāng)我們代碼中包含邏輯時(shí),我們就需要通過配置 local backend、不同配置和 state 文件來本地驗(yàn)證對(duì)應(yīng)的 plan 結(jié)果。示例:

圖片

(2) 檢查 plan 結(jié)果

在部署流水線中,通過 terraform plan 加人工驗(yàn)證。在測(cè)試環(huán)境中 apply 后,人工測(cè)試來保證正確性。驗(yàn)證完成后,對(duì)于后續(xù)環(huán)境來說在測(cè)試環(huán)境的 plan 結(jié)果就是其它環(huán)境的參考輸入,由人工核對(duì)確認(rèn)后進(jìn)行 apply。

部署后

在資源生成后,我們便可以通過測(cè)試腳本調(diào)用 CLI/API 請(qǐng)求目標(biāo)資源,來驗(yàn)證產(chǎn)生的結(jié)果與預(yù)期一致。比如服務(wù)可以被成功訪問、數(shù)據(jù)庫確實(shí)被創(chuàng)建出來并配有正確的參數(shù),密鑰管理器中被保存下來的數(shù)據(jù)庫密鑰我們可以成功連接到數(shù)據(jù)庫等等。與應(yīng)用測(cè)試一樣,任何一條失敗的測(cè)試都應(yīng)讓我們的 Pipeline 變紅,向團(tuán)隊(duì)告警。并確保只有在前一個(gè)環(huán)境被驗(yàn)證通過后,我們才向下一個(gè)環(huán)境前進(jìn)。

一個(gè)測(cè)試的范例

我們以 Ruby/RSpec 為例。在一個(gè)代碼庫中,以生成的目標(biāo)資源上下文劃分測(cè)試文件。

比如對(duì)于 RDS 數(shù)據(jù)庫的創(chuàng)建,我們可以組織這三個(gè)文件:

  • rds_spec.rb: 用來驗(yàn)證 AWS RDS 生成的資源,如 cluster、db parameter。
  • db_spec.rb: 用來驗(yàn)證在 DB 中進(jìn)行的設(shè)置,比如支持動(dòng)態(tài)數(shù)據(jù)庫憑證所在 DB 中創(chuàng)建的資源,DB 的 extension 被正確啟用。
  • vault_spec.rb:用來驗(yàn)證 Vault 中創(chuàng)建的資源、比如 master 憑證的存儲(chǔ)、支持動(dòng)態(tài)數(shù)據(jù)庫憑證所需的資源。

一個(gè)文件中的組織結(jié)構(gòu)如下:

圖片

下面是一個(gè)驗(yàn)證 RDS 的 DB parameter 按預(yù)期被創(chuàng)建的例子:

圖片

可以看出測(cè)試代碼非常的語義化,沒有額外的數(shù)據(jù)結(jié)構(gòu)定義和難懂的語法??疵靼琢诉@個(gè)測(cè)試,其它命令行相關(guān)的測(cè)試也就全都會(huì)寫了。平臺(tái)開發(fā)者們可以專注于業(yè)務(wù)驗(yàn)證,而不會(huì)因?yàn)闇y(cè)試框架帶來額外的負(fù)擔(dān)。

IaC 可以測(cè)試驅(qū)動(dòng)開發(fā)嗎?

當(dāng)然,只需要我們能在編寫功能代碼之前被測(cè)內(nèi)容是什么。我們可以通過各種文檔來識(shí)別出被測(cè)內(nèi)容,比如 Kubectl、AWS、Vault 等 CLI,或各種服務(wù)的 API。如果我們無法識(shí)別出被測(cè)內(nèi)容時(shí),那就需要通過拆解步驟、手動(dòng)部署資源等方式分析出來。像在其它語言進(jìn)行測(cè)試驅(qū)動(dòng)開發(fā)時(shí)一樣,小步驗(yàn)證,紅綠重構(gòu)。

進(jìn)行測(cè)試驅(qū)動(dòng)在其它語言中帶來的優(yōu)點(diǎn),在 IaC 也一樣大部分適用:

  • 促進(jìn)模塊化設(shè)計(jì)和提交
  • 簡(jiǎn)化調(diào)試過程
  • 更快地反饋循環(huán)
  • 更好地設(shè)計(jì)決策
  • 易于重構(gòu)
  • 減少過度工程
  • 保障測(cè)試覆蓋率:這點(diǎn)需要單獨(dú)提一下,目前還沒有什么好的方案可以檢查 IaC 代碼的測(cè)試覆蓋率,所以在測(cè)試驅(qū)動(dòng)中「只實(shí)現(xiàn)剛好可以通過測(cè)試的代碼」對(duì)保障覆蓋率很重要。

總結(jié)

自動(dòng)化測(cè)試是高代碼質(zhì)量和穩(wěn)定開發(fā)效率的重要保障,應(yīng)用服務(wù)開發(fā)如是,基礎(chǔ)設(shè)施因?yàn)閾?dān)負(fù)著更大的使命和責(zé)任更是如此。測(cè)試驅(qū)動(dòng)能幫助開發(fā)者更好的設(shè)計(jì)和實(shí)現(xiàn)。在 IaC 開發(fā)過程也同樣適用。在工具選型上,避免選擇編寫成本過高和太復(fù)雜的語言和工具,大部分 Ops 們更習(xí)慣編寫動(dòng)態(tài)語言的腳本,方便和順手更重要。

希望本文能對(duì)你的工程實(shí)踐帶來啟發(fā),從下一個(gè) IaC feature 開始測(cè)試驅(qū)動(dòng)開發(fā)。

責(zé)任編輯:趙寧寧 來源: Thoughtworks洞見
相關(guān)推薦

2018-12-05 09:00:46

DevOps持續(xù)交付持續(xù)集成

2022-02-10 11:54:34

即時(shí)基礎(chǔ)設(shè)施基礎(chǔ)設(shè)施數(shù)字化轉(zhuǎn)型

2023-05-09 12:02:59

智慧城市智慧交通物聯(lián)網(wǎng)

2023-04-11 15:26:44

數(shù)據(jù)中心服務(wù)器

2009-12-18 17:14:25

惠普基礎(chǔ)架構(gòu)

2009-12-22 13:59:59

惠普基礎(chǔ)設(shè)施運(yùn)營

2023-02-02 11:21:45

物聯(lián)網(wǎng)數(shù)字孿生智慧城市

2022-09-15 11:10:17

物聯(lián)網(wǎng)能源

2017-09-16 17:28:55

基礎(chǔ)設(shè)施代碼持續(xù)交付

2020-04-09 10:57:12

超融合基礎(chǔ)設(shè)施服務(wù)器超融合

2023-08-04 16:32:18

2023-06-16 15:53:55

DevOps基礎(chǔ)設(shè)施

2019-11-05 13:57:38

云計(jì)算混合云IT

2020-02-24 11:08:27

云計(jì)算網(wǎng)絡(luò)攻擊數(shù)據(jù)

2021-05-08 13:13:55

智能設(shè)施漏洞攻擊

2023-05-04 16:27:35

數(shù)據(jù)中心

2020-04-28 10:21:58

基礎(chǔ)設(shè)施硬件遠(yuǎn)程工作

2025-08-12 04:00:00

2017-06-09 15:25:23

IT設(shè)施數(shù)據(jù)中心融合

2015-12-07 09:39:53

光纖數(shù)據(jù)中心
點(diǎn)贊
收藏

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

久久久久久亚洲精品| 欧美精品日韩综合在线| 欧美连裤袜在线视频| 五月婷婷激情视频| 日韩精品第一区| 91精品欧美久久久久久动漫 | 国产乱了高清露脸对白| 日本精品另类| 一区二区三区色| 欧美日韩精品一区| 国产偷人妻精品一区二区在线| 亚洲福利国产| 中文字幕亚洲无线码a| 日韩精品――色哟哟| 厕沟全景美女厕沟精品| 亚洲欧美色综合| 欧美亚洲免费高清在线观看 | 久久国产精品露脸对白| 欧美激情区在线播放| 天堂久久精品忘忧草| 亚洲视频精选| 欧美日韩免费视频| 欧美一区二区三区爽大粗免费| 日本在线观看www| 91免费在线播放| 91丨九色丨国产| 一级黄色小视频| 午夜在线视频观看日韩17c| 久久九九亚洲综合| 69视频在线观看免费| 豆花视频一区二区| 欧美一区二区三区思思人| 欧美自拍小视频| av综合电影网站| 亚洲成人免费在线观看| 中文字幕人成一区| 不卡在线视频| 久久久99精品免费观看| 国产日韩欧美一区二区| 成人h动漫精品一区二区无码| 乱一区二区av| 国产精品电影观看| www.国产一区二区| 午夜亚洲视频| 日韩av毛片网| 黄瓜视频在线免费观看| 中文在线一区| 91av网站在线播放| 日韩av片在线播放| 一区在线观看| 高清欧美性猛交| 激情综合网五月婷婷| 婷婷亚洲最大| 久久久精品国产亚洲| 国产三级黄色片| 日韩精品一区二区三区免费观影| 亚洲欧洲国产一区| 一区二区三区四区免费| 农村少妇一区二区三区四区五区| 精品国产免费久久| 丰满岳乱妇一区二区| 这里视频有精品| 精品国产乱码久久| yy1111111| 亚洲伊人春色| 国产亚洲精品日韩| 午夜黄色福利视频| 久久久久久久久99精品大| 精品国产一区二区在线| 搜索黄色一级片| 欧美精品一线| 97在线日本国产| av片免费观看| 精品一区二区免费在线观看| 91久久久在线| 蜜桃视频污在线观看| 99精品黄色片免费大全| 欧美日韩精品久久| 性开放的欧美大片| 一区二区三区欧美在线观看| 黄页网站大全在线观看| 欧美18—19sex性hd| 欧美精品在线视频| 国产精品熟妇一区二区三区四区 | 噜噜噜噜噜久久久久久91| 黄色av网站在线免费观看| 国产精品久久精品日日| 996这里只有精品| 韩国久久久久久| 欧美二区在线观看| 青青草视频网站| 日韩精品免费| 国外成人性视频| 在线观看黄色国产| 国产999精品久久久久久 | 91欧美一区二区| 欧美激情视频给我| wwwwww国产| 久久99精品一区二区三区三区| 成人黄色av网站| 天天干天天做天天操| 欧美国产一区视频在线观看| 少妇久久久久久被弄到高潮| 成人国产二区| 欧美一级在线视频| 一区二区黄色片| 欧美+日本+国产+在线a∨观看| 91国产中文字幕| 国产剧情精品在线| 91免费观看国产| 无码毛片aaa在线| 欧美xxx性| 亚洲国产精品成人精品| 99久久精品久久亚洲精品| 亚洲视频www| 99国产高清| √天堂资源地址在线官网| 午夜久久久久久久久| 午夜啪啪小视频| 国模精品一区| 91极品女神在线| www久久久com| 中文字幕亚洲区| 少妇高潮喷水久久久久久久久久| 美女久久精品| 日韩在线观看免费网站| 亚洲 欧美 成人| 不卡电影一区二区三区| 男女裸体影院高潮| www一区二区三区| 中文字幕亚洲欧美在线| av一级在线观看| 2023国产精品自拍| a级黄色一级片| 91精品入口| 欧美大片在线看| 国产精品久久久久久久免费| 日本一区二区不卡视频| 国产天堂在线播放| 香蕉精品久久| 欧美一区在线直播| 亚洲av成人精品毛片| 亚洲不卡在线观看| 在线观看免费视频国产| 欧美日韩精选| 国产98在线|日韩| 黄色羞羞视频在线观看| 欧美一区日本一区韩国一区| 波多野结衣久久久久| 日一区二区三区| 日韩免费电影一区二区| 神马久久午夜| 亚洲男人av在线| 国产精品乱码一区二区视频| 26uuu精品一区二区三区四区在线| 欧美精品一区免费| 午夜先锋成人动漫在线| 欧美最猛性xxxxx亚洲精品| 天堂а√在线8种子蜜桃视频 | 国产一区二区免费| 在线观看日本网站| 亚洲国产精品激情在线观看| 一道本视频在线观看| 日韩电影在线视频| 亚洲一区精品电影| 黄视频在线免费看| 亚洲欧美一区二区激情| av首页在线观看| 一色屋精品亚洲香蕉网站| 波多野结衣中文字幕在线播放| 韩国在线一区| 欧美日韩国产三区| 亚洲人成网站在线在线观看| 精品中文字幕视频| 亚洲av成人无码久久精品老人| 在线一区二区三区四区五区| 国产日韩精品中文字无码| 国产伦精品一区二区三区免费迷 | 免费成人在线观看| 国产盗摄视频在线观看| 91成人入口| 国产精品com| 18加网站在线| 日韩精品视频免费在线观看| 亚洲性猛交富婆| 亚洲一区在线免费观看| 熟女少妇一区二区三区| 麻豆视频观看网址久久| 国产天堂视频在线观看| 国产欧美日韩精品一区二区免费| 91色视频在线观看| 一区二区精品伦理...| 视频一区视频二区国产精品| 亚洲精品久久久久久动漫器材一区| 色婷婷亚洲综合| 麻豆成人在线视频| 久久精品一区蜜桃臀影院| 欧美激情第四页| 天堂久久久久va久久久久| 一区二区三区一级片| 国产va免费精品观看精品视频| 91久久精品久久国产性色也91| 中文在线免费视频| 色综合久综合久久综合久鬼88| 国模吧精品人体gogo| 精品99一区二区| 91福利在线观看视频| 精品久久久一区| 欧美日韩免费一区二区| 中文字幕乱码久久午夜不卡| 亚洲国产精品自拍视频| 国产又黄又大久久| 国产精品乱码久久久久| 亚洲国产一区二区三区a毛片| 一区二区三区|亚洲午夜| 天天做夜夜做人人爱精品| 亚洲xxxxx| 免费视频观看成人| 日本精品免费一区二区三区| 国语对白在线刺激| 久久久国产一区二区| 成人免费在线电影| 国产视频欧美视频| 女人18毛片水真多18精品| 制服丝袜亚洲色图| 中文字幕人成人乱码亚洲电影| 欧美日韩国产一区中文午夜| 免费中文字幕视频| 国产精品高潮呻吟| 中文字幕有码在线播放| 99v久久综合狠狠综合久久| 国产精品亚洲一区二区无码| 国产一区二区三区国产| 成人亚洲免费视频| 久久黄色级2电影| 精品日韩久久久| 蜜桃视频免费观看一区| 免费日韩中文字幕| 丝袜诱惑亚洲看片| 国产精品亚洲a| 欧美亚洲自偷自偷| 91猫先生在线| 久久国产精品99国产| 国产黄页在线观看| 国产一区二区三区成人欧美日韩在线观看| 亚洲一区二区三区av无码| 欧美三级特黄| 蜜桃传媒一区二区三区| 国产精品久久久一区二区| av黄色在线网站| 天堂成人免费av电影一区| 免费黄色特级片| 蜜桃视频在线观看一区| 日本一二区免费| 国内精品第一页| 四虎成人免费视频| 成人动漫在线一区| 疯狂揉花蒂控制高潮h| 久久亚洲精品国产精品紫薇| 蜜桃传媒一区二区亚洲av | 老司机精品福利在线观看| 久操国产精品| 亚洲精品一区二区三| 偷拍欧美精品| 国产精品视频二| 99在线|亚洲一区二区| 日韩少妇内射免费播放18禁裸乳| 欧美亚洲专区| av中文字幕网址| 国产jizzjizz一区二区| 小毛片在线观看| 国产欧美一区二区精品久导航| 国产精品20p| 亚洲天堂久久久久久久| 麻豆亚洲av熟女国产一区二| 岛国av一区二区在线在线观看| 亚洲中文字幕无码爆乳av| 欧美猛男男办公室激情| 亚洲毛片在线播放| 国产视频精品久久久| 91亚洲欧美| 久久久亚洲国产天美传媒修理工| 伊人久久av| 国产一区二区丝袜| 盗摄系列偷拍视频精品tp| 欧美日韩一区二区三区免费| 国产韩日影视精品| av在线观看地址| 蜜桃一区二区三区四区| 超碰caoprom| 国产精品家庭影院| 国产午夜小视频| 欧美日韩国产综合草草| 亚洲国产精品久久久久久6q| 亚洲欧美中文字幕在线一区| 肉体视频在线| 国产精品福利网站| 亚洲国产中文在线| 日韩精品一区二区三区四区五区| 正在播放日韩欧美一页| 免费无码av片在线观看| 国产激情一区二区三区| av黄色在线免费观看| 亚洲永久免费av| 在线视频 91| 日韩精品免费综合视频在线播放| 高潮毛片在线观看| 国产成人精品一区二区三区| youjizzjizz亚洲| 国产日本欧美在线| 日韩黄色免费电影| 中文字幕乱码在线| 一区二区三区四区视频精品免费| 午夜一级黄色片| 日韩电影免费观看在线观看| 成人高清免费在线| 国产精品普通话| 在线视频亚洲专区| 免费看毛片的网址| 国产麻豆精品久久一二三| 99久久99久久精品免费| 欧美性猛交xxxx免费看| 国产91免费在线观看| 久久亚洲精品一区二区| 成人精品国产| 日韩一区不卡| 久久婷婷亚洲| 国产精品九九九九九| 亚洲成a人v欧美综合天堂| 国产黄色高清视频| 久久久精品久久| 国产一区二区三区精品在线观看| 午夜精品一区二区在线观看| 久久激情一区| 免费在线观看你懂的| 狠狠做深爱婷婷久久综合一区 | 久久先锋影音av鲁色资源网| 日本熟妇毛茸茸丰满| 精品国产一二三| aa国产成人| 精品毛片久久久久久| 日韩一级在线| 国产艳俗歌舞表演hd| 欧美日韩国产页| 毛片免费在线| 国产精品成人免费电影| 精品国产一区探花在线观看| www日韩在线观看| 欧美韩国日本不卡| 一卡二卡三卡在线| 久久这里只有精品视频首页| 国产日韩欧美中文在线| 蜜臀av性久久久久蜜臀av| 国产成人综合亚洲网站| 久久久久99精品成人片毛片| 精品国产一区二区国模嫣然| 女人高潮被爽到呻吟在线观看| 久久99影院| 日韩av中文在线观看| 手机毛片在线观看| 777xxx欧美| 丰乳肥臀在线| 欧美人xxxxx| 蜜臀久久99精品久久久久宅男| 国精产品久拍自产在线网站| 欧美一级淫片007| 91豆花视频在线播放| 精品日本一区二区三区在线观看| 可以免费看不卡的av网站| 青青草自拍偷拍| 日韩欧美精品在线视频| 久久青草伊人| 日韩久久不卡| 国产大陆a不卡| 成年人视频在线免费看| 中文字幕av日韩| 久久精品一级| 久久国产亚洲精品无码| 欧美经典三级视频一区二区三区| 91久久精品国产91性色69| 欧美富婆性猛交| 欧美人与拘性视交免费看| 三区视频在线观看| 亚洲国产裸拍裸体视频在线观看乱了| 日韩精品123| 成人性生交大片免费看小说 | 韩国三级日本三级少妇99| 外国成人在线视频| 欧洲美女亚洲激情| 午夜精品久久久久久久99樱桃| 国产福利电影在线| 国产精品国产精品| 日韩电影在线免费| 久久精品国产亚洲AV无码麻豆| 一区二区中文字幕| 高清精品xnxxcom| 97超碰成人在线| 欧美视频免费在线| 尤物视频在线看| 亚洲v国产v在线观看|