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

字節(jié)跳動模型大規(guī)模部署實戰(zhàn)

人工智能 深度學習
隨著 PyTorch/TensorFlow 框架的流行,深度學習模型訓練和在線推理完成了統(tǒng)一,開發(fā)者僅需要關注具體算法邏輯,調用框架的 Python API 完成訓練驗證過程即可,

一. 背景介紹

在字節(jié)跳動,基于深度學習的應用遍地開花,工程師關注模型效果的同時也需要關注線上服務一致性和性能,早期這通常需要算法專家和工程專家分工合作并緊密配合來完成,這種模式存在比較高的 diff 排查驗證等成本。

隨著 PyTorch/TensorFlow 框架的流行,深度學習模型訓練和在線推理完成了統(tǒng)一,開發(fā)者僅需要關注具體算法邏輯,調用框架的 Python API 完成訓練驗證過程即可,之后模型可以很方便的序列化導出,并由統(tǒng)一的高性能 C++ 引擎完成推理工作。提升了開發(fā)者訓練到部署的體驗。

然而,完整的服務通常還存在大量的預處理/后處理等業(yè)務邏輯,這類邏輯通常是把各種輸入經(jīng)過加工處理轉變?yōu)?Tensor,再輸入到模型,之后模型的輸出 Tensor 再加工成目標格式,一些典型的場景如下:

  • Bert
  • Resnet

圖片

圖片

我們的目標就是為以上端到端的過程,提供自動化且統(tǒng)一的訓練、推理方案,減輕人工開發(fā)推理過程、對齊 diff 等一系列問題,實現(xiàn)大規(guī)模的統(tǒng)一部署方案。

二. 核心問題

PyTorch/TensorFlow 等框架相對已經(jīng)解決了模型的訓練/推理統(tǒng)一的問題,因此模型計算本身不存在訓推一體的問題了(算子性能優(yōu)化不在本次討論范圍)。

核心要解決的問題就是:預處理和后處理需要提供高性能訓推一體的方案。

對于此類邏輯,TensorFlow 2.x 提供了 tf.function(還不完善),PyTorch 提供了 TorchScript,其無一例外都是選擇了原生 Python 語法子集。  但即使強大如此,仍然存在不可忽略的問題:

  • 性能:此方案大多基于虛擬機實現(xiàn),虛擬機方案靈活并且非常可控,但深度學習框架中的虛擬機大多通常性能不夠優(yōu)良。補充說明一下,框架早期都是為 Tensor 計算設計,數(shù)組計算每個算子成本很高,虛擬機的派發(fā)和調度成本可以忽略。但是,移植到程序語言編程層面開銷難以忽略,代碼寫多了就會成為性能瓶頸。據(jù)測試,TorchScript 解釋器性能只有 Python 的 1/5 左右,tf.function 性能更差一些。
  • 功能不全:事實上應用到真實場景中,我們仍然可以找出很多 tf.function/TorchScript 不支持的重要功能,比如:自定義的資源不能打包,只能序列化內置類型;字符串只能做 bytes 處理,中文等 unicode 會造成 diff;容器必須同構,不支持自定義類型等等...

再者,還有很多非深度學習任務,比如在自然語言處理中仍然有很多非深度學習的應用或者子任務,如序列標注,語言模型解碼,樹模型的人工特征構造等任務,這些通常具有更靈活的特征范式,但同時都沒有完整實現(xiàn)端到端的訓推一體方案,仍然有大量的開發(fā)以及正確性校驗工作。

為了解決上述問題,我們開發(fā)了一套基于編譯的預處理方案:MATXScript!

三. MATXScript

在深度學習算法開發(fā)中,開發(fā)者通常使用 Python 進行快速迭代和實驗,同時使用 C++ 開發(fā)高性能的線上服務,其中正確性校驗和服務開發(fā)都會成為較重負擔!

