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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

Jenkins的Pipeline脚本在美团餐饮SaaS中的实践

發布時間:2023/12/9 编程问答 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Jenkins的Pipeline脚本在美团餐饮SaaS中的实践 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

2019獨角獸企業重金招聘Python工程師標準>>>

一、背景

在日常開發中,我們經常會有發布需求,而且還會遇到各種環境,比如:線上環境(Online),模擬環境(Staging),開發環境(Dev)等。最簡單的就是手動構建、上傳服務器,但這種方式太過于繁瑣,使用持續集成可以完美地解決這個問題,推薦了解一下Jenkins。 Jenkins構建也有很多種方式,現在使用比較多的是自由風格的軟件項目(Jenkins構建的一種方式,會結合SCM和構建系統來構建你的項目,甚至可以構建軟件以外的系統)的方式。針對單個項目的簡單構建,這種方式已經足夠了,但是針對多個類似且又存在差異的項目,就難以滿足要求,否則就需要大量的job來支持,這就存在,一個小的變動,就需要修改很多個job的情況,難以維護。我們團隊之前就存在這樣的問題。

目前,我們團隊主要負責開發和維護多個Android項目,而且每個項目都需要構建,每個構建流程非常類似但又存在一定的差異。比如構建的流程大概如下:

  • 克隆代碼;
  • 靜態代碼檢查(可選);
  • 單元測試(可選);
  • 編譯打包APK或者熱補丁;
  • APK分析,獲取版本號(VersionCode),包的Hash值(apkhash)等;
  • 加固;
  • 上傳測試分發平臺;
  • 存檔(可選);
  • 觸發自動化測試(可選);
  • 通知負責人構建結果等。

整個流程大體上是相同的,但是又存在一些差異。比如有的構建可以沒有單元測試,有的構建不用觸發自動化測試,而且構建結果通知的負責人也不同。如果使用自由風格軟件項目的普通構建,每個項目都要建立一個job來處理流程(可能會調用其他job)。

這種處理方式原本也是可以的,但是必須考慮到,可能會有新的流程接入(比如二次簽名),構建流程也可能存在Bug等多種問題。無論哪種情況,一旦修改主構建流程,每個項目的job都需要修改和測試,就必然會浪費大量的時間。針對這種情況,我們使用了Pipeline的構建方式來解決。

當然,如果有項目集成了React Native,還需要構建JsBundle。在Native修改以后,JsBundle不一定會有更新,如果是構建Native的時候一起構建JsBundle,就會造成很多資源浪費。并且直接把JsBundle這類大文件放在Native的Git倉庫里,也不是特別合適。

本文是分享一種Pipeline的使用經驗,來解決這類問題。

二、Pipeline的介紹

Pipeline也就是構建流水線,對于程序員來說,最好的解釋是:使用代碼來控制項目的構建、測試、部署等。使用它的好處有很多,包括但不限于:

  • 使用Pipeline可以非常靈活的控制整個構建過程;
  • 可以清楚的知道每個構建階段使用的時間,方便構建的優化;
  • 構建出錯,使用stageView可以快速定位出錯的階段;
  • 一個job可以搞定整個構建,方便管理和維護等。

Stage View

三、使用Pipeline構建

新建一個Pipeline項目,寫入Pipeline的構建腳本,就像下面這樣: 對于單個項目來說,使用這樣的Pipeline來構建能夠滿足絕大部分需求,但是這樣做也有很多缺陷,包括:

  • 多個項目的Pipeline打包腳本不能公用,導致一個項目寫一份腳本,維護比較麻煩。一個變動,需要修改多個job的腳本;
  • 多個人維護構建job的時候,可能會覆蓋彼此的代碼;
  • 修改腳本失敗以后,無法回滾到上個版本;
  • 無法進行構建腳本的版本管理,老版本發修復版本需要構建,可能和現在用的job版本已經不一樣了,等等。

四、把Pipeline當代碼寫

既然存在缺陷,我們就要找更好的方式,其實Jenkins提供了一個更優雅的管理Pipeline腳本的方式,在配置項目Pipeline的時候,選擇Pipeline script from SCM,就像下面這樣: 這樣,Jenkins在啟動job的時候,首先會去倉庫里面拉取腳本,然后再運行這個腳本。在腳本里面,我們規定的構建方式和流程,就會按部就班地執行。構建的腳本,可以實現多人維護,還可以Review,避免出錯。 以上就算搭建好了一個基礎,而針對多個項目時,還有一些事情要做,不可能完全一樣,以下是構建的結構圖:

如此以來,我們的構建數據來源分為三部分:job UI界面、倉庫的通用Pipeline腳本、項目下的特殊配置,我們分別來看一下:

job UI界面(參數化構建)

在配置job的時候,選擇參數化構建過程,傳入項目倉庫地址、分支、構建通知人等等。還可以增加更多的參數 ,這些參數的特點是,可能需要經常修改,比如靈活選擇構建的代碼分支。

項目配置

在項目工程里面,放入針對這個項目的配置,一般是一個項目固定,不經常修改的參數,比如項目名字,如下圖:

注入構建信息

