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

Serverless 工程實踐|Serverless 應用優化與調試秘訣

網絡
前言:本文將以阿里云函數計算為例,提供了在線調試、本地調試等多種應用優化與調試方案。

Serverless 應用調試秘訣

在應用開發過程中,或者應用開發完成,所執行結果不符合預期時,我們要進行一定的調試工作。但是在 Serverless 架構下,調試往往會受到極大的環境限制,出現所開發的應用在本地可以健康、符合預期的運行,但是在 FaaS 平臺上發生一些不可預測的問題的情況。而且在一些特殊環境下,本地沒有辦法模擬線上環境,難以進行項目的開發和調試。

Serverless 應用的調試一直都是備受詬病的,但是各個云廠商并沒有因此放棄在調試方向的深入探索。以阿里云函數計算為例,其提供了在線調試、本地調試等多種調試方案。

在線調試

1.簡單調試

所謂的簡單調試,就是在控制臺進行調試。以阿里云函數計算為例,其可以在控制臺通過“執行”按鈕,進行基本的調試,如圖所示。

函數在線簡單調試頁面

必要的時候,我們也可以通過設置 Event 來模擬一些事件,如圖所示。

通過設置 Event 模擬事件

在線調試的好處是,可以使用線上的一些環境進行代碼的測試。當線上環境擁有 VPC 等資源時,在本地環境是很難進行調試的,例如數據庫需要通過 VPC 訪問,或者有對象存儲觸發器的業務邏輯等。

2.斷點調試

除了簡單的調試之外,部分云廠商也支持斷點調試,例如阿里云函數計算的遠程調試、騰訊云云函數的遠程調試等。以阿里云函數計算遠程調試為例,其可以通過控制臺進行函數的在線調試。當創建好函數之后,用戶可以選擇遠程調試,并點擊“開啟調試”按鈕,如圖所示。

函數在線斷點調試頁面(一)

開啟調試之后,稍等片刻,系統將會進入遠程調試界面,如圖所示。

函數在線斷點調試頁面(二)

此時可以進行一些斷點調試,如圖所示。

函數在線斷點調試頁面(三)

本地調試

1.命令行工具

就目前來看,大部分 FaaS 平臺都會為用戶提供相對完備的命令行工具,包括 AWS 的SAM CLI、阿里云的 Funcraft,同時也有一些開源項目例如 Serverless Framework、Serverless Devs 等對多云廠商的支持。通過命令行工具進行代碼調試的方法很簡單。以 Serverless Devs 為例,本地調試阿里云函數計算。

首先確保本地擁有一個函數計算的項目,如圖所示。

本地函數計算項目

然后在項目下執行調試指令,例如在 Docker 中進行調試,如圖所示。

命令行工具調試函數計算

2.編輯器插件

以 VScode 插件為例,當下載好阿里云函數計算的 VSCode 插件,并且配置好賬號信息之后,可以在本地新建函數,并且在打點之后可以進行斷點調試,如圖所示。

VSCode 插件調試函數計算

當函數調試完成之后,執行部署等操作。

其他調試方案

1.Web 框架的本地調試

在阿里云 FaaS 平臺開發傳統 Web 框架,以 Python 語言編寫的 Bottle 框架為例,可以增加以下代碼:

  1. app = bottle.default_app()并且對run方法進行條件限制 (if __name__ == '__main__'):if __name__ == '__main__':    bottle.run(host='localhost', port=8080, debug=True)例如:# index.pyimport bottle@bottle.route('/hello/<name>')def index(name):    return "Hello world"app = bottle.default_app()if __name__ == '__main__':    bottle.run(host='localhost', port=8080, debug=True) 

當部署應用到線上時,只需要在入口方法處填寫 ndex.app,即可實現平滑部署。

2.本地模擬事件調試

