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

歡迎訪(fǎng)問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

【大数据】Presto开发自定义聚合函数

發(fā)布時(shí)間:2024/1/18 编程问答 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【大数据】Presto开发自定义聚合函数 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

Presto 在交互式查詢(xún)?nèi)蝿?wù)中擔(dān)當(dāng)著重要的職責(zé)。隨著越來(lái)越多的人開(kāi)始使用 SQL 在 Presto 上分析數(shù)據(jù),我們發(fā)現(xiàn)需要將一些業(yè)務(wù)邏輯開(kāi)發(fā)成類(lèi)似 Hive 中的 UDF,提高 SQL 使用人員的效率,同時(shí)也保證 Hive 和 Presto 環(huán)境中的 UDF 統(tǒng)一。

1、Presto函數(shù)介紹

在此之前先簡(jiǎn)單介紹下UDF和UDAF,UDF叫做用戶(hù)自定義函數(shù),而UDAF叫做用戶(hù)自定義聚合函數(shù),區(qū)別就在于UDF不會(huì)保存狀態(tài),一行輸入一行輸出,而UDAF會(huì)涉及到狀態(tài)的保存,通過(guò)聚合多個(gè)節(jié)點(diǎn)的數(shù)據(jù)來(lái)轉(zhuǎn)換為最終的輸出結(jié)果。

在 Presto 中,函數(shù)大體分為三種:scalar,aggregation 和 window 類(lèi)型。分別如下:

1)scalar標(biāo)量函數(shù),簡(jiǎn)單來(lái)說(shuō)就是 Java 中的一個(gè)靜態(tài)方法,本身沒(méi)有任何狀態(tài)(不保存數(shù)據(jù),一行輸入一行輸出)。

2)aggregation累積狀態(tài)的函數(shù),或聚集函數(shù),如count,avg。如果只是單節(jié)點(diǎn),單機(jī)狀態(tài)可以直接用一個(gè)變量存儲(chǔ)即可,但是presto是分布式計(jì)算引擎,狀態(tài)數(shù)據(jù)會(huì)在多個(gè)節(jié)點(diǎn)之間傳輸,因此狀態(tài)數(shù)據(jù)需要被序列化成 Presto 的內(nèi)部格式才可以被傳輸。簡(jiǎn)單來(lái)說(shuō)Aggregation對(duì)應(yīng)于多行輸入一行輸出。

3)window 窗口函數(shù),窗口函數(shù)在查詢(xún)結(jié)果的行上進(jìn)行計(jì)算,執(zhí)行順序在HAVING子句之后,ORDER BY子句之前。在 Presto SQL 中,窗口函數(shù)的語(yǔ)法形式如下:

windowFunction(arg1,....argn) OVER([PARTITION BY<...>] [ORDER BY<...>] [RANGE|ROWS BETWEEN AND])

窗口函數(shù)語(yǔ)法由關(guān)鍵字OVER觸發(fā),且包含三個(gè)子句:
PARTITION BY: 指定輸入行分區(qū)的規(guī)則,類(lèi)似于聚合函數(shù)的GROUP BY子句,不同分區(qū)里的計(jì)算互不干擾(窗口函數(shù)的計(jì)算是并發(fā)進(jìn)行的,并發(fā)數(shù)和partition數(shù)量一致),缺省時(shí)將所有數(shù)據(jù)行視為一個(gè)分區(qū)
ORDER BY: 決定了窗口函數(shù)處理輸入行的順序
RANGE|ROWS BETWEEN AND: 指定窗口邊界,不常用,缺省時(shí)的窗口為當(dāng)前行所在的分區(qū)第一行到當(dāng)前行。

2、自定義函數(shù)

官方文檔地址:https://prestodb.io/docs/current/develop/functions.html

2.1自定義Scalar函數(shù)的實(shí)現(xiàn)

2.1.1定義一個(gè)java類(lèi)
1)用 @ScalarFunction 的 Annotation 標(biāo)記實(shí)現(xiàn)業(yè)務(wù)邏輯的靜態(tài)方法。

2)用 @Description 描述函數(shù)的作用,這里的內(nèi)容會(huì)在 SHOW FUNCTIONS 中顯示。

3)用@SqlType 標(biāo)記函數(shù)的返回值類(lèi)型,如返回字符串,因此是 StandardTypes.VARCHAR。

4)Java 方法的返回值必須使用 Presto 內(nèi)部的序列化方式,因此字符串類(lèi)型必須返回 Slice, 使用 Slices.utf8Slice 方法可以方便的將 String 類(lèi)型轉(zhuǎn)換成 Slice 類(lèi)型

public class ExampleStringFunction {@ScalarFunction("lowercaser")@Description("converts the string to alternating case")@SqlType(StandardTypes.VARCHAR)public static Slice lowercaser(@SqlType(StandardTypes.VARCHAR) Slice slice){String argument = slice.toStringUtf8();return Slices.utf8Slice(argument.toLowerCase());} }

2.2 自定義Aggregation函數(shù)

2.2.1實(shí)現(xiàn)原理步驟
Presto 把 Aggregation 函數(shù)分解成三個(gè)步驟執(zhí)行:

1、input(state, data): 針對(duì)每條數(shù)據(jù),執(zhí)行 input 函數(shù)。這個(gè)過(guò)程是并行執(zhí)行的,因此在每個(gè)有數(shù)據(jù)的節(jié)點(diǎn)都會(huì)執(zhí)行,最終得到多個(gè)累積的狀態(tài)數(shù)據(jù)。

2、combine(state1, state2):將所有節(jié)點(diǎn)的狀態(tài)數(shù)據(jù)聚合起來(lái),多次執(zhí)行,直至所有狀態(tài)數(shù)據(jù)被聚合成一個(gè)最終狀態(tài),也就是 Aggregation 函數(shù)的輸出結(jié)果。

3、output(final_state, out):最終輸出結(jié)果到一個(gè) BlockBuilder。

2.2.2 具體代碼實(shí)現(xiàn)過(guò)程
1、定義一個(gè) Java 類(lèi),使用 @AggregationFunction 標(biāo)記為 Aggregation 函數(shù)

2、使用 @InputFunction、 @CombineFunction、@OutputFunction 分別標(biāo)記計(jì)算函數(shù)、合并結(jié)果函數(shù)和最終輸出函數(shù)在 Plugin 處注冊(cè) Aggregation 函數(shù)

3、一個(gè)繼承AccumulatorState的State接口,get和set方法

4、并使用 @AccumulatorStateMetadata 提供序列化(stateSerializerClass指定)和 Factory 類(lèi)信息(stateFactoryClass指定)。自己寫(xiě)一個(gè)序列化類(lèi)和一個(gè)工廠(chǎng)類(lèi)。(復(fù)雜數(shù)據(jù)類(lèi)型需要:自定義類(lèi)保存狀態(tài)、Map、List等)

簡(jiǎn)單類(lèi)型Aggregation