QA提一個Bug,我們需要確定,這是哪次的構建,或者要知道commitId,從而方便進行定位。因此在構建時,可以把構建信息注入到APK之中。

  • 把屬性注入到gradle.properties
  • # 應用的后端環境 APP_ENV=Beta # CI 打包的編號,方便確定測試的版本,不通過 CI 打包,默認是 0 CI_BUILD_NUMBER=0 # CI 打包的時間,方便確定測試的版本,不通過 CI 打包,默認是 0 CI_BUILD_TIMESTAMP=0
  • 在build.gradle里設置buildConfigField
  • #使用的是gradle.properties里面注入的值 buildConfigField "String", "APP_ENV", "\"${APP_ENV}\"" buildConfigField "String", "CI_BUILD_NUMBER", "\"${CI_BUILD_NUMBER}\"" buildConfigField "String", "CI_BUILD_TIMESTAMP", "\"${CI_BUILD_TIMESTAMP}\"" buildConfigField "String", "GIT_COMMIT_ID", "\"${getCommitId()}\""//獲取當前Git commitId String getCommitId() {try {def commitId = 'git rev-parse HEAD'.execute().text.trim()return commitId;} catch (Exception e) {e.printStackTrace();} }
  • 顯示構建信息 在App里,找個合適的位置,比如開發者選項里面,把剛才的信息顯示出來。QA提Bug時,要求他們把這個信息一起帶上
  • mCIIdtv.setText(String.format("CI 構建號:%s", BuildConfig.CI_BUILD_NUMBER)); mCITimetv.setText(String.format("CI 構建時間:%s", BuildConfig.CI_BUILD_TIMESTAMP)); mCommitIdtv.setText(String.format("Git CommitId:%s", BuildConfig.GIT_COMMIT_ID));

    倉庫的通用Pipeline腳本

    通用腳本是抽象出來的構建過程,遇到和項目有關的都需要定義成變量,再從變量里進行讀取,不要在通用腳本里寫死。

    node {try{stage('檢出代碼'){//從git倉庫中檢出代碼git branch: "${BRANCH}",credentialsId: 'xxxxx-xxxx-xxxx-xxxx-xxxxxxx', url: "${REPO_URL}"loadProjectConfig();}stage('編譯'){//這里是構建,你可以調用job入參或者項目配置的參數,比如:echo "項目名字 ${APP_CHINESE_NAME}"//可以判斷if (Boolean.valueOf("${IS_USE_CODE_CHECK}")) {echo "需要靜態代碼檢查"} else {echo "不需要靜態代碼檢查"}}stage('存檔'){//這個演示的Android的項目,實際使用中,請根據自己的產物確定def apk = getShEchoResult ("find ./lineup/build/outputs/apk -name '*.apk'")def artifactsDir="artifacts"//存放產物的文件夾sh "mkdir ${artifactsDir}"sh "mv ${apk} ${artifactsDir}"archiveArtifacts "${artifactsDir}/*"}stage('通知負責人'){emailext body: "構建項目:${BUILD_URL}\r\n構建完成", subject: '構建結果通知【成功】', to: "${EMAIL}"}} catch (e) {emailext body: "構建項目:${BUILD_URL}\r\n構建失敗,\r\n錯誤消息:${e.toString()}", subject: '構建結果通知【失敗】', to: "${EMAIL}"} finally{// 清空工作空間cleanWs notFailBuild: true}}// 獲取 shell 命令輸出內容 def getShEchoResult(cmd) {def getShEchoResultCmd = "ECHO_RESULT=`${cmd}`\necho \${ECHO_RESULT}"return sh (script: getShEchoResultCmd,returnStdout: true).trim() }//加載項目里面的配置文件 def loadProjectConfig(){def jenkinsConfigFile="./jenkins.groovy"if (fileExists("${jenkinsConfigFile}")) {load "${jenkinsConfigFile}"echo "找到打包參數文件${jenkinsConfigFile},加載成功"} else {echo "${jenkinsConfigFile}不存在,請在項目${jenkinsConfigFile}里面配置打包參數"sh "exit 1"} }

    輕輕的點兩下Build with Parameters -> 開始構建,然后等幾分鐘的時間,就能夠收到郵件。

    五、其他構建結構

    以上,僅僅是針對我們當前遇到問題的一種不錯的解決方案,可能并不完全適用于所有場景,但是可以根據上面的結構進行調整,比如:

    • 根據stage拆分出不同的Pipeline腳本,這樣方便CI的維護,一個或者幾個人維護構建中的一個stage;
    • 把構建過程中的stage做成普通的自由風格的軟件項目的job,把它們作為基礎服務,在Pipeline中調用這些基礎服務等。

    六、當遇上React Native

    當項目引入了React Native以后,因為技術棧的原因,React Native的頁面是由前端團隊開發,但容器和原生組件是Android團隊維護,構建流程也發生了一些變化。

    方案對比

    方案說明缺點優點
    手動拷貝等JsBundle構建好了,再手動把構建完成的產物,拷貝到Native工程里面1. 每次手動操作,比較麻煩,效率低,容易出錯<br />2. 涉及到跨端合作,每次要去前端團隊主動拿JsBundle<br />3. Git不適合管理大文件和二進制文件簡單粗暴
    使用submodule保存構建好的JsBundle直接把JsBundle放在Native倉庫的一個submodule里面,由前端團隊主動更新,每次更新Native的時候,直接就拿到了最新的JsBundle1. 簡單無開發成本<br />2. 不方便單獨控制JsBundle的版本<br />3. Git不適合管理大文件和二進制文件前端團隊可以主動更新JsBundle
    使用submodule管理JsBundle的源碼直接把JsBundle的源碼放在Native倉庫的一個submodule里面,由前端團隊開發更新,每次構建Native的時候,先構構建JsBundle1. 不方便單獨控制JsBundle的版本<br />2. 即使JsBundle無更新,也需要構建,構建速度慢,浪費資源方便靈活
    分開構建,產物存檔JsBundle和Native分開構建,構建完了的JsBundle分版本存檔,Native構建的時候,直接去下載構建好了的JsBundle版本1. 通過配置管理JsBundle,解放Git<br />2. 方便Jenkins構建的時候,動態配置需要的JsBundle版本1. 需要花費時間建立流程<br />2. 需要開發Gradle的JsBundle下載插件

    前端團隊開發頁面,構建后生成JsBundle,Android團隊拿到前端構建的JsBundle,一起打包生成最終的產物。 在我們開發過程中,JsBundle修改以后,不一定需要修改Native,Native構建的時候,也不一定每次都需要重新構建JsBundle。并且這兩個部分由兩個團隊負責,各自獨立發版,構建的時候也應該獨立構建,不應該融合到一起。

    綜合對比,我們選擇了使用分開構建的方式來實現。

    分開構建

    因為需要分開發布版本,所以JsBundle的構建和Native的構建要分開,使用兩個不同的job來完成,這樣也方便兩個團隊自行操作,避免相互影響。 JsBundle的構建,也可以參考上文提到的Pipeline的構建方式來做,這里不再贅述。 在獨立構建以后,怎么才能組合到一起呢?我們是這樣思考的:JsBundle構建以后,分版本的儲存在一個地方,供Native在構建時下載需要版本的JsBundle,大致的流程如下:

    這個流程有兩個核心,一個是構建的JsBundle歸檔存儲,一個是在Native構建時去下載。

    JsBundle歸檔存儲

    方案缺點優點
    直接存檔在Jenkins上面1. JsBundle不能匯總瀏覽<br>2. Jenkins很多人可能要下載,命名帶有版本號,時間,分支等,命名不統一,不方便構建下載地址<br>3. 下載Jenkins上面的產物需要登陸授權,比較麻煩1. 實現簡單,一句代碼就搞定,成本低
    自己構建一個存儲服務1. 工程大,開發成本高<br>2. 維護起來麻煩可擴展,靈活性高
    MSS<br>(美團存儲服務)1. 儲存空間大<br>2. 可靠性高,配合CDN下載速度快<br>3. 維護成本低, 價格便宜

    這里我們選擇了MSS。 上傳文件到MSS,可以使用s3cmd,但畢竟不是每個Slave上面都有安裝,通用性不強。為了保證穩定可靠,這里基于MSS的SDK寫個小工具即可,比較簡單,幾行代碼就可以搞定。

    private static String TenantId = "mss_TenantId=="; private static AmazonS3 s3Client;public static void main(String[] args) throws IOException {if (args == null || args.length != 3) {System.out.println("請依次輸入:inputFile、bucketName、objectName");return;}s3Client = AmazonS3ClientProvider.CreateAmazonS3Conn();uploadObject(args[0], args[1], args[2]); }public static void uploadObject(String inputFile, String bucketName, String objectName) {try {File file = new File(inputFile);if (!file.exists()) {System.out.println("文件不存在:" + file.getPath());return;}s3Client.putObject(new PutObjectRequest(bucketName, objectName, file));System.out.printf("上傳%s到MSS成功: %s/v1/%s/%s/%se", inputFile, AmazonS3ClientProvider.url, TenantId, bucketName, objectName);} catch (AmazonServiceException ase) {System.out.println("Caught an AmazonServiceException, which " +"means your request made it " +"to Amazon S3, but was rejected with an error response" +" for some reason.");System.out.println("Error Message: " + ase.getMessage());System.out.println("HTTP Status Code: " + ase.getStatusCode());System.out.println("AWS Error Code: " + ase.getErrorCode());System.out.println("Error Type: " + ase.getErrorType());System.out.println("Request ID: " + ase.getRequestId());} catch (AmazonClientException ace) {System.out.println("Caught an AmazonClientException, which " +"means the client encountered " +"an internal error while trying to " +"communicate with S3, " +"such as not being able to access the network.");System.out.println("Error Message: " + ace.getMessage());} }

    我們直接在Pipeline里構建完成后,調用這個工具就可以了。 當然,JsBundle也分類型,在調試的時候可能隨時需要更新,這些JsBundle不需要永久保存,一段時間后就可以刪除了。在刪除時,可以參考MSS生命周期管理。所以,我們在構建JsBundle的job里,添加一個參數來區分。

    //根據TYPE,上傳到不同的bucket里面 def bucket = "rn-bundle-prod" if ("${TYPE}" == "dev") {bucket = "rn-bundle-dev" //有生命周期管理,一段時間后自動刪除 } echo "開始JsBundle上傳到MSS" //jar地址需要替換成你自己的 sh "curl -s -S -L http://s3plus.sankuai.com/v1/mss_xxxxx==/rn-bundle-prod/rn.bundle.upload-0.0.1.jar -o upload.jar" sh "java -jar upload.jar ${archiveZip} ${bucket} ${PROJECT}/${targetZip}" echo "上傳JsBundle到MSS:${archiveZip}"

    Native構建時JsBundle的下載

    為了實現構建時能夠自動下載,我們寫了一個Gradle的插件。 首先要在build.gradle里面配置插件依賴:

    classpath 'com.zjiecode:rn-bundle-gradle-plugin:0.0.1'

    在需要的Module應用插件:

    apply plugin: 'mt-rn-bundle-download'

    在build.gradle里面配置JsBundle的信息:

    RNDownloadConfig {//遠程文件目錄,因為有多種類型,所以這里可以填多個。paths = ['http://msstest-corp.sankuai.com/v1/mss_xxxx==/rn-bundle-dev/xxx/','http://msstest-corp.sankuai.com/v1/mss_xxxx==/rn-bundle-prod/xxx/']version = "1"//版本號,這里使用的是打包JsBundle的BUILD_NUMBERfileName = 'xxxx.android.bundle-%s.zip' //遠程文件的文件名,%s會用上面的version來填充outFile = 'xxxx/src/main/assets/JsBundle/xxxx.android.bundle.zip' // 下載后的存儲路徑,相對于項目根目錄 }

    插件會在package的task前面,插入一個下載的task,task讀取上面的配置信息,在打包階段檢查是否已經存在這個版本的JsBundle。如果不存在,就會去歸檔的JsBundle里,下載我們需要的JsBundle。 當然,這里的version可以使用上文介紹的注入構建信息的方式,通過job參數的方式進行注入。這樣在Jenkins構建Native時,就可以動態地填寫需要JsBundle的版本了。 這個Gradle插件,我們已經放到到了github倉庫,你可以基于此修改,當然,也歡迎PR。 https://github.com/zjiecode/rn-bundle-gradle-plugin

    六、總結

    我們把一個構建分成了好幾個部分,帶來的好處如下:

    • 核心構建過程,只需要維護一份,減輕維護工作;
    • 方便多個人維護構建CI,避免Pipeline代碼被覆蓋;
    • 方便構建job的版本管理,比如要修復某個已經發布的版本,可以很方便切換到發布版本時候用的Pipeline腳本版本;
    • 每個項目,配置也比較靈活,如果項目配置不夠靈活,可以嘗試定義更多的變量;
    • 構建過程可視化,方便針對性優化和錯誤定位等。

    當然,Pipeline也存在一些弊端,比如:

    • 語法不夠友好,但好在Jenkins提供了一個比較強大的幫助工具(Pipeline Syntax);
    • 代碼測試繁瑣,沒有本地運行環境,每次測試都需要提交運行一個job,等等。

    當項目集成了React Native時,配合Pipeline,我們可以把JsBundle的構建產物上傳到MSS歸檔。在構建Native的時候 ,可以動態地下載。

    七、作者

    張杰,美團點評高級Android工程師,2017年加入餐飲平臺成都研發中心,主要負責餐飲平臺B端應用開發。 王浩,美團點評高級Android工程師,2017年加入餐飲平臺成都研發中心,主要負責餐飲平臺B端應用開發。

    八、招聘廣告

    本文作者來自美團成都研發中心(是的,我們在成都建研發中心啦)。我們在成都有眾多后端、前端和測試的崗位正在招人,歡迎大家投遞簡歷:songyanwei@meituan.com。

    轉載于:https://my.oschina.net/meituantech/blog/1922037

    總結

    以上是生活随笔為你收集整理的Jenkins的Pipeline脚本在美团餐饮SaaS中的实践的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    成年人免费在线观看 | 欧美另类交在线观看 | 成人免费影院 | 午夜精品久久久久久久久久久久 | 成人国产精品av | 成人黄色在线观看视频 | 91精品在线免费 | 免费在线观看av不卡 | 亚洲黄色av | 日韩激情小视频 | 五月婷婷六月丁香 | 久草免费手机视频 | 人人澡澡人人 | 欧美日韩中文字幕综合视频 | 免费av影视 | 欧美日韩国产精品一区 | 国产无遮挡猛进猛出免费软件 | 国产免费区 | 日本h视频在线观看 | 天天综合网天天 | 激情五月婷婷网 | 日韩午夜视频在线观看 | 婷婷五天天在线视频 | 欧美 日韩 视频 | 九色视频网址 | 国产小视频你懂的在线 | 久久综合九色综合97婷婷女人 | 伊人黄色网 | 日韩亚洲在线 | 国产视频一区在线播放 | 久久久久久综合 | 免费观看成人av | 亚洲天堂网在线视频观看 | 综合婷婷久久 | 国产精品中文在线 | 久久视频中文字幕 | 国产手机视频 | 一区二区三区免费看 | 黄色软件在线观看免费 | 五月天.com | 亚洲精区二区三区四区麻豆 | 午夜视频免费 | 成人av教育| 91在线porny国产在线看 | 久久这里有精品 | 国产97在线看 | 国产精品免费不卡 | 中文av网站 | 91九色porny蝌蚪视频 | 国产精品久久久久婷婷 | 欧美色图亚洲图片 | 精品女同一区二区三区在线观看 | 日本中文乱码卡一卡二新区 | 香蕉成人在线视频 | 黄色av一区二区 | 免费成人在线观看视频 | 日韩在线电影 | a在线视频v视频 | 欧美男男激情videos | 天天天干天天射天天天操 | 午夜视频一区二区 | 深爱婷婷激情 | 91人人爱| 亚洲无线视频 | 91亚·色 | 在线观看黄色国产 | 欧美国产日韩一区二区三区 | 99国产精品一区二区 | av综合 日韩 | 四虎影视av| 亚洲精品在线播放视频 | 五月婷婷综合激情网 | 四季av综合网站 | 夜夜操天天操 | 日韩高清一 | 久久在线看 | 国产精品自产拍在线观看网站 | 黄色三级av | 久久手机免费视频 | 一区二区三区中文字幕在线 | 香蕉网在线| 伊人www22综合色 | 久久久久久久久黄色 | 久久艹人人 | 日韩视频在线观看视频 | 日韩黄色在线电影 | 久久与婷婷| 国产精品福利av | 久久精品99精品国产香蕉 | 一区二区视频电影在线观看 | 精品一二三四在线 | 91中文在线观看 | 日韩色视频在线观看 | 色噜噜在线观看视频 | 国产精品va视频 | www.色就是色 | 国产日韩欧美在线观看 | 亚洲欧洲精品一区二区 | 9色在线视频 | 国产精品二区在线 | 亚洲国产视频网站 | 亚洲狠狠操 | 成人免费看片98欧美 | 国内精品久久久久久久久久清纯 | 91黄色在线视频 | 果冻av在线| 国产三级在线播放 | 99久久这里只有精品 | 国产男女免费完整视频 | 亚洲九九| 国产va精品免费观看 | 亚洲婷婷在线视频 | 97av色| 欧美天天综合网 | 97超碰人人爱 | 中文在线a∨在线 | 最新日韩在线观看 | 亚洲激情 在线 | 99国产一区二区三精品乱码 | 玖玖玖影院 | 精品福利片 | 99婷婷狠狠成为人免费视频 | 久久99热这里只有精品国产 | 国产精品久久久久久一区二区 | a√天堂资源 | 亚洲精品午夜一区人人爽 | 九九免费观看视频 | 久久久国产99久久国产一 | 日韩精品不卡 | 2020天天干夜夜爽 | v片在线看 | 一本一本久久a久久精品综合妖精 | 激情在线免费视频 | 91丝袜美腿 | 黄色片亚洲| 成人在线视频免费观看 | 成年人在线观看免费视频 | 天堂va欧美va亚洲va老司机 | 久久精品视频在线观看 | 日韩欧美有码在线 | 91午夜精品 | 国产日韩精品一区二区三区 | 最近乱久中文字幕 | 黄色免费电影网站 | 99在线精品观看 | 欧美精品一区二区在线播放 | 日韩精品久久中文字幕 | 日本超碰在线 | 91尤物在线播放 | 久草在线视频资源 | 91黄色小视频 | 亚洲天堂网站视频 | 成人久久影院 | 久草精品在线播放 | 免费精品国产 | 亚洲成人精品 | 国产一级大片免费看 | 九九久久视频 | 福利av在线 | 97超碰人人看 | 久草在线播放视频 | 91精品麻豆 | 日韩欧美高清一区二区三区 | 91麻豆精品国产91久久久久 | 麻豆高清免费国产一区 | 91在线精品秘密一区二区 | 日本mv大片欧洲mv大片 | 国内精品久久久久久久影视简单 | 中文不卡视频在线 | 国产精品久久久久久久久久免费看 | 在线观看中文字幕亚洲 | 激情 一区二区 | 国产精品自在线拍国产 | 日本一区二区免费在线观看 | 日本高清免费中文字幕 | 国产一级片久久 | 久久久午夜电影 | 99精品国产一区二区 | 久久高清免费视频 | 91色国产在线 | 日韩av男人的天堂 | 国产精品 日韩 | 亚洲女人av| 精品麻豆入口免费 | 中文字幕永久在线 | 91视频3p| 久久免费在线观看视频 | 中文字幕在线观看免费观看 | 九色精品免费永久在线 | 婷婷五月在线视频 | 一本一本久久a久久精品牛牛影视 | 免费一区在线 | 大型av综合网站 | 波多野结衣日韩 | 欧美做受高潮电影o | 欧美在线视频精品 | 综合激情网 | 国内精品美女在线观看 | 色偷偷888欧美精品久久久 | 日日干日日色 | 成人91在线 | 免费色视频网站 | 日本aaaa级毛片在线看 | 欧美另类xxxx| 日韩视频免费观看高清 | 91一区啪爱嗯打偷拍欧美 | 麻豆视频免费入口 | 日韩一区二区三区在线看 | 96久久久 | 美女一二三区 | 黄色小说18 | 97电影院网 | 亚洲三级av | 午夜精品在线看 | 天天射天天艹 | 2023av在线 | 国产99亚洲| 国产精品成人av久久 | 日韩av影视 | 国产精品麻豆三级一区视频 | 欧美一级乱黄 | 国产精品丝袜在线 | 免费在线观看污网站 | 美女久久久久久久久久久 | 在线观看一区二区精品 | 欧美巨大| 91视频电影 | av中文字幕剧情 | 亚洲综合视频在线 | 久久爽久久爽久久av东京爽 | 91视频麻豆视频 | 国产中文视 | 综合中文字幕 | 国产精品免费麻豆入口 | 国产精品6999成人免费视频 | 天天色天天操天天爽 | 亚洲国产字幕 | 久久免费一 | 91在线日本 | 91黄站| 久艹视频在线观看 | 91av官网| 欧美一级片在线免费观看 | 在线看污网站 | 日韩高清在线一区 | 亚洲dvd| 在线欧美小视频 | 夜夜夜影院 | 国产在线精品区 | 911香蕉 | 日韩欧美在线综合网 | 久久亚洲区 | 91亚洲精品久久久久图片蜜桃 | 日韩欧美视频 | 久久久久免费精品视频 | 在线观看成人网 | 久久全国免费视频 | 91久久久久久久一区二区 | 亚洲成人免费观看 | 99热官网 | 亚洲国产一区二区精品专区 | 亚洲观看黄色网 | 日韩伦理一区二区三区av在线 | 伊人电影在线观看 | 日韩美女黄色片 | av黄色免费网站 | 日本一区二区三区视频在线播放 | 欧美日韩国产一区二区在线观看 | 99视频在线看 | 久久你懂得 | 黄色国产成人 | 碰超在线 | 精品uu | 91精品免费视频 | 麻豆av一区二区三区在线观看 | 91久久爱热色涩涩 | 91pony九色丨交换 | 婷婷久久五月 | 91视频高清完整版 | 日韩专区 在线 | 日韩爱爱网站 | 亚洲欧美国产视频 | 不卡av在线免费观看 | 国产精品久久99综合免费观看尤物 | 久久久久久免费网 | 久久人人97超碰精品888 | 日韩高清在线一区二区三区 | av动图| 天天综合视频在线观看 | 久久视频精品在线观看 | 日韩高清不卡一区二区三区 | 99看视频在线观看 | av网站播放 | 超碰97人人射妻 | a级成人毛片 | 五月婷亚洲| 成人永久视频 | 成人av一区二区兰花在线播放 | 午夜精品电影一区二区在线 | 国产五月婷婷 | 日韩免费三区 | 日韩久久精品一区二区三区 | 国产区精品区 | 国产手机在线视频 | 91高清视频在线 | 日韩成人免费在线观看 | 97超碰站| 色综合久久88色综合天天 | 亚洲精品国偷自产在线91正片 | 特级毛片在线观看 | av一区二区在线观看中文字幕 | 国产 中文 日韩 欧美 | 亚洲一区网站 | 九热精品| 久草视频在线资源 | 国产高清在线a视频大全 | 国产成人亚洲在线观看 | 亚洲天堂网在线视频 | 激情久久久久久久久久久久久久久久 | 免费观看十分钟 | 婷婷色站 | 人人草人 | 日韩免费福利 | 人人爽爽人人 | 久久久久国产一区二区三区 | 久久九九久久精品 | 国产日产欧美在线观看 | 欧美精品中文在线免费观看 | 色婷婷成人网 | 热九九精品 | 中文字幕在线播放一区二区 | 久久99国产精品免费网站 | 日日夜夜天天久久 | 91精品国产91 | 日韩有码在线播放 | 欧美在线视频日韩 | 在线观看香蕉视频 | 亚洲国产黄色 | 免费在线观看91 | 日韩电影在线观看一区二区三区 | 91日韩精品一区 | 亚洲精品999 | 二区在线播放 | 三级黄色三级 | 亚洲男男gaygay无套同网址 | 色香网| 国产精品麻豆果冻传媒在线播放 | 成人av直播 | 在线免费看黄色 | 91女神的呻吟细腰翘臀美女 | 久9在线| 99精品视频在线观看免费 | 亚洲国产精品va在线 | 天天干,狠狠干 | 久久免费视频2 | 毛片.com| 欧美精品久久天天躁 | 欧美精品一区二区蜜臀亚洲 | 欧美热久久 | 91在线91 | 精品国产自在精品国产精野外直播 | 午夜影视av| 中文字幕精品三级久久久 | 亚洲作爱 | 日韩在线网址 | 日韩在线电影一区二区 | 色天堂在线视频 | 日韩精品一区二区在线观看 | 91视频国产免费 | 激情伊人五月天久久综合 | 日韩高清黄色 | 制服丝袜欧美 | av网站免费看| 在线观看免费成人 | 日韩网站在线观看 | 全久久久久久久久久久电影 | 99久久久久久久 | 蜜臀aⅴ国产精品久久久国产 | 欧美性粗大hdvideo | 久久免费视频1 | 中文字幕av免费在线观看 | 国产日韩欧美在线播放 | 国产乱对白刺激视频在线观看女王 | 久草视频在线资源 | 欧美精品生活片 | 亚洲国产中文字幕在线 | 国内精品久久天天躁人人爽 | 免费福利在线 | 天堂av色婷婷一区二区三区 | 日韩毛片久久久 | 精品国产乱子伦一区二区 | 欧美肥妇free | 亚洲国产视频在线 | 亚洲aⅴ免费在线观看 | 日韩影视精品 | 精品国产伦一区二区三区观看方式 | 99久久婷婷国产一区二区三区 | 九九久久久久99精品 | 色综合久久精品 | 在线日韩精品视频 | 国产大片黄色 | 国产伦精品一区二区三区照片91 | 国产免费国产 | 欧美精品一区二区在线播放 | 91资源在线视频 | 婷婷综合五月 | 精产嫩模国品一二三区 | 五月天综合 | 日韩久久精品一区二区 | 91在线麻豆 | 免费av高清 | 成人影视免费看 | 久久这里只有精品久久 | 在线a视频免费观看 | 五月婷婷六月丁香 | 久久久精品一区二区 | 成年人天堂com | 午夜12点 | 成人资源在线播放 | av电影一区二区三区 | 国产福利午夜 | 日韩欧美在线视频一区二区 | 国产精品完整版 | 91精品天码美女少妇 | 91av在线视频播放 | 色婷丁香 | 91一区二区在线 | 五月天激情视频 | www.狠狠 | 久久久久久久久毛片精品 | 精品自拍sae8—视频 | 欧美激情精品久久久久久 | 亚欧日韩成人h片 | 日本最新中文字幕 | 在线视频app | 亚洲美女在线一区 | 国产精品久久99精品毛片三a | 国产小视频在线观看免费 | 97av在线视频免费播放 | 中文字幕亚洲情99在线 | 久久国产精品久久国产精品 | 国产在线观看一 | 日韩精品一区二区免费视频 | 午夜久久久久久久久久久 | av中文天堂| 国产成人久久精品一区二区三区 | 亚洲在线免费视频 | 久草精品电影 | 在线观看黄网站 | 99超碰在线观看 | 国产亚洲精品久久久久5区 成人h电影在线观看 | 日韩免费一级a毛片在线播放一级 | 亚洲天天看 | 中文字幕在线观看免费高清电影 | 成人黄大片视频在线观看 | 国产福利免费在线观看 | 中文在线中文a | 亚洲人成在线电影 | 波多野结衣小视频 | 亚洲色视频 | 精品毛片久久久久久 | 国产 日韩 在线 亚洲 字幕 中文 | 亚洲在线视频播放 | 在线免费视频a | 91理论片午午伦夜理片久久 | 91香蕉久久| 少妇精69xxtheporn | 在线观看激情av | 中文字幕高清在线 | 久久艹国产 | 狠狠干中文字幕 | 久久经典视频 | 国产精品国产三级国产aⅴ9色 | 精品 激情 | 国产一级片网站 | 国产在线精| 亚洲精品免费在线观看视频 | 国产亚洲精品久久 | 免费黄色小网站 | 天天色天天射综合网 | 69精品视频| 天天摸天天弄 | 成人性生交大片免费观看网站 | 中文字幕成人网 | 色综合中文字幕 | 国产精品21区| 日韩二区三区 | 亚洲黄a| 婷婷av资源 | 久久中文欧美 | 天天操天天插 | 日韩免费三区 | 九九综合九九综合 | 精品视频专区 | 激情视频网页 | 91av官网| 久久久精品 一区二区三区 国产99视频在线观看 | 五月天天色 | 在线国产一区二区三区 | 国产成人精品亚洲日本在线观看 | 午夜精品视频在线 | 亚洲一级黄色大片 | 色爽网站 | 色婷久久 | 久草在线免费看视频 | 99亚洲天堂 | 成人在线观看免费视频 | 97超级碰 | 五月婷婷黄色网 | 久99久在线视频 | 香蕉久草| 久久性生活片 | 探花视频在线观看+在线播放 | av电影中文字幕 | 91秒拍国产福利一区 | 成年一级片 | 国产麻豆电影 | 色婷婷电影 | 性色大片在线观看 | 欧美日韩在线看 | 一本一本久久a久久精品综合小说 | 精品福利在线观看 | 开心激情五月婷婷 | 日韩中文字幕免费在线观看 | 国产色爽 | 亚洲精品福利在线观看 | 国产精品手机看片 | 美女视频免费精品 | 久久理论电影 | 97在线播放 | 就要干b | 国内精品毛片 | 国产亚洲激情视频在线 | 超碰97在线资源站 | 中文字幕在线精品 | 在线免费观看国产精品 | 波多野结衣在线视频免费观看 | 香蕉影视在线观看 | 国产精品大全 | 黄视频色网站 | 国产大尺度视频 | 亚洲情婷婷 | 成人一级黄色片 | a爱爱视频 | 天天操伊人 | 国产免费a | 婷婷在线免费 | 毛片无卡免费无播放器 | 国产一区二区成人 | 在线观看的黄色 | 精品国产一区二区三区不卡 | 久操视频在线播放 | 国产高清专区 | 毛片在线网 | 麻豆91精品视频 | 日韩欧美在线免费观看 | 久久久久久久网 | av3级在线| 日韩视频免费 | 五月激情亚洲 | 国产精品免费观看网站 | 日韩精品一区二区免费视频 | 一区二三国产 | 国产 色 | 久久午夜电影网 | 欧美精品三级 | 成 人 黄 色 视频 免费观看 | 久久精品中文字幕免费mv | 天天插天天 | 天天摸天天操天天爽 | 日韩精品中文字幕在线观看 | 久久专区| 色婷婷综合久久久中文字幕 | 天天色天天射天天干 | 免费在线播放av电影 | 丁香综合网 | 久久黄色网| 久久精品国产第一区二区三区 | 最近字幕在线观看第一季 | 日韩激情网 | 91九色porn在线资源 | 四虎国产永久在线精品 | 91九色网址| 日韩欧美一级二级 | 亚洲欧美成人在线 | 日本在线观看黄色 | 成人超碰在线 | a级国产乱理伦片在线观看 亚洲3级 | 97在线视频免费播放 | 国产午夜精品久久 | 亚洲欧美成人 | 国产精品一区二区三区电影 | 91视频麻豆 | 久久a视频| 手机看国产毛片 | 瑞典xxxx性hd极品 | 91香蕉国产在线观看软件 | 成人av影视在线 | 在线观看视频97 | 狠狠干天天色 | 久久久久久久久国产 | 婷婷色中文字幕 | 黄色日视频 | 二区视频在线 | 五月天综合色激情 | 亚洲韩国一区二区三区 | 中文字幕一二三区 | 亚洲小视频在线观看 | 美女网站在线观看 | 麻豆视频成人 | 日韩欧美视频二区 | 日韩精品不卡在线 | 国产精品毛片一区视频播不卡 | 五月婷在线观看 | 天堂视频一区 | 天天射天天干天天 | 在线香蕉视频 | 国产一级黄色免费看 | 国产精品国产三级国产aⅴ无密码 | 丁香视频五月 | 黄色毛片大全 | 99久精品| 99久久精品国产亚洲 | 精品欧美一区二区精品久久 | 久久免费在线视频 | 在线观看视频亚洲 | 久久99国产精品视频 | 免费看日韩片 | 国产精品久久久久久久免费 | 久久久电影网站 | 亚洲精品国产精品国 | 久久久穴 | 久久久一本精品99久久精品66 | 日韩电影精品 | 在线综合色 | 精品在线免费观看 | 97人人精品| 天天操天天色天天射 | 成人h动漫在线看 | 国产在线 一区二区三区 | 黄色电影在线免费观看 | 国产999精品 | 久久网址 | www.夜夜干.com | www日韩在线观看 | 91中文字幕| 91视频免费看片 | 日韩大片免费观看 | 一区二区三区精品在线 | 中国精品一区二区 | 亚洲精品网站 | 亚洲精品成人av在线 | 色婷婷成人网 | 奇米影视8888 | 久久久久高清毛片一级 | 亚洲2019精品 | 黄色在线成人 | 欧美激情在线网站 | 日韩中文字幕国产 | 免费看十八岁美女 | 欧美性生活久久 | 中文字幕无吗 | 99热国产在线 | 国产高清专区 | 亚洲激情av | 中文字幕在线播放视频 | 国产一区二区精 | 国产麻豆精品95视频 | www欧美色| 天堂av免费观看 | 91视频免费 | 天天操月月操 | 97超碰.com | 亚洲午夜久久久久久久久久久 | 亚洲网站在线看 | 成人免费看片98欧美 | 欧美另类v | 久久夜色精品亚洲噜噜国4 午夜视频在线观看欧美 | 天天插天天干天天操 | 日韩在线电影一区二区 | japanesefreesexvideo高潮 | 成人激情开心网 | 97精品国产91久久久久久久 | 五月婷在线观看 | 91日韩精品一区 | 天堂av在线网 | 婷婷视频在线观看 | 欧美在线一二区 | 亚洲精品小视频 | 免费国产亚洲视频 | 在线观看精品视频 | 99久e精品热线免费 99国产精品久久久久久久久久 | 婷婷六月色 | 久久99爱视频 | 伊甸园av在线 | 在线影院中文字幕 | 国产欧美精品一区二区三区 | 久久激五月天综合精品 | 97色在线| 97人人视频 | www.午夜视频 | 成年人免费看片网站 | 日韩中文字幕在线看 | 又黄又刺激又爽的视频 | 久久超碰在线 | 成人毛片在线观看视频 | 国产精品久久久久久久久久尿 | 黄色tv视频| 在线看一区二区 | 国产精品精品久久久久久 | 亚洲高清久久久 | 99在线视频观看 | 婷婷综合影院 | 91高清视频在线 | 国产精品九九九九九 | 日韩黄色在线观看 | 欧美日在线 | 久草国产精品 | 精品国产乱码久久久久久1区2匹 | 一级黄色大片 | 久草爱 | 中文字幕乱码一区二区 | 干干夜夜 | 免费看的黄色录像 | 亚洲精品日韩av | 中文字幕精品在线 | 成人a v视频 | 99久久www | 久久最新网址 | 99久久日韩精品视频免费在线观看 | 91成人看片 | 国产又粗又硬又爽的视频 | 国产精品久久久久一区二区三区共 | 日本三级在线观看中文字 | 夜夜躁狠狠躁日日躁 | 日本久久高清视频 | 久久99精品久久只有精品 | 99综合久久 | 高清精品视频 | 久久99精品久久久久久 | 国产一在线精品一区在线观看 | 一区二区在线电影 | 国产美女在线免费观看 | 一级性生活片 | 国产精品普通话 | 久精品视频免费观看2 | av在线免费不卡 | 日韩精品一区二区三区高清免费 | 69久久久久久久 | 特级黄色视频毛片 | 中文字幕亚洲国产 | 久久三级视频 | 欧美日韩精品在线 | 超碰在97 | 开心激情久久 | 7777xxxx| 久久精品女人毛片国产 | 天天天天天天天操 | 色综合久久久久网 | 国产精品美女免费 | 日韩肉感妇bbwbbwbbw | 狠狠干 狠狠操 | 5月丁香婷婷综合 | 日韩精品免费专区 | 九九av | 久草在线免费资源 | 欧美高清视频不卡网 | 天天爽天天爽夜夜爽 | 狠狠色狠狠色综合日日92 | 国产又粗又猛又爽 | 91成人免费视频 | 性色在线视频 | 人人插人人费 | 欧美一级电影片 | 中文字幕激情 | 亚洲精品美女久久久久网站 | 亚洲视频综合在线 | 亚洲高清视频一区二区三区 | 日韩精品播放 | 亚洲精品99久久久久久 | 久久手机视频 | 在线观看视频91 | 三级视频日韩 | 日韩v欧美v日本v亚洲v国产v | 成人午夜电影久久影院 | 狠狠色噜噜狠狠狠合久 | 国产一区二区免费在线观看 | 久久久久色| 日日爽夜夜爽 | 91精品少妇偷拍99 | 精品欧美在线视频 | 免费观看完整版无人区 | 蜜臀av免费一区二区三区 | 免费精品人在线二线三线 | www色网站 | 亚洲精品乱码 | www五月婷婷| 成人午夜av电影 | av中文在线播放 | 99在线视频观看 | 国产第一页在线观看 | 91丨九色丨国产在线观看 | 免费av小说| 91精品网站| 国产精品色在线 | 99精品欧美一区二区三区黑人哦 | 国产中文字幕av | 91精品区 | 亚洲综合最新在线 | 欧美大片mv免费 | 亚洲视频观看 | 日韩精品免费在线观看 | 欧美一区影院 | 久久久久国产精品视频 | 在线播放国产一区二区三区 | 亚洲国内在线 | 精品国产亚洲日本 | 亚州av免费 | 日日爽天天爽 | 中文字幕丰满人伦在线 | 亚洲欧美日韩在线看 | 亚洲精品视频中文字幕 | 亚洲精欧美一区二区精品 | 伊人久久电影网 | 一区二区中文字幕在线观看 | 韩国av一区二区三区 | 九九热在线观看视频 | 免费观看国产视频 | 亚洲性少妇性猛交wwww乱大交 | 国产一二三区av | 日本精品一二区 | 综合天天久久 | 婷婷五月情 | 国产成人一区二区三区在线观看 | 亚洲成人中文在线 | 亚洲免费资源 | 在线观看爱爱视频 | 黄色a在线 | 成年人在线观看网站 | 国产97在线视频 | 欧美高清成人 | 精品国产伦一区二区三区观看说明 | 永久免费在线 | 黄污视频网站 | 日本特黄特色aaa大片免费 | 久久特级毛片 | 欧美日韩性视频 | av片子在线观看 | 国产精品 久久 | 国产理论片在线观看 | 久草在线99 | 亚洲日本一区二区在线 | 久久精品高清视频 | 国产精品入口久久 | 欧美精品一区二区三区四区在线 | 爱干视频 | 超碰人人草人人 | 日韩一级电影在线 | 亚洲精品小视频 | 五月天最新网址 | 日韩黄在线观看 | 日韩电影在线观看一区二区 | 国产香蕉97碰碰碰视频在线观看 | 成人国产网址 | 欧美另类交在线观看 | 国产精品久久久久一区二区三区共 | 亚洲国产高清视频 | 91福利国产在线观看 | 少妇精69xxtheporn | 成年人视频在线 | 久久久久国产成人免费精品免费 | 2000xxx影视 | 欧美国产一区二区 | 韩国av电影在线观看 | 96久久精品 | 成人黄色在线观看视频 | 久久字幕精品一区 | 黄色网址av| 国产99久久九九精品免费 | 五月婷婷一区二区三区 | 九九热精品视频在线观看 | 西西www4444大胆在线 | 91精品综合在线观看 | 涩涩网站在线看 | 91亚洲精品久久久蜜桃网站 | 亚洲国产成人在线播放 | 亚洲视频播放 | 99精品色 | 国产又粗又猛又色又黄网站 | 欧美性性网 | 欧美一区二区在线免费看 | 午夜视频在线观看一区二区三区 | 天天操天天拍 | 日本精品久久 | 国产伦精品一区二区三区无广告 | 特级a毛片 | 日韩综合视频在线观看 | 国产视频中文字幕 | 天天综合天天做天天综合 | 国产精品99久久久久久武松影视 | 国产在线观看 | 97人人视频| 日韩激情av在线 | 黄色成人毛片 | 亚洲国产成人精品在线 | 视频在线观看国产 | 久久视频这里有久久精品视频11 | 精品一区二区三区电影 | 成片人卡1卡2卡3手机免费看 | 丁香婷婷激情网 | 日韩一区二区免费播放 | 中文字幕视频播放 | 日韩高清在线一区二区三区 | 亚洲少妇影院 | 精品在线一区二区 | 在线日韩精品视频 | 中文字幕专区高清在线观看 | 欧美亚洲成人xxx | 亚洲天堂视频在线 | 久久久精品国产一区二区三区 | 最近中文字幕免费av | japanesexxxhd奶水 91在线精品一区二区 | 九草在线观看 | 日日干影院 | 亚洲视频 一区 | 亚洲精品乱码久久久久久 | 五月天亚洲综合 | 婷婷久操 | 五月婷婷六月丁香激情 | 成年人免费观看在线视频 | 亚洲视频 一区 | 国产在线精品播放 | 麻豆视屏 | 黄色一区二区在线观看 | 激情av资源网 | 91探花系列在线播放 | 三级免费黄色 | 久久综合成人网 | 久久影视网 | 日本中文字幕在线一区 | 免费在线色电影 | 欧美午夜一区二区福利视频 | 免费高清无人区完整版 | 天天综合天天综合 | 日韩电影在线一区二区 | 91麻豆操| 在线视频亚洲 | 午夜影院一级片 | 日韩最新理论电影 | 精品欧美小视频在线观看 | 成人av一区二区三区 | 在线之家免费在线观看电影 | 最新精品国产 | 91av手机在线 | 久久视频精品 | 精品国产一区二区三区久久久蜜月 | 精品一区在线看 | 亚洲成人精品 | 18+视频网站链接 | 色久综合 | 国产成人精品综合久久久 | 久久久穴| 2022中文字幕在线观看 | 91精品国产一区 | 黄色大片网 | 国产一级在线看 | 久久久精品一区二区 | 中文字幕欧美日韩va免费视频 | 人人看看人人 | 日韩中文幕| 天天操天天怕 | 日产乱码一二三区别免费 | 久久不卡日韩美女 | 高清不卡一区二区在线 | 中文字幕精 | 久久久久久国产精品美女 | 日韩极品在线 | 欧美极品xxx | 五月天综合在线 | 国产一区二区三区网站 | 国产精品系列在线观看 | 成年人网站免费观看 | 国产一区二区精品 | 久久国产精品一区二区三区 | 久久综合中文字幕 | 综合av在线 | 综合久久婷婷 | 欧美精品免费在线 | 黄色视屏av | 青青草在久久免费久久免费 | 99久久电影| 日韩欧美在线观看一区 | 久久久一本精品99久久精品 | 一区二区三区四区免费视频 | 日韩一区二区三免费高清在线观看 | 美女久久久久 | 国产精品毛片一区二区 | 欧美日韩国产在线精品 |