針對非 Web 框架,我們可以在本地構建一個方法,例如要調試對象存儲觸發器:

  1. import jsondef handler(event, context):    print(event)def test():    event = {        "events": [            {                "eventName""ObjectCreated:PutObject",                "eventSource""acs:oss",                "eventTime""2017-04-21T12:46:37.000Z",                "eventVersion""1.0",                "oss": {                    "bucket": {                        "arn""acs:oss:cn-shanghai:123456789:bucketname",                        "name""testbucket",                        "ownerIdentity""123456789",                        "virtualBucket"""                    },                    "object": {                        "deltaSize"122539,                        "eTag""688A7BF4F233DC9C88A80BF985AB7329",                        "key""image/a.jpg",                        "size"122539                    },                    "ossSchemaVersion""1.0",                    "ruleId""9adac8e253828f4f7c0466d941fa3db81161****"                },                "region""cn-shanghai",                "requestParameters": {                    "sourceIPAddress""140.205.***.***"                },                "responseElements": {                    "requestId""58F9FF2D3DF792092E12044C"                },                "userIdentity": {                    "principalId""123456789"                }            }        ]    }    handler(json.dumps(event), None)if __name__ == "__main__":    print(test()) 

這樣,通過構造一個 event 對象,即可實現模擬事件觸發。

Serverless 應用優化

資源評估依舊重要

Serverless 架構雖然是按量付費的,但是并不代表它就一定比傳統的服務器租用費用低。如果對自己的項目評估不準確,對一些指標設置不合理,Serverless 架構所產生的費用可能是巨大的。

一般情況下,FaaS 平臺的收費和三個指標有直接關系,即所配置的函數規格(例如內存規格等)、程序所消耗的時間以及產生的流量費用。通常情況下,程序所消耗的時間可能與內存規格、程序本身所處理的業務邏輯有關。流量費用與程序本身和客戶端交互的數據包大小有關。所以在這三個常見的指標中,可能因為配置不規范導致計費出現比較大偏差的就是內存規格。以阿里云函數計算為例,假設有一個 Hello World 程序,每天都會被執行 10000 次,不同規格的內存所產生的費用(不包括網絡費用)如表所示。

通過表中可以看到,當程序在 128MB 規格的內存中可以正常執行,如果錯誤地將內存規格設置成 3072MB,可能每月產生的費用將會暴漲 25 倍!所以在上線 Serverless 應用之前,要對資源進行評估,以便以更合理的配置來進一步降低成本。

合理的代碼包規格

各個云廠商的 FaaS 平臺中都對代碼包大小有著限制。拋掉云廠商對代碼包的限制,單純地說代碼包的規格可能會產生的影響,通過函數的冷啟動流程可以看到,如圖所示。

函數冷啟動流程簡圖

在函數冷啟動過程中,當所上傳的代碼包過大,或者文件過多導致解壓速度過慢,就會使加載代碼過程變長,進一步導致冷啟動時間變久。

設想一下,當有兩個壓縮包,一個是只有 100KB 的代碼壓縮包,另一個是 200MB 的代碼壓縮包,兩者同時在千兆的內網帶寬下理想化(即不考慮磁盤的存儲速度等)下載,即使最大速度可以達到 125MB/s,那么前者的下載時間只有不到 0.01 秒,后者需要 1.6 秒。除了下載時間之外,加上文件的解壓時間,那么兩者的冷啟動時間可能就相差 2 秒。一般情況下,對于傳統的 Web 接口,如果要 2 秒以上的響應時間,實際上對很多業務來說是不能接受的,所以在打包代碼時就要盡可能地降低壓縮包大小。以 Node.js 項目為例,打包代碼包時,我們可以采用 Webpack 等方法來壓縮依賴包大小,進一步降低整體代碼包的規格,提升函數的冷啟動效率。

合理復用實例