對(duì)于簡(jiǎn)單數(shù)據(jù)類(lèi)型的聚合函數(shù)編寫(xiě)比較簡(jiǎn)單,實(shí)現(xiàn)一個(gè)包含input、combine、output的aggregation和一個(gè)狀態(tài)設(shè)定接口State提供get、set方法即可,不用去關(guān)心序列化和狀態(tài)保存問(wèn)題。
Aggregation:

@AggregationFunction("avg") public final class IntervalYearToMonthAverageAggregation {private IntervalYearToMonthAverageAggregation() {}@InputFunctionpublic static void input(LongAndDoubleState state, @SqlType(StandardTypes.INTERVAL_YEAR_TO_MONTH) long value){state.setLong(state.getLong() + 1);state.setDouble(state.getDouble() + value);}@CombineFunctionpublic static void combine(LongAndDoubleState state, LongAndDoubleState otherState){state.setLong(state.getLong() + otherState.getLong());state.setDouble(state.getDouble() + otherState.getDouble());}@OutputFunction(StandardTypes.INTERVAL_YEAR_TO_MONTH)public static void output(LongAndDoubleState state, BlockBuilder out){long count = state.getLong();if (count == 0) {out.appendNull();}else {double value = state.getDouble();INTERVAL_YEAR_MONTH.writeLong(out, round(value / count));}} }

LongAndDoubleState :寫(xiě)一個(gè)接口實(shí)現(xiàn)繼承自AccumulatorState類(lèi),提供get、set方法即可。

public interface LongAndDoubleStateextends AccumulatorState {long getLong();void setLong(long value);double getDouble();void setDouble(double value); }

復(fù)雜類(lèi)型Aggregation

對(duì)于復(fù)雜數(shù)據(jù)類(lèi)型則需要提供序列化機(jī)制,你要序列化那些東西都是由你來(lái)制指定的。在AccumulatorState的接口上用注解指定@AccumulatorStateMetadata 提供序列化(stateSerializerClass指定)和 Factory 類(lèi)信息(stateFactoryClass指定),自定義一個(gè)序列化器和序列化工廠(chǎng)類(lèi),實(shí)現(xiàn)類(lèi)的序列化和反序列化。

Aggregation類(lèi): 這個(gè)類(lèi)實(shí)現(xiàn)比較簡(jiǎn)單,和簡(jiǎn)單數(shù)據(jù)類(lèi)型的實(shí)現(xiàn)一樣,input、combine、output。