MatxScript(https://github.com/bytedance/matxscript) 是一個 Python 子語言的 AOT 編譯器,可以自動化將 Python 翻譯成 C++,并提供一鍵打包發(fā)布功能。使用 MATXScript 可以讓開發(fā)者快速進行模型迭代的同時以較低成本完成高性能服務的部署。

核心架構如下:

圖片

  • 最底層是純 C++/CUDA 的基礎庫,由高性能算子專家開發(fā)。
  • 在基礎庫之上,準守約定封裝出來 Python 的 庫,可以用在 training 過程中。
  • 需要 inferencing 時,利用 MATXScript 可以把 Python 代碼,翻譯成對等的 C++ 代碼,編譯成動態(tài)鏈接庫,加上模型及其他依賴的資源,一起打包發(fā)布即可。

其中,編譯器作用非常關鍵,其核心流程如下:

圖片

通過以上流程,用戶所編寫的預處理代碼,可以被編譯成 Pipeline 中的一個 JitOp,為了把前后處理和模型聯(lián)動,我們還開發(fā)了 tracing 系統(tǒng)(接口設計上參考了 PyTorch),架構如下:

圖片

基于 MATXScript,我們可以訓練和推理使用同一套代碼,大大降低了模型部署的成本。同時,架構和算法得到了解耦,算法同學完全使用 Python 工作即可,架構同學專注于編譯器開發(fā)及 Runtime 優(yōu)化,在字節(jié)跳動,此方案得到了大規(guī)模部署驗證!

四. 小試牛刀

此處以最簡單的英文文本預處理為例,展示一下 MATXScript 如何使用。

目標:把一段英文文本轉成 indexes

  1. 編寫一個基本的查字典的邏輯
class Text2Ids:
def __init__(self) -> None:
self.table: Dict[str, int] = {
"hello": 0,
"world": 1,
"[UNK]": 2,
}

def lookup(self, word: str)
return self.table.get(word, 2)

def __call__ (self, words: List[str])
return [self.lookup(w) for w in words]
  1. 編寫 Pipeline
import matx

class WorkFlow:
def __init__(self):
# 此處會進行代碼編譯,Python 代碼自動編譯封裝為 Callable 對象
self.text2ids = matx.script(Text2Ids)()

def process(self, texts):
ids = self.text2ids(texts)
return ids

# test
handler = WorkFlow()
print(handler.process("hello world unknown"))
# output: [0, 1, 2]
  1. Trace 導出到 磁盤
# dump
mod = matx.trace(handler.process, "hello world")
print(mod.run({"texts": "hello world"}))
mod.save('./my_dir')
# load
mod = matx.load('./my_dir', -1)
print(mod.run({"texts": "hello world"}))
  1. C++ 加載
#include <string>
#include <vector>
#include <map>
#include <iostream>
#include <matxscript/pipeline/tx_session.h>
using namespace ::matxscript::runtime;
int main()
{
// test case
std::unordered_map<std::string, RTValue> feed_dict;
feed_dict.emplace("texts", Unicode(U"hello world"));
std::vector<std::pair<std::string, RTValue>> result;
const char* module_path = "./my_dir";
const char* module_name = "model.spec.json";
{
// -1 mean cpu
auto sess = TXSession::Load(module_path, module_name, -1);
auto result = sess->Run(feed_dict);
for (auto& r : result) {
std::cout << "key: " << r.first << ", value: " << r.second << std::endl;
}
}
return 0;
}

完整的代碼見:https://github.com/bytedance/matxscript/tree/main/examples/text2ids

小結:以上是一個非常簡單的純 Python 實現(xiàn)的預處理邏輯,且能被一段通用的 C++ 代碼加載運行,下面我們結合模型展示一個實際的多模態(tài)端到端案例!

五. 多模態(tài)案例

此處以圖文多模態(tài)(Bert+Resnet)為例,模型使用 PyTorch 編寫,展示訓練和部署中實際的工作。

  1. 配置環(huán)境
    a. 配置 gcc/cuda 等基礎設施(通常是運維同學已經(jīng)搞定)
    b. 安裝 MATXScript 及基于此開發(fā)的基礎庫(text、vision等)
  2. 編寫模型代碼
    a. 此處省略,大家可以參考論文或其他開源實現(xiàn)自行搞定
  3. 編寫預處理代碼

    a. text

from typing import List, Dict, Tuple
import libcut
import matx
class Vocabulary:
...
def utf8_decoder(s: List[bytes]):
return [x.decode() for x in s]
class TextNDArrayBuilder:
...
class TextPipeline:
def __init__(self, mode: str = "eval"):
self.mode = mode
self.cut_engine = libcut.Cutter('/path/to/cut_models', ...)
self.vocab = matx.script(Vocabulary)('/path/to/vocab.txt')
self.decoder = matx.script(utf8_decoder)
self.input_builder = matx.script(TextNDArrayBuilder)(self.vocab)
def process(self, text: List[bytes]):
# List[bytes] 是對齊 C++ 的 vector<string>
text: List[str] = self.decoder(text)
words: List[List[str]] = self.cut_engine(text)
batch_ids: List[List[int]] = self.vocab(words)
input_ids, segment_ids, mask_ids = self.input_builder(batch_ids, 32)
if self.mode == "train":
return input_ids.torch(), segment_ids.torch(), mask_ids.torch()
return input_ids, segment_ids, mask_ids

    b. vision

from typing import List, Dict, Tuple
import matx
from matx import vision
class VisionPipeline:
def __init__(self,
device_id: int = 0,
mode: str = "eval",
image_size: int = 224,):
self.is_training = mode == 'train'
self.mode = mode
...
def process(self, image,):
if self.is_training:
decode_nds = self.random_crop_decode(image)
flip_nds = self.random_flip(decode_nds)
resize_nds = self.resize(flip_nds)
transpose_nd = self.transpose_norm(resize_nds, vision.SYNC)
else:
decode_nds = self.decode(image)
resize_nds = self.resize(decode_nds)
crop_nds = self.center_crop(resize_nds)
transpose_nd = self.transpose_norm(crop_nds, vision.SYNC)
if self.mode == "trace":
return transpose_nd
return transpose_nd.torch()
  1. 接入 DataLoader
    a. TextPipeline 可以當成一個正常的 Python Class 接入 Dataset 即可
    b. VisionPipeline 涉及到 GPU 預處理,更適合按 batch 進行處理,需要自己單獨構造一個 DataLoader(這里埋個點,之后會開源字節(jié)跳動內部基于多線程的 DataLoader)
  2. 加上模型代碼,開始訓練吧
  3. 導出端到端的 Inference Model
class MultimodalEvalPipeline:
def __init__(self):
self.text_pipe = TextPipeline(mode="eval", ...)
self.vision_pipe = VisionPipeline(mode="eval", ...)
self.torch_model = torch.jit.load('/path/to/multimodal.jit', map_locatinotallow='cuda:0')
self.tx_model_op = matx.script(self.torch_model, device=0)

def eval(self, texts: List[bytes], images: List[bytes])
input_ids, segment_ids, mask_ids = self.text_pipe.process(texts)
images = self.vision_pipe.process(images)
scores = self.tx_model_op(input_ids, segment_ids, mask_ids, images)
return scores
# examples
example_batch_size = 8
text_examples = ['hello, world'.encode()] * example_batch_size
with open('/path/image.jpg', 'rb') as f:
image_example = f.read()
image_examples = [image_example] * example_batch_size
# pipeline instance
pipe = MultimodalEvalPipeline(...)
mod = matx.trace(pipe.eval, text_examples, image_examples)
# test
print(mod.run({"texts": text_examples, "images": image_examples}))
# save
mod.save('/path/to/my_multimodal')

小結:經(jīng)過以上步驟,我們即可完成端到端的訓練&發(fā)布工作,且整個過程是純 Python 代碼完成的,可以完全由算法同學自己控制。當然,如果模型計算本身還有性能問題,也是可以在背后通過自動改圖優(yōu)化工作完成。

注:完整代碼示例見 https://github.com/bytedance/matxscript/tree/main/examples/e2e_multi_modal

六. 統(tǒng)一Server

在上個章節(jié),我們得到了一個算法同學發(fā)布的模型包,本章節(jié)論述如果用統(tǒng)一的服務進行加載和運行。

完整的 Server 包括:IDL 協(xié)議、Batching 策略、進/線程調度和排布、模型推理...

這里,我們只討論模型推理這塊,其他的都是可以按約定開發(fā)即可。我們以一個 main 函數(shù)來示例模型加載和運行的過程:

#include <string>
#include <vector>
#include <map>
#include <iostream>
#include <matxscript/pipeline/tx_session.h>
using namespace ::matxscript::runtime;
int main()
{
// test case
std::unordered_map<std::string, RTValue> feed_dict;
feed_dict.emplace("texts", List({String("hello world")}));
feed_dict.emplace("images", List({String("......")}));
std::vector<std::pair<std::string, RTValue>> result;
const char* module_path = "/path/to/my_multimodal";
const char* module_name = "model.spec.json";
{
// cuda:0
auto sess = TXSession::Load(module_path, module_name, 0);
auto result = sess->Run(feed_dict);
for (auto& r : result) {
std::cout << "key: " << r.first << ", value: " << r.second << std::endl;
}
}
return 0;
}

以上代碼就是最簡單的一個 C++ 加載多模態(tài)模型的案例,對 Server 開發(fā)的同學來說,只需進行簡單的抽象和約定,即可把上述代碼改造成一個統(tǒng)一的 C++ 模型服務框架。

七. 更多信息

我們是字節(jié)跳動-AML-機器學習系統(tǒng)團隊,致力于為公司提供統(tǒng)一的高性能訓推一體化框架,同時也會通過火山引擎機器學習平臺服務于合作企業(yè),火山引擎機器學習平臺預計 2023 年起提供 MATX 的相關支持,包括預置鏡像環(huán)境、常用場景的公開樣例、企業(yè)接入和使用過程中的技術保障等,可以達到訓練和推理場景低成本加速和一體化的效果。歡迎在 https://www.volcengine.com/product/ml-platform 詳細了解我們的產(chǎn)品。

責任編輯:龐桂玉 來源: 字節(jié)跳動技術團隊
相關推薦

2021-09-06 11:15:05

數(shù)據(jù)治理字節(jié)跳動埋點

2023-11-20 07:27:00

云原生Spark

2022-10-14 14:44:04

字節(jié)跳動ByteTechHTTP 框架

2024-11-26 19:29:35

2022-11-24 10:01:10

架構分布式

2025-09-10 09:59:52

2017-08-21 07:50:18

EasyStackOpenStack部署

2024-06-07 14:01:29

2023-12-01 17:42:10

2013-05-16 10:02:43

SaaS云計算部署

2013-05-22 09:40:57

大規(guī)模部署SaaSSaaS

2013-05-14 13:30:08

部署SaaS云計算

2022-06-02 16:58:06

Ray機器學習字節(jié)

2018-02-27 08:39:47

圖譜數(shù)據(jù)存儲

2022-07-07 11:00:09

美團模型實踐

2014-08-13 16:41:13

瞻博網(wǎng)絡OpenContraiSDN

2023-05-09 18:45:28

監(jiān)控監(jiān)視工具

2023-12-01 17:46:31

數(shù)據(jù)庫技術

2023-06-28 08:23:41

搜索語義模型
點贊
收藏

51CTO技術棧公眾號

黄色软件在线观看| 日产精品久久久久久久| 国产电影一区二区三区爱妃记| 2022国产精品视频| 国产精品免费视频久久久| 在线观看黄网址| 国产精品乱战久久久| 91成人在线精品| 色一情一乱一乱一区91| 天天干天天干天天干| 免费在线成人网| 色综合久久88色综合天天看泰| 国产精品无码一区二区三区免费 | 国产精品久久久久久在线| 最新成人av网站| 久久网福利资源网站| 中文字幕在线免费看线人| 久久久久亚洲精品中文字幕| 日本韩国一区二区| 青草视频在线观看视频| 日本中文在线观看| 久久女同精品一区二区| αv一区二区三区| 一区二区视频网| 亚洲欧美日韩国产| 欧美极品少妇xxxxⅹ免费视频| 亚洲а∨天堂久久精品2021| 国产精品一线| 日韩精品一区二区三区在线播放| 中文字幕在线导航| 亚洲伊人av| 亚洲大片精品永久免费| 久久久99精品视频| 色开心亚洲综合| 国产丝袜欧美中文另类| 噜噜噜噜噜久久久久久91| 亚洲精品中文字幕成人片| 国产一区二区久久| 国产欧美日韩精品在线观看| 在线观看亚洲黄色| 免费在线亚洲欧美| 欧美在线观看网站| 成人午夜视频精品一区| 91久久亚洲| 亚洲在线视频一区| 一本色道久久综合亚洲91| 日韩精品另类天天更新| 亚洲av成人精品一区二区三区在线播放 | 亚洲一区二区三区影院| 国产树林野战在线播放| 日本欧美在线视频免费观看| 国产精品毛片高清在线完整版| 欧美一区激情视频在线观看| 国产h在线观看| 国产日韩一级二级三级| 日韩国产高清一区| 成人网视频在线观看| 国产日韩av一区二区| 秋霞在线观看一区二区三区| 成年女人的天堂在线| 欧美国产精品一区| 麻豆中文字幕在线观看| www免费视频观看在线| 亚洲激情一二三区| 欧美高清中文字幕| 国产高清自产拍av在线| 欧美日韩免费在线| 一区二区在线播放视频| 日韩成人在线电影| 日韩欧美专区在线| 国产又粗又猛又色| 九九视频精品全部免费播放| 伊人久久久久久久久久久久久| 999福利视频| 欧美a级一区| 7777免费精品视频| 成人黄色三级视频| 激情综合色丁香一区二区| 91丝袜脚交足在线播放| 天堂网av2014| 亚洲国产精品t66y| 97在线免费视频观看| 密臀av在线播放| 欧美午夜精品理论片a级按摩| av在线免费看片| 欧美电影在线观看免费| 伊人久久久久久久久久久久久| 人妻久久一区二区| 亚洲在线成人| 成人中文字幕在线观看| 内射后入在线观看一区| 国产欧美日韩在线观看| 日本美女爱爱视频| 韩漫成人漫画| 日韩女同互慰一区二区| 制服 丝袜 综合 日韩 欧美| 亚洲精品国产成人影院| 91高清视频免费观看| 影音先锋黄色网址| 99久免费精品视频在线观看| 亚洲午夜激情| 亚洲妇女成熟| 精品少妇一区二区三区在线播放| 91精品人妻一区二区| 亚洲国产精品久久久天堂| 国产91精品久| 国产婷婷在线视频| 国产亚洲精品精华液| 日韩黄色片在线| 午夜无码国产理论在线| 精品国产免费久久| www深夜成人a√在线| 久久资源在线| 极品日韩久久| 欧美另类tv| 欧美另类一区二区三区| 99久久久无码国产精品性| 国产精品99免费看| 成人中心免费视频| 亚洲成人三级| 在线中文字幕一区| 伊人网伊人影院| 亚洲精华国产欧美| 国产精品国产三级欧美二区| 岛国成人毛片| 欧美久久免费观看| 在线视频第一页| 欧美亚洲在线| 久久国产精品久久| 91老司机福利在线| 日韩免费福利电影在线观看| а天堂中文在线资源| 免费亚洲视频| 欧美日产一区二区三区在线观看| 九色porny丨首页入口在线| 欧美一区二区三区四区五区| 极品美妇后花庭翘臀娇吟小说| 免费观看一级特黄欧美大片| 免费成人看片网址| 国偷自产一区二区免费视频 | 精品久久久久久中文字幕人妻最新| 亚洲理论电影网| 95av在线视频| 在线中文字幕-区二区三区四区| 欧美精品一二三| 国产喷水在线观看| 激情成人综合网| 成人在线免费观看网址| 国产亚洲亚洲国产一二区| 久久精品91久久香蕉加勒比 | 国产mv日韩mv欧美| 成人在线视频一区二区三区| 国产精品一区免费在线 | 国产成人自拍在线| 日b视频免费观看| 大型av综合网站| 91成人在线播放| 日韩a级作爱片一二三区免费观看| 欧美日韩在线免费| 精品人伦一区二区三电影 | 国产精品视频专区| 欧美精品hd| 日韩小视频在线观看专区| 欧美日韩国产精品一区二区三区| 国产91精品一区二区| 国产素人在线观看| 国产精品最新| 成人激情视频小说免费下载| 18视频在线观看| 亚洲国产日韩欧美综合久久| 久久久久久少妇| 国产精品丝袜一区| 亚洲国产欧美日韩在线| 99亚洲伊人久久精品影院红桃| 欧美精品一区二区三区久久| 欧美成人一二区| 欧美激情免费在线| 精品欧美不卡一区二区在线观看| 欧美日韩免费不卡视频一区二区三区 | 一区二区高清视频在线观看| 波多野结衣视频播放| 久久先锋资源| ijzzijzzij亚洲大全| 精品少妇一区| 国产精品影院在线观看| 青春草在线免费视频| 亚洲天堂第二页| www.com在线观看| 欧美午夜影院在线视频| 2025国产精品自拍| 91麻豆文化传媒在线观看| 日本高清久久久| 9国产精品视频| 自拍偷拍一区二区三区| 日本一道高清一区二区三区| 91精品国产自产在线观看永久| 国产伦子伦对白在线播放观看| 永久免费毛片在线播放不卡| 你懂的网站在线| 91精品啪在线观看国产60岁| 日韩免费av片| 亚洲视频一区二区在线观看| 香蕉视频黄色在线观看| 国产成人三级在线观看| 欧美三级理论片| 亚洲免费大片| 免费日韩在线观看| 四季av在线一区二区三区| 蜜桃传媒视频第一区入口在线看| 精品91福利视频| 国产精品福利在线观看| 成人在线黄色电影| 欧美精品午夜视频| 一区二区三区视频在线观看视频| 亚洲精品国产精品久久清纯直播| 国产精品羞羞答答在线| 日本韩国欧美一区二区三区| 黄色激情视频在线观看| 亚洲黄色免费电影| 黑人操日本美女| 国产精品福利影院| 色欲狠狠躁天天躁无码中文字幕| aaa亚洲精品| 国产精品嫩草69影院| 韩国精品在线观看| 久久久久国产一区| 视频一区在线视频| 国产男女无遮挡| 99人久久精品视频最新地址| 成人免费网站入口| 激情久久五月| 国产经典久久久| 欧美有码视频| 91精品国产吴梦梦| 欧美成人久久| av日韩在线看| 欧美精品一区二区三区久久久竹菊| 一区在线电影| 久久久国产精品| 一区二区在线观| 亚洲区综合中文字幕日日| 26uuu成人| 久久久久久久久久久久久久久久久久 | 亚洲第一区色| 国产免费黄色一级片| 精久久久久久| 男人揉女人奶房视频60分| 国产欧美日韩亚洲一区二区三区| 欧美日韩在线一| 国产精品色网| aaa毛片在线观看| 日韩av在线发布| 亚州精品一二三区| 精品一区二区三区视频 | 久久亚洲综合色| 亚洲男人天堂古典| 久久国产精品系列| 色综合夜色一区| 天干夜夜爽爽日日日日| 在线国产亚洲欧美| 一区二区 亚洲| 欧美一区二区高清| 蜜桃视频在线观看www| 亚洲国产中文字幕久久网| 色资源在线观看| 国产亚洲人成a一在线v站| 91caoporn在线| 欧美猛交免费看| 国产夫妻在线播放| 国产精品美女久久| 亚洲第一二区| 久久一区免费| 久久国产精品亚洲人一区二区三区| 一区二区冒白浆视频| 午夜精品亚洲| 777米奇影视第四色| 免费精品视频在线| 久久精品无码专区| 国产亚洲精品资源在线26u| 99久久精品久久亚洲精品| 亚洲一区二区三区视频在线| 亚洲天堂视频网站| 在线播放中文字幕一区| 欧日韩在线视频| 国产香蕉精品视频一区二区三区| 国产乱色在线观看| 8x海外华人永久免费日韩内陆视频| 欧美精品高清| 国产伦精品一区二区三区免费视频 | 性欧美freesex顶级少妇| 国产视频999| 日韩av网址大全| 五月天综合婷婷| 欧美亚洲视频| 佐佐木明希电影| 日本一二三四高清不卡| 四虎成人精品永久免费av| 欧美视频精品在线| 天堂av一区二区三区| 久久精品国产亚洲| av综合电影网站| 亚洲自拍偷拍福利| 欧美日韩有码| 国产一区二区在线视频播放| 精一区二区三区| 欧美多人猛交狂配| 亚洲二区在线观看| 国产剧情久久久| 国产一区二区动漫| 国产高清自产拍av在线| 91九色极品视频| 成人午夜国产| 无码人妻丰满熟妇区毛片18| 国产福利91精品一区二区三区| 日本一区二区视频在线播放| 婷婷一区二区三区| www.精品久久| 久久精品在线视频| 国产人妖一区| 日韩视频在线观看国产| 国产精品毛片| 91精品又粗又猛又爽| 一区二区三区国产精品| 国产又粗又猛又爽又黄91| 亚洲性视频网站| 高清不卡亚洲| 日本成人三级| 亚洲综合二区| 中文字幕乱码在线| 亚洲va欧美va天堂v国产综合| 国产suv一区二区| 超碰97人人做人人爱少妇| 巨大黑人极品videos精品| 日本精品二区| 日韩av中文字幕一区二区 | 五月婷婷开心中文字幕| 欧美激情在线观看视频| 日韩一区二区三区高清在线观看| 国产又黄又爽免费视频| 狠狠色2019综合网| 久草视频手机在线| 欧美一区二区三区成人| 在线观看小视频| 99精品国产高清一区二区| 一区二区三区国产精华| 宇都宫紫苑在线播放| 亚洲美女区一区| 精品人妻伦一二三区久久| 色在人av网站天堂精品| 国产一区二区三区不卡av| 国产96在线 | 亚洲| 99综合电影在线视频| 国产精品视频免费播放| 亚洲欧美另类中文字幕| 欧美色片在线观看| 综合久久国产| 国产精品一区二区在线观看网站| 九九热精品免费视频| 欧美精品一区二区蜜臀亚洲| 高端美女服务在线视频播放| 麻豆一区区三区四区产品精品蜜桃| 久久中文在线| 中文字幕电影av| 亚洲精品一区二区三区蜜桃下载 | 欧美私模裸体表演在线观看| 91社区在线| 999国内精品视频在线| 在线看片欧美| 国产精久久一区二区三区| 欧美日韩国产大片| 欧洲一区二区三区| 美女被啪啪一区二区| 久久精品国产精品亚洲红杏| 久草国产在线观看| 日韩精品免费在线视频| 成人午夜一级| 国产免费裸体视频| 久久精品视频在线看| 国产三级精品在线观看| 性亚洲最疯狂xxxx高清| 青青草成人影院| 波多野结衣中文字幕在线播放| 激情成人中文字幕| 秋霞午夜在线观看| 国模精品娜娜一二三区| 另类调教123区| 国产第一页在线播放| 在线精品高清中文字幕| 51亚洲精品| 亚洲综合日韩欧美| 无码av免费一区二区三区试看| 永久免费在线观看视频| 韩国成人av| 国产在线精品视频| 久久99国产综合精品免费| 久久夜色精品亚洲噜噜国产mv| 婷婷综合成人| 亚洲欧美激情一区二区三区| 欧美伊人久久久久久久久影院| caoprom在线|