為了更好地解決冷啟動的問題、更合理地利用資源,各個云廠商的 FaaS 平臺中是存在實例復用情況的。所謂的實例復用,就是當一個實例完成一個請求后并不會釋放,而是進入靜默的狀態。在一定時間范圍內,如果有新的請求被分配過來,則會直接調用對應的方法,而不需要再初始化各類資源等,這在很大程度上減少了函數冷啟動的情況出現。為了驗證,我們可以創建兩個函數:

  1. 函數1:# -*- coding: utf-8 -*-def handler(event, context):    print("Test")    return 'hello world'函數2:# -*- coding: utf-8 -*-print("Test")def handler(event, context):    return 'hello world' 

在控制臺點擊“測試”按鈕,對上述兩個函數進行測試,判斷其是否在日志中輸出了 “Test”,統計結果如表所示。

函數復用記錄

可以看到,其實實例復用的情況是存在的。進一步思考,如果 print("Test") 語句是一個初始化數據庫連接,或者是函數 1 和函數 2 加載了一個深度學習模型,是不是函數 1 就是每次請求都會執行,而函數 2 可以復用已有對象?

所以在實際的項目中,有一些初始化操作是可以按照函數 2 實現的,例如:

在機器學習場景下,在初始化的時候加載模型,避免每次函數被觸發都會加載模型。
在初始化的時候建立鏈接對象,避免每次請求都創建鏈接對象。
其他一些需要首次加載時下載、加載的文件在初始化時實現,提高實例復用效率。

善于利用函數特性

各個云廠商的 FaaS 平臺都有一些特性。所謂的平臺特性,是指這些功能可能并不是 CNCF WG-Serverless Whitepaper v1.0 中規定的能力或者描述的能力,僅僅是作為云平臺根據自身業務發展和訴求從用戶角度出發挖掘出來并且實現的功能,可能只是某個云平臺或者某幾個云平臺所擁有的功能。這類功能一般情況下如果利用得當會讓業務性能有質的提升。

1.Pre-freeze & Pre-stop

以阿里云函數計算為例,在平臺發展過程中,用戶痛點(尤其是阻礙傳統應用平滑遷移至 Serverless 架構)如下。

異步背景指標數據延遲或丟失:如果在請求期間沒有發送成功,則可能被延遲至下一次請求,或者數據點被丟棄。
同步發送指標增加延時:如果在每個請求結束后都調用類似 Flush 接口,不僅增加了每個請求的延時,對于后端服務也產生了不必要的壓力。
函數優雅下線:實例關閉時應用有清理連接、關閉進程、上報狀態等需求。在函數計算中實例下線時,開發者無法掌握,也缺少 Webhook 通知函數實例下線事件。
根據這些痛點,阿里云發布了運行時擴展 (Runtime Extensions) 功能。該功能在現有的 HTTP 服務編程模型上擴展,在已有的 HTTP 服務器模型中增加了 PreFreeze 和 PreStop Webhook。擴展開發者負責實現 HTTP handler,監聽函數實例生命周期事件,如圖所示。

擴展編程模型與現有編程模型處理的工作內容簡圖

PreFreeze:在每次函數計算服務決定冷凍當前函數實例前,函數計算服務會調用 HTTP GET/prefreeze 路徑,擴展開發者負責實現相應邏輯以確保完成實例冷凍前的必要操作,例如等待指標發送成功等,如圖所示。函數調用 InvokeFunction 的時間不包含 PreFreeze Hook 的執行時間。

PreFreeze時序圖

PreStop:在每次函數計算決定停止當前函數實例前,函數計算服務會調用 HTTP GET/prestop 路徑,擴展開發者負責實現相應邏輯以確保完成實例釋放前的必要操作,如等待數據庫鏈接關閉,以及上報、更新狀態等,如圖所示。

PreStope 時序圖

2.單實例多并發