@AggregationFunction("presto_collect") public class CollectListAggregation {@InputFunctionpublic static void input(@AggregationState CollectState state, @SqlType(StandardTypes.VARCHAR) Slice id,@SqlType(StandardTypes.VARCHAR) Slice key) {try {CollectListStats stats = state.get();if (stats == null) {stats = new CollectListStats();state.set(stats);}int inputId = Integer.parseInt(id.toStringUtf8());String inputKey = key.toStringUtf8();stats.addCollectList(inputId,inputKey, 1);} catch (Exception e) {throw new RuntimeException(e+" --------- input err");}}@CombineFunctionpublic static void combine(@AggregationState CollectState state, CollectState otherState) {try {CollectListStats collectListStats = state.get();CollectListStats oCollectListStats = otherState.get();if(collectListStats == null) {state.set(oCollectListStats);} else {collectListStats.mergeWith(oCollectListStats);}}catch (Exception e) {throw new RuntimeException(e+" --------- combine err");}}@OutputFunction(StandardTypes.*VARCHAR*)public static void output(@AggregationState CollectState state, BlockBuilder out) {try {CollectListStats stats = state.get();if (stats == null) {out.appendNull();return;}// 統(tǒng)計(jì)Slice result = stats.getCollectResult();if (result == null) {out.appendNull();} else {VarcharType.VARCHAR.writeSlice(out, result);}} catch (Exception e) {throw new RuntimeException(e+" -------- output err");}} }

狀態(tài)保存接口:

@AccumulatorStateMetadata(stateSerializerClass = CollectListStatsSerializer.class, stateFactoryClass = CollectListStatsFactory.class) public interface CollectState extends AccumulatorState {CollectListStats get();void set(CollectListStats value); }

存放數(shù)據(jù)的類(lèi):此類(lèi)需要實(shí)現(xiàn)數(shù)據(jù)的序列化和反序列化,這是最關(guān)鍵和比較麻煩的地方,貼一個(gè)例子,關(guān)鍵在于需要自己控制存儲(chǔ)空間以及數(shù)據(jù)的順序,和讀取的時(shí)候按照一定順序讀取。對(duì)于字符要先存儲(chǔ)長(zhǎng)度,然后是字節(jié),讀取則先讀取字符長(zhǎng)度,然后讀取這么長(zhǎng)的數(shù)據(jù),最后轉(zhuǎn)化為字符。

public class CollectListStats {private static final int INSTANCE_SIZE = ClassLayout.parseClass(CollectListStats.class).instanceSize();//<id,<key,value>>private Map<Integer,Map<String,Integer>> collectContainer = new HashMap<>();private long contentEstimatedSize = 0;private int keyByteLen = 0;private int keyListLen = 0;CollectListStats() {}CollectListStats(Slice serialized) {deserialize(serialized);}void addCollectList(Integer id, String key, int value) {if (collectContainer.containsKey(id)) {Map<String, Integer> tmpMap = collectContainer.get(id);if (tmpMap.containsKey(key)) {tmpMap.put(key, tmpMap.get(key)+value);}else{tmpMap.put(key,value);contentEstimatedSize += ( key.getBytes().length + SizeOf.SIZE_OF_INT*);keyByteLen += key.getBytes().length;keyListLen++;}} else {Map<String,Integer> tmpMap = new HashMap<String,Integer>();tmpMap.put(key, value);keyByteLen += key.getBytes().length;keyListLen++;collectContainer.put(id, tmpMap);contentEstimatedSize += SizeOf.SIZE_OF_INT;}}//[{id:1,{"aaa":3,"fadf":6},{}]Slice getCollectResult() {Slice jsonSlice = null;try {StringBuilder jsonStr = new StringBuilder();jsonStr.append("[");int collectLength = collectContainer.entrySet().size();for (Map.Entry<Integer, Map<String, Integer>> mapEntry : collectContainer.entrySet()) {Integer id = mapEntry.getKey();Map<String, Integer> vMap = mapEntry.getValue();jsonStr.append("{id:").append(id).append(",{");int vLength = vMap.entrySet().size();for (Map.Entry<String, Integer> vEntry : vMap.entrySet()) {String key = vEntry.getKey();Integer value = vEntry.getValue();jsonStr.append(key).append(":").append(value);vLength--;if (vLength != 0) {jsonStr.append(",");}}jsonStr.append("}");collectLength--;if (collectLength != 0) {jsonStr.append(",");}}jsonStr.append("]");jsonSlice = Slices.utf8Slice*(jsonStr.toString());} catch (Exception e) {throw new RuntimeException(e+" ---------- get CollectResult err");}return jsonSlice;}public void deserialize(Slice serialized) {try {SliceInput input = serialized.getInput();//外層map的長(zhǎng)度int collectStatsEntrySize = input.readInt();for (int collectCnt = 0; collectCnt < collectStatsEntrySize; collectCnt++) {int id = input.readInt();int keyEntrySize = input.readInt();for (int idCnt = 0; idCnt < keyEntrySize; idCnt++) {int keyBytesLen = input.readInt();byte[] keyBytes = new byte[keyBytesLen];for (int byteIdx = 0; byteIdx < keyBytesLen; byteIdx++) {keyBytes[byteIdx] = input.readByte();}String key = new String(keyBytes);int value = input.readInt();addCollectList(id, key, value);}}} catch (Exception e) {throw new RuntimeException(e+" ----- deserialize err");}}public Slice serialize() {SliceOutput builder = null;int requiredBytes = //對(duì)應(yīng) SliceOutput builder append的內(nèi)容所占用的空間SizeOf.SIZE_OF_INT*3 //id entry數(shù)目,id數(shù)值,key Entry數(shù)目\+ keyListLen * SizeOf.SIZE_OF_INT* //key bytes長(zhǎng)度\+ keyByteLen* //key byte總長(zhǎng)度\+ keyListLen * SizeOf.SIZE_OF_INT; //valuetry {// 序列化builder = Slices.*allocate*(requiredBytes).getOutput();for (Map.Entry<Integer,Map<String, Integer>> entry : collectContainer.entrySet()) {//id個(gè)數(shù)builder.appendInt(collectContainer.entrySet().size());//id 數(shù)值builder.appendInt(entry.getKey());Map<String, Integer> kMap = entry.getValue();builder.appendInt(kMap.entrySet().size());for (Map.Entry<String, Integer> vEntry : kMap.entrySet()) {byte[] keyBytes = vEntry.getKey().getBytes();builder.appendInt(keyBytes.length);builder.appendBytes(keyBytes);builder.appendInt(vEntry.getValue());}}return builder.getUnderlyingSlice();} catch (Exception e) {throw new RuntimeException(e+" ---- serialize err requiredBytes = " + requiredBytes + " keyByteLen= " + keyByteLen + " keyListLen = " + keyListLen);}}long estimatedInMemorySize() {return INSTANCE_SIZE + contentEstimatedSize;}void mergeWith(CollectListStats other) {if (other == null) {return;}for (Map.Entry<Integer,Map<String, Integer>> cEntry : other.collectContainer.entrySet()) {Integer id = cEntry.getKey();Map<String, Integer> kMap = cEntry.getValue();for (Map.Entry<String, Integer> kEntry : kMap.entrySet()) {addCollectList(id, kEntry.getKey(), kEntry.getValue());}}} }

上面的例子我是直接從別人那兒拿過(guò)來(lái)的(個(gè)人比較懶:https://www.cnblogs.com/lrxvx/p/12558902.html),實(shí)際方式也很簡(jiǎn)單,就是實(shí)現(xiàn)序列化和反序列化方法以及一個(gè)管理存儲(chǔ)空間的方法。需要注意的是序列化和反序列化時(shí)候的順序一定要保證,Presto提供了許多屬性方式的選項(xiàng)如int、long、byte,對(duì)于String方式序列化,可以將String轉(zhuǎn)為byte再進(jìn)行序列化,思路就是先序列化一個(gè)長(zhǎng)度進(jìn)去,再將字節(jié)內(nèi)容序列化,反序列化的時(shí)候先讀length,再讀相應(yīng)的字節(jié)內(nèi)容轉(zhuǎn)為String就好了,而對(duì)象類(lèi)型的屬性,本質(zhì)上還是可以直接序列化屬性,反序列化時(shí)候重新創(chuàng)建對(duì)象,內(nèi)容沒(méi)變。Presto的序列化方式比較高效,原因是因?yàn)槲铱梢灾恍蛄谢蚁胍膶傩跃秃昧?#xff0c;缺點(diǎn)是擴(kuò)展性不足。

序列化類(lèi):

public class CollectListStatsSerializer implements AccumulatorStateSerializer<CollectState> {@Overridepublic Type getSerializedType() {return VARBINARY;}@Overridepublic void serialize(CollectState state, BlockBuilder out) {if (state.get() == null) {out.appendNull();} else {VARBINARY.writeSlice(out, state.get().serialize());}}@Overridepublic void deserialize(Block block, int index, CollectState state) {state.set(new CollectListStats(VARBINARY.getSlice(block, index)));} }

序列化工廠(chǎng)類(lèi):

public class CollectListStatsFactory implements AccumulatorStateFactory<CollectState> {@Overridepublic CollectState createSingleState() {return new SingleState();}@Overridepublic Class<? extends CollectState> getSingleStateClass() {return SingleState.class;}@Overridepublic CollectState createGroupedState() {return new GroupState();}@Overridepublic Class<? extends CollectState> getGroupedStateClass() {return GroupState.class;}public static class GroupState implements GroupedAccumulatorState, CollectState {private static final int INSTANCE_SIZE = ClassLayout.parseClass(GroupedDigestAndPercentileState.class).instanceSize();private final ObjectBigArray<CollectListStats> collectStatsList = new ObjectBigArray<>();private long size;private long groupId;@Overridepublic void setGroupId(long groupId) {this.groupId = groupId;}@Overridepublic void ensureCapacity(long size) {collectStatsList.ensureCapacity(size);}@Overridepublic CollectListStats get() {return collectStatsList.get(groupId);}@Overridepublic void set(CollectListStats value) {CollectListStats previous = get();if (previous != null) {size -= previous.estimatedInMemorySize();}collectStatsList.set(groupId, value);size += value.estimatedInMemorySize();}@Overridepublic long getEstimatedSize() {return INSTANCE_SIZE +size + collectStatsList.sizeOf();}}public static class SingleState implements CollectState{private CollectListStats stats;@Overridepublic CollectListStats get() {return stats;}@Overridepublic void set(CollectListStats value) {stats = value;}@Overridepublic long getEstimatedSize() {if (stats == null) {return 0;}return stats.estimatedInMemorySize();}} }

驗(yàn)證自定義函數(shù)

當(dāng)我們開(kāi)發(fā)好自定義函數(shù)后如何驗(yàn)證呢,一種方式是使用Presto內(nèi)置函數(shù)注冊(cè)機(jī)制進(jìn)行單元測(cè)試,Presto 函數(shù)由MetadataManager中的FunctionRegistry進(jìn)行管理,開(kāi)發(fā)的函數(shù)要生效必須要先注冊(cè)到FunctionRegistry中。函數(shù)注冊(cè)是在 Presto 服務(wù)啟動(dòng)過(guò)程中進(jìn)行的,有以下兩種方式進(jìn)行函數(shù)注冊(cè)。

FunctionListBuilder builder = new FunctionListBuilder().window(RowNumberFunction.class).aggregate(ApproximateCountDistinctAggregation.class).scalar(RepeatFunction.class).function(MAP_HASH_CODE)......

注冊(cè)好之后就可以編寫(xiě)相應(yīng)的單元測(cè)試代碼了。完整的Aggregation測(cè)試代碼如下:

import com.facebook.presto.common.type.Type; import com.facebook.presto.metadata.FunctionAndTypeManager; import com.facebook.presto.metadata.FunctionListBuilder; import com.facebook.presto.metadata.MetadataManager; import com.facebook.presto.operator.aggregation.InternalAggregationFunction; import io.airlift.slice.Slice; import io.airlift.slice.Slices; import org.testng.annotations.BeforeClass; import org.testng.annotations.Test;import static com.facebook.presto.block.BlockAssertions.createSlicesBlock; import static com.facebook.presto.common.type.VarcharType.VARCHAR; import static com.facebook.presto.operator.aggregation.AggregationTestUtils.assertAggregation; import static com.facebook.presto.sql.analyzer.TypeSignatureProvider.fromTypes;public class TestAggregation{private static final FunctionAndTypeManager FUNCTION_AND_TYPE_MANAGER = MetadataManager.createTestMetadataManager().getFunctionAndTypeManager();private static InternalAggregationFunction getAggregation(Type... arguments){return FUNCTION_AND_TYPE_MANAGER.getAggregateFunctionImplementation(FUNCTION_AND_TYPE_MANAGER.lookupFunction("presto_collect", fromTypes(arguments)));}private static final InternalAggregationFunction COLLECTION_AGGREGATION = getAggregation(VARCHAR, VARCHAR); //和Aggregation中的類(lèi)型對(duì)應(yīng),java類(lèi)型的Slice對(duì)應(yīng)Varchar@BeforeClasspublic void init(){FunctionListBuilder builder = new FunctionListBuilder().aggregate(CollectListAggregation.class);FUNCTION_AND_TYPE_MANAGER.registerBuiltInFunctions(builder.getFunctions());}@Testpublic void collectionAggregationTest(){String result="xxx"; //你期望的aggregation結(jié)果Slice str1= Slices.utf8Slice("x");Slice str2= Slices.utf8Slice("y");assertAggregation(COLLECTION_AGGREGATION,result,createSlicesBlock(str1, str2),createSlicesBlock(str1, str2));} }

標(biāo)量函數(shù)單元測(cè)試

而對(duì)于標(biāo)量函數(shù)scalar的測(cè)試略有不同,示例如下:

public class TestBitwiseFunctionsextends AbstractTestFunctions {@Testpublic void testBitCount(){assertFunction("bit_count(0, 64)", BIGINT, 0L); //bit_count為標(biāo)量函數(shù)名,傳參,參數(shù)如果為String則用單引號(hào),參數(shù)類(lèi)型,期望結(jié)果} }

當(dāng)然進(jìn)行單元測(cè)試后,我們期望到真實(shí)的庫(kù)中去驗(yàn)證,內(nèi)置函數(shù)滿(mǎn)足不了使用需求時(shí),就需要自行開(kāi)發(fā)函數(shù)來(lái)拓展函數(shù)庫(kù)。開(kāi)發(fā)者自行編寫(xiě)的拓展函數(shù)一般通過(guò)插件的方式進(jìn)行注冊(cè)。PluginManager在安裝插件時(shí)會(huì)調(diào)用插件的getFunctions()方法,將獲取到的函數(shù)集合通過(guò)MetadataManager的addFunctions方法進(jìn)行注冊(cè):

public class ExampleFunctionsPluginimplements Plugin {@Overridepublic Set<Class<?>> getFunctions(){return ImmutableSet.<Class<?>>builder().add(ExampleNullFunction.class).add(IsNullFunction.class).add(IsEqualOrNullFunction.class).add(ExampleStringFunction.class).add(ExampleAverageFunction.class).build();} }

Presto 函數(shù)的注冊(cè)機(jī)制,新增和修改函數(shù)后,必須要重啟服務(wù)才能生效,所以目前還不支持真正的用戶(hù)自定義函數(shù)。插件函數(shù)進(jìn)行注冊(cè)之后,在resource下創(chuàng)建META-INF/services目錄,并創(chuàng)建文件名為com.facebook.presto.spi.Plugin的文件,并添加內(nèi)容:

xxx.xxx.xxx.ExampleFunctionsPlugin

然后利用presto的插件打包,此時(shí)會(huì)在target目錄下生成zip文件,把xxx.zip解壓到${PRESTOHOME}/plugin,重啟presto服務(wù)即可進(jìn)行驗(yàn)證。

總的來(lái)說(shuō),Presto的UDF和UDAF開(kāi)發(fā)總結(jié)為一張圖:

注意:各個(gè)版本的Presto源碼有所不同,遇到類(lèi)不正確的對(duì)版本進(jìn)行調(diào)整,上面是用的Presto版本為0.264,更多的參考Presto的官方源碼https://github.com/prestodb/presto,而對(duì)于Persto的分組聚合查詢(xún)流程可以參見(jiàn):Presto中的分組聚合查詢(xún)流程

總結(jié)

以上是生活随笔為你收集整理的【大数据】Presto开发自定义聚合函数的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

免费视频久久久 | 久久91久久久久麻豆精品 | 在线色网站 | 深爱激情综合 | 亚洲香蕉在线观看 | 激情欧美一区二区免费视频 | 午夜视频在线观看欧美 | 六月色婷婷| 亚洲国产精品一区二区尤物区 | 香蕉成人在线视频 | 日韩欧美综合视频 | 91在线视频导航 | 一本一道久久a久久综合蜜桃 | 丁香资源影视免费观看 | 黄色精品视频 | 亚洲高清色综合 | 97电影在线观看 | 免费在线一区二区三区 | 久久国产电影院 | 日韩精品三区四区 | 国产精品永久免费 | 精品视频久久久久久 | 在线免费中文字幕 | 99久久超碰中文字幕伊人 | 久久久国产成人 | 亚洲va欧美va| 少妇高潮流白浆在线观看 | 成人视屏免费看 | 91在线精品观看 | 国产麻豆精品95视频 | 亚洲国产免费网站 | 波多野结衣在线观看一区 | 亚洲 欧洲av| 五月天中文字幕 | 日韩中文字幕第一页 | 国产区av在线 | 欧美精品一区二区性色 | 在线免费性生活片 | 日韩视频中文字幕 | 99免费精品| 亚洲日本va中文字幕 | 中文字幕在线观看视频网站 | 午夜精品久久久99热福利 | 在线观看视频免费播放 | 国产精品第52页 | 亚洲午夜av | 福利视频一二区 | 91中文在线视频 | 国产群p | av高清网站在线观看 | 久久在线免费观看 | 国产午夜小视频 | 国产小视频免费在线网址 | 日本久久久精品视频 | 午夜美女av | 日日操天天操夜夜操 | 日韩在线三区 | 激情影音先锋 | 国内揄拍国内精品 | 中文字幕一区二区在线播放 | 久久久精品一区二区 | 欧美日韩3p | 一区二区三区中文字幕在线观看 | www.五月天婷婷.com | 亚洲人人av| 韩国av三级 | 日韩av在线看 | 免费黄a| 一级特黄av | 久久99国产精品自在自在app | 国产精品欧美激情在线观看 | 视频成人免费 | 亚洲黄色a | 日韩av美女| 日韩久久久久久久久久 | 日韩视 | 91视频大全| 欧美激情视频一区二区三区免费 | av在线8| 天天av资源| 中文字幕在线播放日韩 | 99视频在线精品国自产拍免费观看 | 欧美日韩国产综合网 | 波多野结衣在线中文字幕 | 五月婷婷在线视频观看 | 91精彩视频在线观看 | 一区二区视频播放 | 日韩黄色大片在线观看 | 国产无遮挡又黄又爽在线观看 | 欧美高清成人 | 国产精品久久久久久久久久东京 | 99热这里精品 | 在线免费黄色片 | av线上免费看 | 天天干天天做 | 国产午夜精品一区二区三区欧美 | 91成版人在线观看入口 | 国产麻豆成人传媒免费观看 | 91视频免费| 久久国语 | 成人免费xxxxxx视频 | av中文字幕网址 | 黄色在线观看免费 | 精品国产乱码久久久久久三级人 | 久久视频在线看 | 国产精品亚洲成人 | 免费在线播放 | 夜夜夜夜猛噜噜噜噜噜初音未来 | 蜜臀av夜夜澡人人爽人人桃色 | 亚洲三区在线 | 四虎永久免费在线观看 | 黄色在线观看www | 久久久久亚洲天堂 | 在线天堂亚洲 | 亚洲一区二区三区毛片 | 国产99久久精品一区二区300 | 婷婷在线视频 | 日韩精品一区二区三区免费观看 | 久久久久久久久久久久久久免费看 | 超碰人人做 | 91亚色视频在线观看 | 久久久久国产精品免费网站 | 97成人在线观看视频 | 午夜精品电影 | 精品国产三级a∨在线欧美 免费一级片在线观看 | 国产色网站 | 成人av日韩 | 亚洲视频 一区 | 99久久精品午夜一区二区小说 | 天天干天天操天天 | 五月婷婷在线综合 | 国产免费又粗又猛又爽 | 四虎视频 | av日韩在线网站 | 亚洲国产精品一区二区尤物区 | 免费网站黄色 | 成年人免费观看国产 | 久久黄色片| 午夜精品视频一区二区三区在线看 | 亚洲最新av在线 | 中文国产成人精品久久一 | 日韩在线视频观看免费 | 久久黄色影视 | 色婷丁香 | 成人四虎影院 | 国产精品久久久久久麻豆一区 | 亚洲视频 中文字幕 | 成人网色 | 成人9ⅰ免费影视网站 | 精品久久1 | 久草视频在线观 | 亚洲成人午夜av | 精品国产一区二区三区久久影院 | 丁香婷婷激情五月 | 又色又爽又黄 | 在线观看黄色 | 久久天天拍| 亚洲精品乱码久久久久久按摩 | av在线官网| 美女视频免费精品 | a天堂中文在线 | 午夜精品三区 | 特级毛片爽www免费版 | 五月婷婷在线观看视频 | 日韩一区二区三 | 2021国产精品视频 | 天天看天天干 | 久久久官网| 97国产视频 | 欧美国产91 | 国产精品嫩草69影院 | 四虎成人精品永久免费av | 色久天 | 亚洲天堂激情 | 亚洲九九九在线观看 | 在线观看国产区 | 亚洲视频1区2区 | 美女搞黄国产视频网站 | 香蕉视频在线免费看 | 免费看三级黄色片 | 久草在线资源免费 | 亚洲人成人天堂h久久 | 99精品国产在热久久下载 | 五月婷婷视频 | 亚洲午夜精品福利 | 国产高清专区 | 91 在线视频播放 | 黄色小网站在线观看 | 精品国产一区二区三区噜噜噜 | 欧美日韩亚洲在线观看 | 91视频com | 日韩av一区二区三区在线观看 | 国产亚洲精品久久久久久 | 久久九精品 | 麻豆精品视频在线观看免费 | 久久99婷婷 | 日韩专区一区二区 | 久久电影中文字幕视频 | 中文字幕日韩一区二区三区不卡 | 亚洲经典中文字幕 | 伊人色**天天综合婷婷 | 香蕉视频在线网站 | 992tv在线| 日韩欧美xxx| 午夜久久影视 | 99视频导航 | 国产精品视频地址 | 国产精品网红直播 | 免费男女羞羞的视频网站中文字幕 | 国产视频 亚洲视频 | 国产一区二区在线免费观看 | 国产精品人成电影在线观看 | 精品一区二区在线免费观看 | 日韩在线欧美在线 | 国产在线视频一区二区 | 97超碰人人澡人人爱 | 久久久久久久久久久免费av | 成人av影视在线 | 午夜精品久久久久久久爽 | japanesefreesexvideo高潮 | 99r国产精品 | 操久在线 | 中文字幕精品一区二区三区电影 | 亚洲国产高清在线观看视频 | 久久久午夜精品福利内容 | 久久精品99国产精品亚洲最刺激 | 免费观看一级成人毛片 | 国产日韩精品在线 | 女人高潮特级毛片 | 午夜999| 亚洲人成人天堂h久久 | 丁香激情综合久久伊人久久 | 国产免费久久久久 | 国产黄影院色大全免费 | 香蕉在线视频观看 | 999久久久免费视频 午夜国产在线观看 | 国产色视频网站 | 西西444www大胆高清视频 | 伊人一级 | 在线观看91精品视频 | 中文字幕大全 | 在线观看视频亚洲 | www.久久久久| 国产视频一区二区在线观看 | 一区 二区电影免费在线观看 | 成人av在线资源 | 蜜臀久久99静品久久久久久 | 欧美xxxxx在线视频 | 黄色精品网站 | 日韩va亚洲va欧美va久久 | 免费观看黄色av | 久久免费视频在线观看6 | 久久国产系列 | 久久久久久黄色 | 日本久久成人中文字幕电影 | 永久黄网站色视频免费观看w | 99视频在线精品 | 免费三级网 | 91av精品| 在线观看一级视频 | wwwwwww黄 | av免费在线观看网站 | 国产精品嫩草影视久久久 | 日韩亚洲国产精品 | 日韩黄色软件 | 久草在线网址 | 91久久丝袜国产露脸动漫 | 福利视频网址 | 一区二区成人国产精品 | 久久久www免费电影网 | 亚洲美女精品区人人人人 | 天天射天天爱天天干 | 成人91在线 | 亚洲国产精品99久久久久久久久 | 国产资源在线播放 | 国产视频不卡 | 国产黄色资源 | www看片网站 | 日韩在线无 | 伊人资源视频在线 | 国产精品手机视频 | 在线亚洲成人 | www.少妇| 视频直播国产精品 | 午夜电影av | 国产这里只有精品 | 激情影院在线 | 欧美日韩久 | 久久tv视频 | 国产高清精 | 欧美综合色在线图区 | 国产专区视频 | 麻豆久久 | 中文字幕免费高 | 亚洲国产免费网站 | 在线观看黄a | 在线观看av的网站 | 17videosex性欧美 | 日本精品一区二区三区在线观看 | 婷婷精品视频 | 天天做日日做天天爽视频免费 | 五月开心婷婷 | 色婷婷国产精品 | 日韩精品免费一区二区 | 国产一级一级国产 | 国产精品免费一区二区 | 在线观看日韩av | 一区二区视频网站 | 国产精品美女999 | 成人亚洲综合 | 午夜精品导航 | 岛国大片免费视频 | av中文字幕第一页 | 日韩精品一区二区三区第95 | 亚洲精品播放 | 天天天干天天射天天天操 | 青青草久草在线 | 精品国产区在线 | 国产字幕在线看 | 亚洲成人资源在线观看 | 天天干天天碰 | 美女在线观看av | 免费av在线网站 | www国产亚洲| 国精产品永久999 | 中文字幕在线看视频 | 去看片| 国产.精品.日韩.另类.中文.在线.播放 | 精品国产一区二区三区噜噜噜 | 国产高清在线免费视频 | 狠狠地日 | 日日干干夜夜 | 色综合久久88色综合天天6 | 久久免费美女视频 | 一区二区毛片 | 成年人在线看片 | 久久久久国 | 久久看毛片 | 日韩在线观看a | 九九九九热精品免费视频点播观看 | 国产亚洲精品久久久久久大师 | 韩国av免费| 久草热久草视频 | 最新精品国产 | 探花视频在线观看免费 | 欧美性色综合 | 久久精品高清 | 亚洲经典中文字幕 | 欧美激情精品久久久久 | 国产精品久久久久久久久毛片 | 日日干日日色 | 91男人影院 | 有码中文在线 | 人人射人人澡 | 日韩a欧美 | 欧美 日韩 性 | 国产韩国日本高清视频 | 91麻豆福利 | 91精品久久久久 | 精品国产伦一区二区三区 | 亚洲精品久久在线 | 日本大片免费观看在线 | 91桃色视频| 中文字幕在线国产精品 | 99精品在线 | 亚洲国产精品电影 | 国产午夜精品福利视频 | 国产色道 | 视频一区二区免费 | 狠狠激情中文字幕 | 欧美久久99 | 四虎小视频 | 欧美精品亚洲二区 | 国产视频1区2区 | 超碰97人人在线 | 亚洲人成在线观看 | 91精品蜜桃 | 国产精品美女视频网站 | 日韩网站视频 | 日本午夜在线亚洲.国产 | 久久艹影院 | 婷婷射五月| 狠狠操夜夜操 | www国产亚洲精品久久麻豆 | 国产精品久久久久永久免费观看 | 日韩三级一区 | 国产成人三级一区二区在线观看一 | 精品国产成人在线 | 九九热免费观看 | 国产91综合一区在线观看 | 国产又黄又爽又猛视频日本 | 久久久久二区 | 成人黄色小说网 | 亚洲激情网站免费观看 | 日本一区二区不卡高清 | 在线观看蜜桃视频 | 天天操天天操天天操天天操天天操 | 天天综合五月天 | 毛片网免费 | av性网站| 91福利视频免费 | 久久久久久久久影视 | 亚洲码国产日韩欧美高潮在线播放 | 成人综合日日夜夜 | 久久精品一二三区白丝高潮 | 欧美日韩国产二区 | 色综合夜色一区 | 日韩有码中文字幕在线 | 91免费观看国产 | 五月婷婷视频在线 | 丝袜+亚洲+另类+欧美+变态 | 久久久久成人免费 | 成人全视频免费观看在线看 | 黄网站免费大全入口 | 手机在线欧美 | 久久一区二区三区超碰国产精品 | 天堂网在线视频 | av理论电影 | 青青草国产精品 | 午夜丁香网 | 日韩a在线看 | 国产精品久久精品 | 婷婷激情站 | 久久精品99国产精品酒店日本 | 国产精品久久久777 成人手机在线视频 | 美女一区网站 | 有码一区二区三区 | 久久久免费在线观看 | 中文字幕高清 | 激情婷婷综合网 | 中文字幕综合在线 | 天天爽天天爽夜夜爽 | 国产色网| 黄色av观看 | 福利av影院 | 天天操天天操 | 91av视频观看 | 国产一区二区三区 在线 | 久久精品屋 | 亚洲精品在线观看av | 国产精品亚洲视频 | 欧美日韩免费观看一区二区三区 | 久久成人黄色 | 精品久久久久久亚洲综合网站 | 欧美日韩精品在线视频 | 国产在线欧美日韩 | 久久久久亚洲精品中文字幕 | 日韩激情网 | 国产理伦在线 | 久久国产影视 | 欧美福利久久 | 91福利专区 | 久久99国产精品二区护士 | 国产成人一区二区三区 | 国产精品久久久久一区二区国产 | 国产精品久久久久久吹潮天美传媒 | 国产手机视频精品 | 一区二区视频在线观看免费 | 激情五月播播久久久精品 | 国产高清 不卡 | 欧美成人在线网站 | 公开超碰在线 | 婷婷国产精品 | 日韩成人xxxx | 在线91网| 一区二区三区免费在线观看视频 | 91看片淫黄大片一级在线观看 | 国产日韩欧美在线观看 | av电影 一区二区 | 久久99国产精品视频 | 国产福利91精品一区二区三区 | 久草资源在线 | 午夜婷婷在线播放 | 久久久久日本精品一区二区三区 | 一级免费看视频 | www色com| 亚洲激情视频 | 男女激情网址 | 免费在线观看视频a | 国产一级久久 | 91大神一区二区三区 | 欧美午夜视频在线 | 天天干天天做 | 亚洲一级片免费观看 | 日韩一区二区免费在线观看 | 国产永久免费高清在线观看视频 | 精品久久九九 | 亚洲精品乱码久久 | 天天摸日日摸人人看 | 国产成人一区二区三区久久精品 | 精品在线观看一区二区三区 | 国产一区二区视频在线播放 | 国产精品精品久久久久久 | 国产在线中文字幕 | 国产一级片一区二区三区 | 波多野结衣在线视频免费观看 | 精品麻豆入口免费 | 婷婷婷国产在线视频 | 久久亚洲精品电影 | 天天看天天干 | 免费69视频 | 久久久久亚洲精品国产 | 国产精品女同一区二区三区久久夜 | 亚洲精品视频网 | 中文字幕在线观看不卡 | 99免费看片 | 亚洲精品在线视频播放 | 91久久精品一区二区二区 | 色www免费视频| 国产一区自拍视频 | 97高清视频 | 日韩在线大片 | 69人人| 中文字幕乱码亚洲精品一区 | 亚洲午夜精品一区二区三区电影院 | 91最新地址永久入口 | av在线播放网址 | 91在线小视频 | 国产黄色精品 | 91精品久久久久久 | 超碰人人干人人 | 国产精品无av码在线观看 | 国产精品久久久久久999 | 国产欧美日韩精品一区二区免费 | 日韩免费| 国产精成人品免费观看 | 国产另类av| 狠狠插狠狠操 | 国产精品h在线观看 | 亚洲精品网站 | 日韩黄色一区 | 婷婷深爱 | 亚洲欧美乱综合图片区小说区 | 日韩在线高清 | 日本在线h | av电影一区| av成人免费观看 | 99久久久久免费精品国产 | 国产色婷婷精品综合在线手机播放 | 在线视频一二三 | 亚洲视屏在线播放 | 精品久久精品久久 | 亚洲综合在线五月天 | 国产精品美女久久久久aⅴ 干干夜夜 | 天天爱天天舔 | 国产精品99久久久精品免费观看 | 麻豆一精品传二传媒短视频 | 中文字幕乱码在线播放 | 国产精品五月天 | 国产精品久久久久久久免费大片 | 亚洲精品电影在线 | 亚洲视频一| a v在线观看 | 欧美另类xxxx | 日韩成人黄色 | 99久久999久久久精玫瑰 | 天天色婷婷 | 亚洲成av人影院 | 91入口在线观看 | 国产不卡一二三区 | 91福利视频免费观看 | 成人三级网站在线观看 | 国产色视频一区 | 超碰国产人人 | a视频在线 | 91在线麻豆| 国产欧美综合视频 | 欧美成年性 | 色婷婷成人网 | 最新精品国产 | 欧美一区在线观看视频 | 99久久综合狠狠综合久久 | 欧美做受69 | 啪啪资源 | 免费看黄网站在线 | 日韩区视频 | japanesexxxhd奶水| 伊人影院av | 国产精品99久久久精品 | 99精品国产一区二区三区不卡 | 91在线91 | 91九色自拍 | 日韩av影视在线观看 | 日本黄色免费电影网站 | 国产一区二区三区网站 | 四虎影视8848aamm | 国产福利一区二区三区视频 | 夜夜澡人模人人添人人看 | av福利在线 | 欧美日韩激情网 | 亚洲一区网 | 亚州av网站大全 | 99麻豆久久久国产精品免费 | 久久官网| 在线观看av小说 | 中文字幕中文字幕在线中文字幕三区 | 国产一级黄色免费看 | 精品国产乱码久久久久久三级人 | 97干com| 99精品免费久久久久久久久日本 | 美国人与动物xxxx | 国产精品18久久久 | 国产成人精品一区二区三区网站观看 | 成人黄色电影免费观看 | 日韩av男人的天堂 | 久久久久麻豆v国产 | 成人黄色一级视频 | 国产夫妻性生活自拍 | 国产成人av一区二区三区在线观看 | 亚洲一级片av | 丁香视频免费观看 | 精品欧美乱码久久久久久 | 九九久久国产 | 久久综合五月天 | 国产最新视频在线 | 国产精品久久久久久高潮 | 亚洲天堂精品视频在线观看 | 久久电影网站中文字幕 | 免费在线观看黄 | 西西大胆免费视频 | 免费在线观看a v | 国产精品美女在线 | 亚洲一区日韩精品 | 亚洲 中文 在线 精品 | 中文永久字幕 | 免费人人干 | 人人干人人草 | 日日夜精品 | 亚洲国产欧美在线看片xxoo | 国产精品一区二区在线观看 | 欧美精品久久久久久久久久丰满 | 日韩在线视 | 粉嫩高清一区二区三区 | 五月婷婷丁香在线观看 | 超碰伊人网 | 日韩中文字幕91 | 少妇性bbb搡bbb爽爽爽欧美 | 综合色站导航 | 亚洲黄色app | 国产一线在线 | 国产一级大片在线观看 | 成年人黄色av | 中文字幕在线视频一区 | 色婷婷欧美 | 99电影 | 日韩超碰 | 综合网五月天 | 欧美精品一区二区在线播放 | 99久久99久久精品 | 国产亚洲欧美一区 | 99综合久久| 日本久草电影 | 久久国内视频 | 国产精品久久一卡二卡 | 久久免费视频观看 | 国产在线看一区 | 国内久久精品 | 日韩欧美一区二区在线 | 91麻豆精品国产91久久久久 | 亚洲精品国产精品国自产 | 91av视频免费在线观看 | 中文字幕在线色 | 97视频在线观看成人 | 日韩在线网址 | 热久久这里只有精品 | 亚洲天堂网在线观看视频 | 国产精品欧美久久久久天天影视 | 毛片精品免费在线观看 | 丁香婷婷激情五月 | 九九在线视频免费观看 | 色九色| 亚洲色图22p| 国产精品网站 | av大全在线播放 | 婷婷色在线观看 | 夜夜骑首页 | 久草国产精品 | 999久久a精品合区久久久 | 国产精品中文字幕在线播放 | 免费久久99精品国产 | 成人久久久久久久久久 | 免费在线国产精品 | 国产精品理论视频 | 91在线精品播放 | 天天天插 | 色爱区综合激月婷婷 | 国产尤物在线视频 | a色网站| 国产精品一区二区三区久久久 | 99成人精品| 欧美俄罗斯性视频 | 午夜12点| 日本激情动作片免费看 | 在线精品视频免费观看 | 国产资源精品在线观看 | 99视频免费在线观看 | 亚洲精品福利在线观看 | 久久久久久久久久影视 | 国产老太婆免费交性大片 | 波多野结衣视频一区二区三区 | 天堂视频中文在线 | 国产综合香蕉五月婷在线 | 丰满少妇久久久 | 最新国产一区二区三区 | 亚洲91视频| 久草在线久草在线2 | 欧美俄罗斯性视频 | 超碰精品在线 | 国产999| 免费在线观看a v | 97色免费视频| 久久欧洲视频 | 一区二区三区不卡在线 | 天天操天天能 | 欧美综合久久 | 国产美女黄网站免费 | 97视频免费在线观看 | 一区二区三区免费在线观看视频 | 在线免费观看视频一区 | 伊人久久精品久久亚洲一区 | 亚洲成aⅴ人片久久青草影院 | 色久网 | 国产成年免费视频 | 久久av中文字幕片 | 亚洲综合少妇 | 最近的中文字幕大全免费版 | 国产精品久久久久久久久久东京 | 探花视频免费在线观看 | 婷婷六月丁香激情 | 激情网站网址 | 日本中文字幕免费观看 | 99久久久久国产精品免费 | 成人在线观看av | 亚洲黄色精品 | 激情欧美网 | 又黄又爽又无遮挡的视频 | 福利电影一区二区 | 成人h电影在线观看 | 狠狠干综合| 欧美成人a在线 | 国产在线观看av | 国产在线欧美日韩 | 亚洲黄色软件 | 欧美一级小视频 | 国产大片黄色 | 狠狠操狠狠干天天操 | 久久1区| 深爱婷婷久久综合 | 国产精品成人一区二区三区吃奶 | 一区二区三区免费播放 | 久久精品一区二区三 | 美女视频免费精品 | 在线观看岛国 | 啪啪动态视频 | 欧美日韩免费观看一区=区三区 | 国产精品久久99 | 综合网天天色 | 一二三四精品 | 日韩精品一区二区三区不卡 | 天天视频色版 | 亚洲国产中文字幕 | 欧美国产一区在线 | 久久福利剧场 | 国产麻豆成人传媒免费观看 | 91在线www | 免费看黄电影 | 日韩理论片在线观看 | 亚州国产精品久久久 | 成人中心免费视频 | 国产在线2020| 久久6精品 | 激情五月激情综合网 | 亚洲男男gaygayxxxgv | 亚洲精品456在线播放第一页 | 成人a毛片 | 狠狠躁日日躁狂躁夜夜躁av | 久久精品香蕉视频 | av官网| 操老逼免费视频 | 欧美精品久久久久久久久久丰满 | 久久婷五月 | 欧美一区三区四区 | 91视频下载 | 久久久国产精品亚洲一区 | 日本在线观看一区二区 | www日韩精品 | 97香蕉久久国产在线观看 | 日韩电影中文字幕在线 | 免费观看完整版无人区 | 天天操天天干天天综合网 | 亚洲专区欧美专区 | 天天鲁一鲁摸一摸爽一爽 | 91av在线播放视频 | 亚洲国产中文在线观看 | 亚洲精品女人久久久 | 午夜精品久久久久久久久久 | 一级黄色视屏 | 日产av在线播放 | 亚洲午夜av久久乱码 | 欧美日韩一区二区久久 | 日韩一区二区三区免费视频 | 三级av网| 亚洲美女视频在线观看 | 成人一级在线观看 | 国产黄色看片 | 亚洲深夜影院 | 一本一本久久a久久精品综合妖精 | 五月婷婷激情综合网 | 日韩欧美在线中文字幕 | 国产精品久久久久久久电影 | 456免费视频 | 91精品国产综合久久婷婷香蕉 | 色com网 | 黄色毛片视频免费观看中文 | 免费网站看av片 | 亚洲一区日韩 | 久久免费看av | 亚洲精品自在在线观看 | 夜色资源站国产www在线视频 | 色在线中文字幕 | 超碰日韩 | 国产原创av在线 | 久久久在线观看 | 黄色一级在线免费观看 | 国产亚洲综合性久久久影院 | 精品国产乱码久久久久久1区2匹 | 国产99精品| ,午夜性刺激免费看视频 | 国产香蕉久久精品综合网 | 97理论片 | 一区二区三区日韩在线观看 | 色综合久| 亚洲闷骚少妇在线观看网站 | 98福利在线| 一区二区三区四区久久 | 久热久草在线 | 国产成人黄色 | 91视频在线免费看 | 麻豆91在线 | 久久视屏网| 午夜国产一区二区三区四区 | 激情av一区二区 | 狠狠干狠狠色 | 久久深爱网 | 久久草| 日韩有码在线播放 | 91av在线看| 91chinese在线| 一区免费观看 | 中文乱幕日产无线码1区 | 中文字幕国产一区二区 | 国产一区视频在线观看免费 | 久久影视中文字幕 | 三级黄色大片在线观看 | 综合网天天 | 日韩在线观看视频网站 | 国产综合视频在线观看 | 亚洲视频高清 | 99亚洲国产精品 | 日韩电影在线观看一区二区 | a v在线观看 | 免费又黄又爽视频 | 超碰个人在线 | 国产黄色精品在线观看 | 天天摸天天舔 | 色综合天天在线 | 免费观看的黄色片 | 中文字幕欧美日韩va免费视频 | 国产69精品久久久久99 | 国产成人99久久亚洲综合精品 | 免费中文字幕 | 一区二精品 | 中文av网站| www.天天干| 久久深夜福利免费观看 | 中文字幕在线观看视频免费 | 日韩成人免费在线观看 | 免费在线观看亚洲视频 | 在线免费观看羞羞视频 | 在线观看精品黄av片免费 | 国产玖玖在线 | 96国产在线 | 特级黄色视频毛片 | 国产拍揄自揄精品视频麻豆 | 成人av久久 | 夜夜干天天操 | 午夜黄色一级片 | 啪啪av在线| av播放在线 | 国产在线观看免费av | 亚洲精品国产精品国自产 | 国产精品国产自产拍高清av | 98精品国产自产在线观看 | 久久精品99国产精品日本 | 91在线播放国产 | 日韩免费区 | 国产在线精品一区二区三区 | av888av.com | 久久久国产成人 | 国内丰满少妇猛烈精品播放 | 久久免费看 | 国产亚洲精品无 | 欧美精品网站 | 五月天久久 | 欧洲视频一区 | 中文字幕专区高清在线观看 | 精品电影一区二区 | 午夜视频一区二区三区 | 日日日日 | www.黄色网.com | 国产精品伦一区二区三区视频 | 91精品视频免费观看 | 亚洲精品视频在线看 | 五月天综合色 | 亚洲精品视频在 | 九九在线国产视频 | 欧美极度另类性三渗透 | 日韩在线观看高清 | 久久久久久黄色 | 久久国产成人午夜av影院潦草 | 国产成人免费观看 | 欧美日韩一区二区久久 | 国产成人黄色网址 | 日韩黄色在线电影 | 一区二区国产精品 | 亚洲国产精品成人综合 | 久久一区二区免费视频 | 国产亚洲精品美女 | 最新国产精品拍自在线播放 | 国产美女精品人人做人人爽 | 99r在线精品| 又黄又爽又湿又无遮挡的在线视频 | 五月婷婷,六月丁香 | 日韩av综合网站 | 亚洲精品字幕 | 欧美污污网站 | 狠狠色狠狠色综合日日小说 | 国产不卡免费视频 | 激情开心站| 不卡的av| 国产精品免费在线播放 | 成人一区影院 | 精品99在线观看 | 久久精品影片 | 国产高清视频在线播放 | 在线观看精品一区 | 永久免费av在线播放 | 麻豆影视在线免费观看 | 国产精品久久久久久久久久久久午 | 国产麻豆精品久久一二三 | 91精品日韩 | 亚洲美女免费精品视频在线观看 | 亚洲精品在线观看免费 | 国产亚洲精品久久久久久久久久久久 | 97国产在线播放 | 啪啪肉肉污av国网站 | 国产高清99 | 亚洲男模gay裸体gay | 久久成人午夜 | 国产精品24小时在线观看 | 九色激情网 | 人人爽人人插 | 国内精品久久影院 | 黄色在线网站噜噜噜 | 超碰在线网 | 久一久久| 在线播放 日韩专区 | 中国一区二区视频 | 国产精品v欧美精品v日韩 | 成人小视频在线免费观看 | 美女网色 | 久草视频资源 | 亚洲精品www久久久久久 | 狠狠色丁香久久婷婷综合丁香 | 天堂网av 在线 | 亚洲网久久| 日韩欧美视频一区二区 | 片网站| 亚洲国产大片 | 91喷水 | 日免费视频 | 日韩在线视频国产 | 中文字幕 婷婷 | 六月丁香婷婷久久 | a视频免费在线观看 | 国内精品在线一区 | 国产精品美女久久久久久久网站 | 日韩av影片在线观看 | 97精品国产97久久久久久粉红 | 亚洲狠狠婷婷综合久久久 | 日韩一区精品 | 国产色道 | 涩av在线 | 精品美女久久久久久免费 | 成人在线一区二区三区 | 国产视频精选 | 国产午夜精品一区二区三区 | 奇米影视8888在线观看大全免费 |