眾所周知,各云廠商的函數計算通常是請求級別的隔離,即當客戶端同時發起 3 個請求到函數計算,理論上會產生 3 個實例進行應對,這個時候可能會涉及冷啟動以及請求之間狀態關聯等問題。因此,部分云廠商提供了單實例多并發的能力(例如阿里云函數計算)。該能力允許用戶為函數設置一個實例并發度 (InstanceConcurrency) ,即單個函數實例可以同時處理多個請求,如圖所示。

單實例多并發效果簡圖

如上圖所示,假設同時有 3 個請求需要處理,當實例并發度設置為 1 時,函數計算需要創建 3 個實例來處理這 3 個請求,每個實例分別處理 1 個請求;當實例并發度設置為 10 時(即1個實例可以同時處理 10 個請求),函數計算只需要創建 1 個實例就能處理這 3 個請求。

單實例多并發的優勢如下。

減少執行時長,節省費用。例如,偏 I/O 函數可以在一個實例內并發處理請求,減少了實例數,從而減少總的執行時長。
請求之間可以共享狀態。多個請求可以在一個實例內共用數據庫連接池,從而減少和數據庫之間的連接數。
降低冷啟動概率。由于多個請求可以在一個實例內處理,創建新實例的次數會減少,冷啟動概率降低。
減少占用 VPC IP。在相同負載下,單實例多并發可以降低總的實例數,從而減少 VPC IP 的占用。
單實例多并發的應用場景比較廣泛,例如函數中有較多時間在等待下游服務響應的場景就比較適合使用該功能。單實例多并發也有不適合應用的場景,例如函數中有共享狀態且不能并發訪問時,單個請求的執行要消耗大量 CPU 及內存資源,這時就不適合使用單實例多并發功能。

 

責任編輯:梁菲 來源: 阿里云云棲號
相關推薦

2021-09-18 10:23:43

Serverless

2021-09-08 10:12:39

Serverless 云計算

2021-10-15 10:00:31

Serverless Knative

2021-11-18 09:46:24

ServerlessKubeless 阿里云

2017-05-29 08:18:11

Serverless架構軟件系統

2022-10-27 14:25:46

無服務器Serverless云原生

2016-07-01 14:43:32

DockerServerless

2021-09-06 16:00:39

Serverless當當Knative

2021-09-13 18:09:59

騰訊文檔業務云計算

2020-04-09 08:57:57

Serverless無服務器語言

2021-05-27 11:03:10

飛豬Serverless

2020-05-26 22:23:03

Serverless容器Serverless

2023-06-28 11:55:50

Serverless架構云計算

2017-03-15 19:03:05

云計算

2020-05-06 16:47:59

ServerlessMVC架構

2023-04-25 08:01:23

JavaQuarkusKubernetes

2020-05-09 09:04:23

Serverless運維測試

2023-01-11 08:00:00

云計算Serverless安全

2021-01-29 12:33:21

云計算Serverless架構

2019-03-14 11:02:21

Serverless前端工程師Ajax
點贊
收藏

51CTO技術棧公眾號

四虎成人免费影院| 色国产在线视频| 亚洲AV成人无码一二三区在线| 在线成人www免费观看视频| 欧美精品一区二区三区久久久 | 性欧美欧美巨大69| 精品国产不卡一区二区三区| 能看的毛片网站| 中中文字幕av在线| 国产午夜精品一区二区三区嫩草| 成人日韩在线电影| 九九精品免费视频| 91精品亚洲| 亚洲人成绝费网站色www| 亚洲天堂伊人网| 成人小电影网站| 亚洲免费在线看| 欧美精品二区三区四区免费看视频| 国产又黄又大又爽| 久久久久国产精品午夜一区| 欧美成人精品一区二区三区| 国产伦理片在线观看| av成人资源网| 91精品久久久久久久久99蜜臂| 国产精品333| 日本资源在线| 亚洲欧美在线aaa| 日本电影一区二区三区| 少妇一级淫片免费看| 激情五月播播久久久精品| 欧美一区亚洲一区| 精品视频一区二区在线观看| 久久影院一区| 亚洲奶大毛多的老太婆| 婷婷五月精品中文字幕| 欧美不卡在线观看| 欧美色倩网站大全免费| 日韩无套无码精品| 欧美一级鲁丝片| 午夜视频在线观看一区| 亚洲高潮无码久久| 三级外国片在线观看视频| 久久精品网站免费观看| 久久久福利视频| 精品国产欧美成人夜夜嗨| 国产69久久精品成人看| 久久久久久激情| 亚洲高清影视| 久久亚洲精品一区二区| 娇小11一12╳yⅹ╳毛片| blacked蜜桃精品一区| 亚洲色无码播放| 亚洲av无码一区二区二三区| 日韩av黄色在线| 日韩成人在线视频| 偷偷色噜狠狠狠狠的777米奇| 亚洲精品午夜| 欧美成人vr18sexvr| 久久久久无码精品| 日韩一区二区三区精品视频第3页| 欧美一区二视频| 美女被艹视频网站| 亚洲一区二区三区在线免费| 精品国产一区a| 国模私拍在线观看| 亚洲人挤奶视频| 亚洲日韩欧美视频一区| 毛片aaaaaa| 91久久高清国语自产拍| 欧美日本国产在线| 五月天综合在线| 亚洲制服av| 国产精品劲爆视频| 国产一区二区三区四区视频| 黑人巨大精品欧美黑白配亚洲| 亚洲xxxxx电影| 国产成人手机在线| 26uuu精品一区二区| 视频一区视频二区视频| 麻豆视频在线免费观看| 亚洲一区中文在线| 久久久久久久激情| 男女啪啪999亚洲精品| 欧美一级片免费看| 国产麻豆xxxvideo实拍| 欧美久久综合网| 久久av在线播放| 国产专区第一页| 精品一区二区在线看| 国产欧美一区二区在线播放| 你懂得在线网址| 亚洲丝袜制服诱惑| 免费在线激情视频| www 久久久| 日韩经典一区二区三区| 天堂网中文在线观看| 欧美黄污视频| 国产精品久久久久久av福利| 性一交一乱一伧老太| www国产成人| 糖心vlog在线免费观看| 高清不卡亚洲| 日韩亚洲欧美在线| 日本爱爱爱视频| 国一区二区在线观看| 国产精品精品视频一区二区三区| www男人的天堂| 欧美激情在线一区二区| 国产3p露脸普通话对白| 欧美特黄色片| 亚洲女成人图区| 激情综合五月网| 另类小说欧美激情| 另类小说综合网| 在线观看a级片| 欧美日韩在线亚洲一区蜜芽| 国产xxxxxxxxx| 欧美精品国产| 成人欧美在线视频| 国产毛片在线| 欧美性猛交xxxx乱大交3| 国产精品区在线| 蜜桃精品噜噜噜成人av| 高清欧美性猛交xxxx| 91精品中文字幕| 国产欧美日韩三级| 日本精品一区在线观看| 国产厕拍一区| 欧美成人中文字幕| 亚洲天堂网视频| 中文字幕免费观看一区| 久久美女福利视频| 少妇一区二区三区| 高清一区二区三区日本久| a级片在线播放| 亚洲欧美在线观看| 岛国av免费在线| 久久久影院免费| 国产精品视频免费在线| 91青青在线视频| 91福利精品第一导航| 日韩中文字幕电影| 在线视频观看日韩| 国产不卡一区二区三区在线观看| 18av在线播放| 日韩美女一区二区三区四区| 欧美日韩综合一区二区| 国产一区二区电影| 亚洲爆乳无码精品aaa片蜜桃| 亚洲成人高清| 久久的精品视频| 国产v片在线观看| 亚洲嫩草精品久久| 亚洲成人福利视频| 亚洲高清二区| 免费精品视频一区| 深夜成人影院| 最新国产精品亚洲| 国产精品成人久久久| 国产精品婷婷午夜在线观看| 一本一道久久a久久综合蜜桃| 国产精品久久久久蜜臀| 亚洲自拍欧美另类| 91禁在线看| 亚洲男人第一av网站| 一区二区乱子伦在线播放| 国产精品乱码一区二三区小蝌蚪| 五月天激情播播| 国产精品va| 久久精品国产精品国产精品污 | 一区二区三区四区视频精品免费| 国产探花一区二区三区| 亚洲人成人一区二区三区| 欧美精品亚洲| 欧美天堂在线| 欧美激情视频网址| 日本中文字幕一区二区有码在线| 91黄视频在线观看| 三级全黄做爰视频| www.欧美日韩国产在线| 日韩欧美黄色大片| 欧美国产激情| 欧美日韩无遮挡| 国产精品亚洲一区二区在线观看 | 91国产精品| 久久免费福利视频| 欧美午夜黄色| 91麻豆精品国产91久久久久久| 中文字幕第28页| 国产女人18水真多18精品一级做| 无码人妻少妇色欲av一区二区| 国产欧美69| 中文字幕久精品免| 国产精品调教| 国产九九精品视频| a'aaa级片在线观看| 视频在线观看一区二区| 黑人乱码一区二区三区av| 欧美曰成人黄网| 国产在线观看免费视频今夜| 欧美国产精品中文字幕| 黄色av电影网站| 精品亚洲国产成人av制服丝袜| 免费看黄在线看| 五月激情久久久| 欧美性xxxx69| 精品在线网站观看| 成人a视频在线观看| 欧美xxxxxx| 久久久亚洲天堂| 大片免费在线看视频| 亚洲人在线视频| 婷婷亚洲一区二区三区| 日韩午夜精品视频| 欧美激情一区二区三区免费观看| 五月婷婷久久丁香| 欧美日韩在线视频免费| 国产精品久久久久毛片软件| 一级性生活大片| 成人高清伦理免费影院在线观看| 国产精品999.| 九色|91porny| 少妇一级淫免费放| 每日更新成人在线视频| 国产精品久久中文字幕| 91精品观看| 一本一道久久久a久久久精品91| 精品中文字幕一区二区三区av| 国产精品久久久久免费| 日韩一区二区三区高清在线观看| 91精品久久久久久久| 桃子视频成人app| 日本老师69xxx| 小草在线视频免费播放| 午夜精品久久久久久久男人的天堂 | 国产精品天美传媒| 中文字幕免费看| 91麻豆精品秘密| 毛片网站免费观看| 久久这里只有精品6| 国产精品无码一区二区三| 成人av资源站| 欧美久久久久久久久久久| 国产91精品露脸国语对白| 亚洲911精品成人18网站| 国产乱码精品一区二区三区av| 中文字幕一区久久| 精品亚洲aⅴ乱码一区二区三区| 91n.com在线观看| 美女在线一区二区| 成人日韩在线视频| 国产一区二区三区四区在线观看| 91大神免费观看| 国产黄人亚洲片| 欧美性猛交乱大交| 懂色av一区二区夜夜嗨| 成人做爰www看视频软件| 波多野结衣中文字幕一区| 欧美在线一级片| 久久久亚洲综合| 国产又粗又猛又爽又黄的视频四季 | 国产精品亚洲天堂| 中文一区一区三区免费在线观看| 国产树林野战在线播放| 黄色亚洲免费| 亚洲国产精品久久久久爰色欲| 日韩精品91亚洲二区在线观看 | 中国一级大黄大黄大色毛片| 亚洲欧美文学| 午夜精品久久久久久久无码| 丝瓜av网站精品一区二区| 亚洲一级免费在线观看| 激情五月婷婷综合| 日韩精品人妻中文字幕有码| 久久久影视传媒| 久久av红桃一区二区禁漫| 亚洲一区视频在线观看视频| 五月婷婷视频在线| 欧美日韩高清在线播放| www久久久久久| 国产一区二区激情| 天堂av在线电影| 日本一欧美一欧美一亚洲视频| 色999久久久精品人人澡69| 99久久久精品免费观看国产| 亚洲综合福利| 只有这里有精品| 久久精品盗摄| 在线观看视频你懂得| 久久精品夜夜夜夜久久| 唐朝av高清盛宴| 在线精品亚洲一区二区不卡| 国产黄色大片网站| 亚洲欧美精品伊人久久| 97超碰资源站在线观看| 欧洲中文字幕国产精品| 国产高清视频一区二区| 久久久久久九九| 综合久久亚洲| av网站在线不卡| av在线综合网| 精品国产视频一区二区三区| 色综合久久久久久久久| 午夜美女福利视频| www.日韩免费| 这里有精品可以观看| 亚洲sss综合天堂久久| 沈樵精品国产成av片| 欧美一级中文字幕| 日本麻豆一区二区三区视频| www.男人天堂| 亚洲精品免费电影| 在线免费观看一区二区| 亚洲精品一区二区三区不| 久久不射影院| 亚洲在线观看视频网站| 日本亚洲不卡| 男女视频网站在线观看| 国产乱人伦偷精品视频不卡| 香蕉久久久久久久| 色综合欧美在线视频区| 色噜噜在线播放| 欧美情侣性视频| 久久久久毛片免费观看| 亚洲一区免费看| 日本午夜一区二区| 成人乱码一区二区三区av| 亚洲成人av电影| 丰满人妻熟女aⅴ一区| 欧美福利视频网站| 国产精品久一| www.午夜色| 精品一区二区三区免费播放| 大胸美女被爆操| 欧美性色aⅴ视频一区日韩精品| 国产中文在线视频| 日本成人精品在线| 亚洲黄页在线观看| 无码人妻丰满熟妇区毛片18| 99精品视频一区二区| 国产在线观看免费av| 精品国产91洋老外米糕| 波多野结依一区| 国产精品免费区二区三区观看| 黑丝一区二区三区| 激情av中文字幕| 亚洲午夜激情av| 人妻精品无码一区二区| 性欧美激情精品| 日本中文字幕在线一区| 男女av免费观看| 国产日韩av一区| 在线观看色网站| 毛片精品免费在线观看| 亚洲视频三区| 九色自拍视频在线观看| 91丨porny丨蝌蚪视频| 99精品在线播放| 最新的欧美黄色| 日韩高清在线观看一区二区| 日韩在线观看a| 久久综合久久鬼色| 国产在线观看第一页| 日韩视频在线观看免费| 免费观看亚洲天堂| 人妻av中文系列| 久久久久久久久久久久久久久99| 瑟瑟视频在线免费观看| 久久精品男人天堂| 国产欧美三级电影| 国产裸体舞一区二区三区| 国产精品高清亚洲| 精品国产av一区二区三区| 国产69精品久久久久99| 国产一区二区三区四区五区 | 99久久久久久| 日韩综合在线观看| 久久久国产精品亚洲一区| 红杏视频成人| 亚洲 欧美 另类人妖| 亚洲最新在线观看| 免费动漫网站在线观看| 亚洲aⅴ男人的天堂在线观看| 亚洲经典在线| 亚洲一级理论片| 欧美不卡激情三级在线观看| 天天免费亚洲黑人免费| 综合视频免费看| 99久久精品99国产精品| 一级黄色片在线观看| 高清欧美性猛交| 99久久婷婷这里只有精品| 日本三级日本三级日本三级极| 欧美三级视频在线播放| 国模私拍视频在线播放| 亚洲一区二区三区免费观看| 成人高清伦理免费影院在线观看| 亚洲综合精品国产一区二区三区| 97视频在线观看网址| 天天综合网网欲色|