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

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

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

6、HIVE JDBC开发、UDF、体系结构、Thrift服务器、Driver、元数据库Metastore、数据库连接模式、单/多用户模式、远程服务模式、Hive技术原理解析、优化等(整理的笔记)

發(fā)布時(shí)間:2024/9/27 数据库 37 豆豆

目錄:
5 HIVE開(kāi)發(fā)
5.1 Hive JDBC開(kāi)發(fā)
5.2 Hive UDF
6 Hive的體系結(jié)構(gòu)
6.2 Thrift服務(wù)器
6.3 Driver
6.4 元數(shù)據(jù)庫(kù)Metastore
6.5 數(shù)據(jù)庫(kù)連接模式
6.5.1 單用戶模式
6.5.2 多用戶模式
6.5.3 遠(yuǎn)程服務(wù)模式
7 Hive技術(shù)原理解析
7.1 Hive工作原理
7.2.1 Hive編譯器的組成
7.2.2 Query Compiler
7.2.3新版本Hive也支持Tez或Spark作為執(zhí)行引擎
8 Hive優(yōu)化

5 HIVE開(kāi)發(fā)

5.1 Hive JDBC開(kāi)發(fā)

若想進(jìn)行Hive JDBC的開(kāi)發(fā),需要開(kāi)啟HiveServer2服務(wù),這里要參考第二章節(jié)的”連接方式”中的HiveServer2/beeline章節(jié)。

其中一個(gè)Hive JDBC的案例如下:

啟動(dòng)完HiveServer2服務(wù),就提供JDBC服務(wù)了,類(lèi)似:

import java.sql.SQLException; import java.sql.Connection; import java.sql.ResultSet; import java.sql.Statement; import java.sql.DriverManager;public class HiveJdbcClient {private static String driverName = "org.apache.hive.jdbc.HiveDriver";/*** @param args* @throws SQLException*/public static void main(String[] args) throws SQLException {try {Class.forName(driverName);} catch (ClassNotFoundException e) {// TODO Auto-generated catch blocke.printStackTrace();System.exit(1);}//replace "hive" here with the name of the user the queries should run asConnection con = DriverManager.getConnection("jdbc:hive2://localhost:10000/default", "hive", "");Statement stmt = con.createStatement();String tableName = "testHiveDriverTable";stmt.execute("drop table if exists " + tableName);stmt.execute("create table " + tableName + " (key int, value string)");// show tablesString sql = "show tables '" + tableName + "'";System.out.println("Running: " + sql);ResultSet res = stmt.executeQuery(sql);if (res.next()) {System.out.println(res.getString(1));}// describe tablesql = "describe " + tableName;System.out.println("Running: " + sql);res = stmt.executeQuery(sql);while (res.next()) {System.out.println(res.getString(1) + "\t" + res.getString(2));}// load data into table// NOTE: filepath has to be local to the hive server// NOTE: /tmp/a.txt is a ctrl-A separated file with two fields per lineString filepath = "/tmp/a.txt";sql = "load data local inpath '" + filepath + "' into table " + tableName;System.out.println("Running: " + sql);stmt.execute(sql);// select * querysql = "select * from " + tableName;System.out.println("Running: " + sql);res = stmt.executeQuery(sql);while (res.next()) {System.out.println(String.valueOf(res.getInt(1)) + "\t" + res.getString(2));}// regular hive querysql = "select count(1) from " + tableName;System.out.println("Running: " + sql);res = stmt.executeQuery(sql);while (res.next()) {System.out.println(res.getString(1));}} }

5.2 Hive UDF

簡(jiǎn)單UDF示例
前期準(zhǔn)備,要把hive的lib包導(dǎo)入到工程中,其中UDF依賴的是hive-exec-2.3.4.jar(針對(duì)hive2.3.4版本)。也就是說(shuō)要把$HIVE_HOME\lib中的內(nèi)容引入到工程中。若用到hadoop中的一些api,也把hadoop的相關(guān)的jar包也引入進(jìn)去。
1、先開(kāi)發(fā)一個(gè)java類(lèi),繼承UDF,并重載evaluate方法。

package hiveudf;import org.apache.hadoop.hive.ql.exec.UDF; import org.apache.hadoop.io.Text;public class ToLowerCase extends UDF {public Text evaluate(final Text s) {if(s == null) {returnnull;}returnnew Text(s.toString().toLowerCase());} }

2、打成jar包上傳到服務(wù)器
3、將jar包添加到hive的classpath
4、hive> add jar /home/udf/hivedata/udf.jar;
5、hive>創(chuàng)建臨時(shí)函數(shù)與開(kāi)發(fā)好的java class關(guān)聯(lián)

hive> create temporary function toLowercase as 'hiveudf.ToLowerCase'; OK Time taken: 0.039 seconds hive>

6、即可在HiveQL中使用自定義的函數(shù)toLowercase

hive> select toLowercase("ZHANGSAN") from dual; OK zhangsan Time taken: 0.122 seconds, Fetched: 1 row(s) hive>

再如判斷身份證的一個(gè)UDF函數(shù):

package com.xxx.xxx.udf;import java.text.SimpleDateFormat; import java.util.Date; import java.util.regex.Matcher; import java.util.regex.Pattern;import org.apache.hadoop.hive.ql.exec.UDF;/*** 身份證校驗(yàn)UDF* * @author xxx* @date 2019年5月29日* * 1.身份證號(hào)碼構(gòu)成:6位地址編碼+8位生日+3位順序碼+1位校驗(yàn)碼 * 2.驗(yàn)證15位,18位證件號(hào)碼是否有效; * 3.15位號(hào)碼將直接轉(zhuǎn)為18位;【這一步不做轉(zhuǎn)化】* 4.校驗(yàn)身份證號(hào)碼除了校驗(yàn)位是否為數(shù)值,校驗(yàn)省份、出生日期* 省份編碼[11, 12, 13, 14, 15, 21, 22, 23, 31, 32, 33, 34, 35, 36, 37, 41, 42, 43,44, 45, 46, 50, 51, 52, 53, 54, 61, 62, 63, 64, 65, 71, 81, 82, 91]* 5.校驗(yàn)位不正確的會(huì)被正確的替代.【最后1位是根據(jù)前面17位生成的,如果不正確,會(huì)生成正確的檢驗(yàn)碼進(jìn)行修正.】* 6.出生日期邏輯有效性,即是否1864年前出生,是否當(dāng)前日期后出生已校驗(yàn)。* 7.1984年4月6日國(guó)務(wù)院發(fā)布《中華人民共和國(guó)居民身份證試行條例》,并且開(kāi)始頒發(fā)第一代居民身份證,按壽命120歲驗(yàn)證,年齡區(qū)間是1864年至今。 * 8.15位證件號(hào)碼轉(zhuǎn)換未考慮1900年前出生的人【這一步不做轉(zhuǎn)化】* 9.去除null,去除空串,去除非15位和18位* 10.判斷前17位是否含非數(shù)字字符.* 11.判斷非法日期,如生日所在日期(2019年2月29日)不存在.* * add jar hdfs://tqHadoopCluster/xxx/udf/idCardUdf.jar;* create temporary function cheakIdCardNumber as 'com.xxx.xxx.udf.IdNumber';* 這這就可以使用cheakIdCardNumber(String idCardNumber)進(jìn)行校驗(yàn)身份證了*/ public class IdNumber extends UDF {private final static int NEW_CARD_NUMBER_LENGTH = 18;private final static int OLD_CARD_NUMBER_LENGTH = 15;/** 開(kāi)始年份 */private final static int YEAR_BEGIN = 1864;/** 18位身份證中最后一位校驗(yàn)碼 */private final static char[] VERIFY_CODE = {'1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'};/** 18位身份證中,各個(gè)數(shù)字的生成校驗(yàn)碼時(shí)的權(quán)值 */private final static int[] VERIFY_CODE_WEIGHT = {7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2};/** 省份編碼集合 */private final static int[] PROVINCE_CODE = {11, 12, 13, 14, 15, 21, 22, 23, 31, 32, 33, 34, 35, 36, 37, 41, 42, 43,44, 45, 46, 50, 51, 52, 53, 54, 61, 62, 63, 64, 65, 71, 81, 82, 91};private final static Pattern PATTERN = Pattern.compile("[0-9]*");private final static ThreadLocal<SimpleDateFormat> THREADLOCAL = new ThreadLocal<SimpleDateFormat>() {@Overrideprotected SimpleDateFormat initialValue() {// 直接返回nullreturn null;}};/*public static void main(String[] args) {IdNumber idNumber = new IdNumber();//String evaluate = idNumber.evaluate("125197791116622");// 125197 791116622// 12519719791116622X// 330304198705234817String evaluate = idNumber.evaluate("330304201902284815");System.out.println(evaluate);}*/public String evaluate(String cardNumber) {// 1.去除NULLif (cardNumber == null) {return null;} Date dNow = new Date();SimpleDateFormat ft = new SimpleDateFormat("yyyy");int yearEnd = Integer.parseInt(ft.format(dNow));cardNumber = cardNumber.trim();// 2.去除空字符串if (cardNumber.length() == 0) {return null;}// 3.去除長(zhǎng)度不正確的,非15或18位if (NEW_CARD_NUMBER_LENGTH != cardNumber.length() & OLD_CARD_NUMBER_LENGTH != cardNumber.length()) {return null;}// 4.如果是18位if (NEW_CARD_NUMBER_LENGTH == cardNumber.length()) {// 4.1.前17位不為數(shù)值,返回nullif (isNumeric(cardNumber.substring(0, 17)) == false) {return null;}// 校驗(yàn)位修正,判斷最后一位是否正確if (IdNumber.calculateVerifyCode(cardNumber) != cardNumber.charAt(17)) {//如果最后一位校驗(yàn)碼不會(huì),則修正校驗(yàn)碼.cardNumber = contertToNewCardNumber(cardNumber, NEW_CARD_NUMBER_LENGTH);}// 身份證前2位是省份編碼, 如果編碼不在已知集合中, 返回null.if (isProvince(cardNumber.substring(0, 2)) == false) {return null;} // 非法日期轉(zhuǎn)換前后不一致, 如當(dāng)前年份不存在2月29日, 返回nullif (isDate(cardNumber.substring(6, 14)) == false) {return null;}// 1984年4月6日國(guó)務(wù)院發(fā)布《中華人民共和國(guó)居民身份證試行條例》,并且開(kāi)始頒發(fā)第一代居民身份證,按壽命120歲驗(yàn)證,年齡區(qū)間是1864年至今。 小于1984的為非法.int birthdayYear = Integer.parseInt(cardNumber.substring(6, 10));if (birthdayYear < YEAR_BEGIN) {return null;}// 如果出生年月大于當(dāng)前日期, 返回nullif (birthdayYear > yearEnd) {return null;}}// 5.如果是15位:15位身份證號(hào)碼不轉(zhuǎn)換為18位.if (OLD_CARD_NUMBER_LENGTH == cardNumber.length()) {// 前15位中含非數(shù)字字符, 返回nullif (isNumeric(cardNumber) == false) {return null;}// 省份編碼不在在已知集合中, 返回nullif (isProvince(cardNumber.substring(0, 2)) == false) {return null;}// 非法日期轉(zhuǎn)換前后不一致, 返回nullif (isDate("19" + cardNumber.substring(6, 12)) == false) {return null;}//將15位身份證轉(zhuǎn)化為18位,考慮1900年前出生的人。//cardNumber = contertToNewCardNumber(cardNumber, OLD_CARD_NUMBER_LENGTH);}return cardNumber;}/*** 校驗(yàn)碼(第十八位數(shù)):* * 十七位數(shù)字本體碼加權(quán)求和公式 S = Sum(Ai * Wi), i = 0...16 ,先對(duì)前17位數(shù)字的權(quán)求和; * Ai:表示第i位置上的身份證號(hào)碼數(shù)字值 * Wi:表示第i位置上的加權(quán)因子 * Wi: 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2; * 計(jì)算模 Y = mod(S, 11) 通過(guò)模得到對(duì)應(yīng)的校驗(yàn)碼* Y: 0 1 2 3 4 5 6 7 8 9 10 * 校驗(yàn)碼: 1 0 X 9 8 7 6 5 4 3 2* * @param cardNumber* @return*/private static char calculateVerifyCode(CharSequence cardNumber) {int sum = 0;for (int i = 0; i < NEW_CARD_NUMBER_LENGTH - 1; i++) {char ch = cardNumber.charAt(i);sum += ((int)(ch - '0')) * VERIFY_CODE_WEIGHT[i];}//VERIFY_CODE = {'1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'};return VERIFY_CODE[sum % 11];}/*** A-把15位身份證號(hào)碼轉(zhuǎn)換到18位身份證號(hào)碼 15位身份證號(hào)碼與18位身份證號(hào)碼的區(qū)別為: * 1. 15位身份證號(hào)碼中,"出生年份"字段是2位,轉(zhuǎn)換時(shí)需要補(bǔ)入"19",表示20世紀(jì)* 2. 15位身份證無(wú)最后一位校驗(yàn)碼。18位身份證中,校驗(yàn)碼根據(jù)根據(jù)前17位生成 B-18位身份證號(hào)碼校驗(yàn)位修復(fù)* * @param cardNumber* @return*/private static String contertToNewCardNumber(String idCardNumber, int cardNumberLength) {StringBuilder buf = new StringBuilder(NEW_CARD_NUMBER_LENGTH);if (cardNumberLength == NEW_CARD_NUMBER_LENGTH) {buf.append(idCardNumber.substring(0, 17));buf.append(IdNumber.calculateVerifyCode(buf));} else if (cardNumberLength == OLD_CARD_NUMBER_LENGTH) {buf.append(idCardNumber.substring(0, 6));buf.append("19");buf.append(idCardNumber.substring(6));buf.append(IdNumber.calculateVerifyCode(buf));}return buf.toString();}/*** 功能:判斷字符串是否為數(shù)字* * @param str* @return*/private static boolean isNumeric(String str) {Matcher isNum = PATTERN.matcher(str);if (isNum.matches()) {return true;} else {return false;}}/*** 功能:判斷前兩位是在省份編碼集合內(nèi)* @param province* @return*/private static boolean isProvince(String province) {int prov = Integer.parseInt(province);for (int i = 0; i < PROVINCE_CODE.length; i++) {if (PROVINCE_CODE[i] == prov) {return true;}}return false;}public static SimpleDateFormat getDateFormat() {SimpleDateFormat df = (SimpleDateFormat)THREADLOCAL.get();if (df == null) {df = new SimpleDateFormat("yyyyMMdd");df.setLenient(false);THREADLOCAL.set(df);}return df;}/*** 功能:判斷出生日期字段是否為日期* * @param str* @return*/private static boolean isDate(String birthDate) {try {SimpleDateFormat sdf = getDateFormat();//如果不合法,會(huì)拋異常, Unparseable date: "20190229"Date cacheBirthDate = sdf.parse(birthDate);if (sdf.format(cacheBirthDate).equals(birthDate) == false) {// 非法日期轉(zhuǎn)換前后不一致return false;}} catch (Exception e) {//e.printStackTrace();return false;}return true;} }

6 Hive的體系結(jié)構(gòu)

下面是Hive的架構(gòu)圖:

圖 1 Hive體系結(jié)構(gòu)

6.1用戶接口

(1)、CLI:CLI啟動(dòng)的時(shí)候,會(huì)同時(shí)啟動(dòng)一個(gè)Hive副本。
(2)、JDBC客戶端:封裝了Thrift,java應(yīng)用程序,可以通過(guò)指定的主機(jī)和端口連接到在另外一個(gè)進(jìn)程中運(yùn)行的hive服務(wù)器。
(3)、ODBC客戶端:ODBC驅(qū)動(dòng)允許支持ODBC協(xié)議的應(yīng)用程序連接到Hive
(4)、WUI接口:通過(guò)瀏覽器訪問(wèn)Hive

6.2Thrift服務(wù)器

基于socket通訊,支持跨語(yǔ)言。Hive Thrift服務(wù)簡(jiǎn)化了在多編程語(yǔ)言中運(yùn)行hive的命令。綁定支持C++,Java,PHP,Python和Ruby語(yǔ)言。

6.3 Driver

核心組件,整個(gè)Hive的核心,該組件包括Complier、Optimizer和Executor; 解釋器、編譯器、優(yōu)化器完成HQL查詢語(yǔ)句從詞法分析、語(yǔ)法分析、編譯、優(yōu)化以及查詢計(jì)劃的生成。生成的查詢計(jì)劃存儲(chǔ)在HDFS中,并在隨后有MapReduce調(diào)用執(zhí)行。

6.4 元數(shù)據(jù)庫(kù)Metastore

Hive的數(shù)據(jù)由兩部分組成:數(shù)據(jù)文件和元數(shù)據(jù)。元數(shù)據(jù)用于存放Hive庫(kù)的基礎(chǔ)信息,它存儲(chǔ)在關(guān)系數(shù)據(jù)庫(kù)中,例如mysql、Oracle、derby。元數(shù)據(jù)包括:數(shù)據(jù)庫(kù)信息、表達(dá)的名字,表的列和分區(qū)及其屬性,表的屬性,表的數(shù)據(jù)所在目錄等。
Hadoop
Hive的數(shù)據(jù)文件存儲(chǔ)在HDFS中,大部分的查詢由MapReduce完成。(對(duì)于包含*的查詢,比如select * from tbl不會(huì)生成MapReduce作業(yè))

6.5數(shù)據(jù)庫(kù)連接模式

6.5.1 單用戶模式

此模式連接到一個(gè)In-memory的數(shù)據(jù)庫(kù)Derby,Derby數(shù)據(jù)是Hive自帶的數(shù)據(jù)庫(kù),默認(rèn)只能有一個(gè)連接,用戶連接到Hive后,會(huì)在當(dāng)前目錄生成一個(gè)metastore文件來(lái)存放元數(shù)據(jù)信息,不同的用戶連接到Hive看到的信息不一致。

6.5.2多用戶模式

通過(guò)網(wǎng)絡(luò)連接到一個(gè)關(guān)系型數(shù)據(jù)庫(kù)中,如MySQL,是最進(jìn)程使用到的模式。這樣多個(gè)用戶操作的元數(shù)據(jù)信息統(tǒng)一放到關(guān)系型數(shù)據(jù)庫(kù),這樣不同用戶可以操作相同的對(duì)象。

6.5.3 遠(yuǎn)程服務(wù)模式

用于非Java客戶端訪問(wèn)元數(shù)據(jù),在服務(wù)器啟動(dòng)MetaStoreServer,客戶端利用Thrift協(xié)議通過(guò)MetaStoreServer訪問(wèn)元數(shù)據(jù)。

7 Hive技術(shù)原理解析

7.1 Hive工作原理

如下圖所示:

流程大致步驟為:

  • 用戶提交查詢等任務(wù)給Driver。
  • 編譯器獲得該用戶的任務(wù)Plan。
  • 編譯器Compiler根據(jù)用戶任務(wù)去MetaStore中獲取需要的Hive的元數(shù)據(jù)信息。
  • 編譯器Compiler得到元數(shù)據(jù)信息,對(duì)任務(wù)進(jìn)行編譯,先將HiveQL轉(zhuǎn)換為抽象語(yǔ)法樹(shù),然后將抽象語(yǔ)法樹(shù)轉(zhuǎn)換成查詢塊,將查詢塊轉(zhuǎn)化為邏輯的查詢計(jì)劃,重寫(xiě)邏輯查詢計(jì)劃,將邏輯計(jì)劃轉(zhuǎn)化為物理的計(jì)劃(MapReduce), 最后選擇最佳的策略。
  • 將最終的計(jì)劃提交給Driver。
  • Driver將計(jì)劃Plan轉(zhuǎn)交給ExecutionEngine去執(zhí)行,獲取元數(shù)據(jù)信息,提交給JobTracker或者SourceManager執(zhí)行該任務(wù),任務(wù)會(huì)直接讀取HDFS中文件進(jìn)行相應(yīng)的操作。
  • 獲取執(zhí)行的結(jié)果。
  • 取得并返回執(zhí)行結(jié)果。
  • 創(chuàng)建表時(shí):
    1、解析用戶提交的Hive語(yǔ)句對(duì)其進(jìn)行解析分解為表、字段、分區(qū)等Hive對(duì)象。根據(jù)解析到的信息構(gòu)建對(duì)應(yīng)的表、字段、分區(qū)等對(duì)象,從SEQUENCE_TABLE中獲取構(gòu)建對(duì)象的最新的ID,與構(gòu)建對(duì)象信息(名稱(chēng)、類(lèi)型等等)一同通過(guò)DAO方法寫(xiě)入元數(shù)據(jù)庫(kù)的表中,成功后將SEQUENCE_TABLE中對(duì)應(yīng)的最新ID+5.實(shí)際上常見(jiàn)的RDBMS都是通過(guò)這種方法進(jìn)行組織的,其系統(tǒng)表中和Hive元素一樣顯示了這些ID信息。通過(guò)這些元數(shù)據(jù)可以很容易的讀取到數(shù)據(jù)。

    工作原理的另外一種說(shuō)法是:
    接收到一個(gè)sql,后面做的事情包括:
    1.詞法分析/語(yǔ)法分析
    使用antlr將SQL語(yǔ)句解析成抽象語(yǔ)法樹(shù)-AST
    2.語(yǔ)義分析
    從Megastore獲取模式信息,驗(yàn)證SQL語(yǔ)句中隊(duì)表名,列名,以及數(shù)據(jù)類(lèi)型的檢查和隱式轉(zhuǎn)換,以及Hive提供的函數(shù)和用戶自定義的函數(shù)(UDF/UAF)
    3.邏輯計(jì)劃生產(chǎn)
    生成邏輯計(jì)劃-算子樹(shù)
    4.邏輯計(jì)劃優(yōu)化
    對(duì)算子樹(shù)進(jìn)行優(yōu)化,包括列剪枝,分區(qū)剪枝,謂詞下推等
    5.物理計(jì)劃生成
    將邏輯計(jì)劃生產(chǎn)包含由MapReduce任務(wù)組成的DAG的物理計(jì)劃
    6.物理計(jì)劃執(zhí)行
    將DAG發(fā)送到Hadoop集群進(jìn)行執(zhí)行
    7.將查詢結(jié)果返回

    流程如下圖:

    7.2 Hive編譯過(guò)程

    轉(zhuǎn)化過(guò)程:
    基本流程為:將HiveQL轉(zhuǎn)化為”抽象語(yǔ)法樹(shù)”—>”查詢塊”—>”邏輯查詢計(jì)劃””物理查詢計(jì)劃”最終選擇最佳決策的過(guò)程。

    優(yōu)化器的主要功能:

  • 將多Multiple join 合并為一個(gè)Muti-way join
  • 對(duì)join、group-by和自定義的MapReduce操作重新進(jìn)行劃分。
  • 消減不必要的列。
  • 在表的掃描操作中推行使用斷言。
  • 對(duì)于已分區(qū)的表,消減不必要的分區(qū)。
  • 在抽樣查詢中,消減不必要的桶。
  • 優(yōu)化器還增加了局部聚合操作用于處理大分組聚合和增加再分區(qū)操作用于處理不對(duì)稱(chēng)的分組聚合。
  • 7.2.1 Hive編譯器的組成


    對(duì)于此的說(shuō)明,網(wǎng)絡(luò)上的另外一種說(shuō)明:

    7.2.2 Query Compiler


    網(wǎng)絡(luò)上描述上述過(guò)程的另外一張圖(同樣是Query Compiler過(guò)程的另外一種畫(huà)法):

    為了說(shuō)明上述執(zhí)行流程,需要輔助一個(gè)簡(jiǎn)單的Hive查詢例子:

    案例1-1:Hive執(zhí)行以下語(yǔ)句:

    INSERT OVERWRITE TABLE access_log_temp2 SELECT a.user, a.prono, a.maker, a.price FROM access_log_hbase a JOIN product_hbase p ON (a.prono = p.prono)

    具體執(zhí)行流程:
    (1)Parser生成AST

    HQL生成的語(yǔ)法解析樹(shù)(AST):
    HIVE主要是利用UNDERLER處理得到上面的抽象語(yǔ)法樹(shù)(這棵抽象語(yǔ)法樹(shù)主要是根據(jù)underller的分詞規(guī)則來(lái)確定根結(jié)點(diǎn)和左右孩子的,Hive的這部分處理是利用underller進(jìn)行的)。
    (2)Semantic Analyzer生成Query Block(QB)

    Tip:
    第二步會(huì)將抽象語(yǔ)法樹(shù)按照QB的方式轉(zhuǎn)換為由QB組成的樹(shù)。通常情況下,每一個(gè)From子句會(huì)生成一個(gè)QB(Query Block)。通過(guò)查看具體有多少個(gè)QB就可查看Hive sql語(yǔ)句最終優(yōu)化成多少個(gè)MapReduce的作業(yè)。

    QB是由兩個(gè)子數(shù)據(jù)結(jié)構(gòu)組成即MetaData(元數(shù)據(jù)信息)和ParseInfo。語(yǔ)義分析的主要過(guò)程是向QB中填充元數(shù)據(jù),另一個(gè)過(guò)程則是摘取AST的子節(jié)點(diǎn),存儲(chǔ)在ParseInfo中。Semantic Analyzer過(guò)程主要是經(jīng)過(guò)以上兩個(gè)過(guò)程,然后把QB關(guān)聯(lián)起來(lái)形成一個(gè)由QB構(gòu)成的圖.

    Logical Plan generator會(huì)將上一步生成的Query Block按照前文講的幾種的Operator,轉(zhuǎn)換為Operator Tree。




    由于Hive查詢語(yǔ)句會(huì)將最后的查詢結(jié)果寫(xiě)入到表access_log_temp2中,所以QB的MetaData中的Name To Destination…會(huì)轉(zhuǎn)化為Operator Tree中的FileSinkOperator(文件下沉)。
    最后會(huì)生成如下的OP Tree:

    Logical Plan Generator (Result)

    這里就得到了一個(gè)有向無(wú)環(huán)圖(DAG),當(dāng)在傳統(tǒng)數(shù)據(jù)庫(kù)中會(huì)對(duì)上圖進(jìn)行優(yōu)化然后執(zhí)行;而在Hadoop集群中這張圖是不行的,因?yàn)樵诩褐袌?zhí)行需要對(duì)這張圖進(jìn)行優(yōu)化、切片,分布式化轉(zhuǎn)化為MapReduce作業(yè)然后執(zhí)行。

    7.2.3新版本Hive也支持Tez或Spark作為執(zhí)行引擎:



    物理計(jì)劃可以通過(guò)hive的Explain命令輸出:
    例如:

    0: jdbc:hive2://master:10000/dbmfz> explain select count(*) from record_dimension; +------------------------------------------------------------------------------------------------------+--+ | Explain | +------------------------------------------------------------------------------------------------------+--+ | STAGE DEPENDENCIES: | | Stage-1 is a root stage | | Stage-0 depends on stages: Stage-1 | | | | STAGE PLANS: | | Stage: Stage-1 | | Map Reduce | | Map Operator Tree: | | TableScan | | alias: record_dimension | | Statistics: Num rows: 1 Data size: 543 Basic stats: COMPLETE Column stats: COMPLETE | | Select Operator | | Statistics: Num rows: 1 Data size: 543 Basic stats: COMPLETE Column stats: COMPLETE | | Group By Operator | | aggregations: count() | | mode: hash | | outputColumnNames: _col0 | | Statistics: Num rows: 1 Data size: 8 Basic stats: COMPLETE Column stats: COMPLETE | | Reduce Output Operator | | sort order: | | Statistics: Num rows: 1 Data size: 8 Basic stats: COMPLETE Column stats: COMPLETE | | value expressions: _col0 (type: bigint) | | Reduce Operator Tree: | | Group By Operator | | aggregations: count(VALUE._col0) | | mode: mergepartial | | outputColumnNames: _col0 | | Statistics: Num rows: 1 Data size: 8 Basic stats: COMPLETE Column stats: COMPLETE | | File Output Operator | | compressed: false | | Statistics: Num rows: 1 Data size: 8 Basic stats: COMPLETE Column stats: COMPLETE | | table: | | input format: org.apache.hadoop.mapred.SequenceFileInputFormat | | output format: org.apache.hadoop.hive.ql.io.HiveSequenceFileOutputFormat | | serde: org.apache.hadoop.hive.serde2.lazy.LazySimpleSerDe | | | | Stage: Stage-0 | | Fetch Operator | | limit: -1 | | Processor Tree: | | ListSink | | | +------------------------------------------------------------------------------------------------------+--+ rows selected (0.844 seconds)

    8 Hive優(yōu)化

    1、join連接時(shí)的優(yōu)化:當(dāng)三個(gè)或多個(gè)以上的表進(jìn)行join操作時(shí),如果每個(gè)on使用相同的字段連接時(shí)只會(huì)產(chǎn)生一個(gè)mapreduce。
    2、join連接時(shí)的優(yōu)化:當(dāng)多個(gè)表進(jìn)行查詢時(shí),從左到右表的大小順序應(yīng)該是從小到大。原因:hive在對(duì)每行記錄操作時(shí)會(huì)把其他表先緩存起來(lái),直到掃描最后的表進(jìn)行計(jì)算
    3、在where字句中增加分區(qū)過(guò)濾器。
    4、當(dāng)可以使用left semi join 語(yǔ)法時(shí)不要使用inner join,前者效率更高。原因:對(duì)于左表中指定的一條記錄,一旦在右表中找到立即停止掃描。
    5、如果所有表中有一張表足夠小,則可置于內(nèi)存中,這樣在和其他表進(jìn)行連接的時(shí)候就能完成匹配,省略掉reduce過(guò)程。設(shè)置屬性即可實(shí)現(xiàn),set hive.auto.covert.join=true; 用戶可以配置希望被優(yōu)化的小表的大小 set hive.mapjoin.smalltable.size=2500000; 如果需要使用這兩個(gè)配置可置入$HOME/.hiverc文件中。
    6、同一種數(shù)據(jù)的多種處理:從一個(gè)數(shù)據(jù)源產(chǎn)生的多個(gè)數(shù)據(jù)聚合,無(wú)需每次聚合都需要重新掃描一次。
    例如:insert overwrite table student select * from employee; insert overwrite table person select * from employee;
    可以優(yōu)化成:from employee insert overwrite table student select * insert overwrite table person select *
    7、limit調(diào)優(yōu):limit語(yǔ)句通常是執(zhí)行整個(gè)語(yǔ)句后返回部分結(jié)果。set hive.limit.optimize.enable=true;
    8、開(kāi)啟并發(fā)執(zhí)行。某個(gè)job任務(wù)中可能包含眾多的階段,其中某些階段沒(méi)有依賴關(guān)系可以并發(fā)執(zhí)行,開(kāi)啟并發(fā)執(zhí)行后job任務(wù)可以更快的完成。設(shè)置屬性:set hive.exec.parallel=true;
    9、hive提供的嚴(yán)格模式,禁止3種情況下的查詢模式。
    a:當(dāng)表為分區(qū)表時(shí),where字句后沒(méi)有分區(qū)字段和限制時(shí),不允許執(zhí)行。
    b:當(dāng)使用order by語(yǔ)句時(shí),必須使用limit字段,因?yàn)閛rder by 只會(huì)產(chǎn)生一個(gè)reduce任務(wù)。
    c:限制笛卡爾積的查詢。
    10、合理的設(shè)置map和reduce數(shù)量。
    11、jvm重用。可在hadoop的mapred-site.xml中設(shè)置jvm被重用的次數(shù)。

    打個(gè)賞唄,您的支持是我堅(jiān)持寫(xiě)好博文的動(dòng)力

    總結(jié)

    以上是生活随笔為你收集整理的6、HIVE JDBC开发、UDF、体系结构、Thrift服务器、Driver、元数据库Metastore、数据库连接模式、单/多用户模式、远程服务模式、Hive技术原理解析、优化等(整理的笔记)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

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

    韩国一区二区三区在线观看 | 久操97| 丝袜美腿在线 | 国产一级视频在线观看 | 成人av免费在线 | 粉嫩av一区二区三区四区五区 | 亚洲国产午夜 | 欧美日本高清视频 | 日韩成人免费在线 | 久久九九精品久久 | 亚洲欧美日韩不卡 | 人人要人人澡人人爽人人dvd | 亚洲电影影音先锋 | 国产精品18久久久久久不卡孕妇 | 日本久久精品 | 国产丝袜一区二区三区 | 国产午夜精品久久久久久久久久 | 亚洲伊人av | 国产精品久久久久久久午夜 | 欧美成a人片在线观看久 | 日韩伦理片一区二区三区 | 97电影手机 | 亚洲综合最新在线 | 亚洲国产色一区 | 国产精品美女久久久久久免费 | 99这里只有精品99 | 少妇bbw搡bbbb搡bbb | 日本精品在线看 | 国产精品不卡 | 日韩一级电影在线观看 | 国产资源网 | 91丨九色丨国产丨porny精品 | 日韩精品专区在线影院重磅 | 久久国语露脸国产精品电影 | 999久久久免费精品国产 | 久热爱| 天天想夜夜操 | www.午夜视频| 久久久久亚洲精品 | 99色在线观看 | 亚洲国产成人在线观看 | 日韩国产精品毛片 | 一级黄色片在线播放 | 天天操网站 | 99久久精品国产欧美主题曲 | 天天综合人人 | 亚洲精品国产精品乱码不99热 | 日韩av一区二区三区在线观看 | 九九亚洲精品 | 在线看黄网站 | av免费在线播放 | 国产精品美女免费看 | 91在线视频在线观看 | 黄色av免费电影 | 草久视频在线观看 | av专区在线 | 精品女同一区二区三区在线观看 | 日日干夜夜爱 | 天天摸天天弄 | 日韩视频三区 | 91在线视频免费91 | 国产精品久久久久久久久久了 | 亚洲欧美国产精品va在线观看 | 国产精品免费久久久久久 | 91麻豆国产福利在线观看 | 欧美精品免费在线观看 | 国产精品videoxxxx | 国产麻豆视频 | 国产第页 | 精品久久久久久久久中文字幕 | 奇米影视8888在线观看大全免费 | 久久久久久中文字幕 | 青青河边草手机免费 | 日本巨乳在线 | 91视频91蝌蚪| 国产不卡免费视频 | 狠狠的干狠狠的操 | av黄色在线观看 | 在线视频欧美日韩 | 日韩精品视频在线免费观看 | 视频福利在线 | 六月婷婷网 | 免费a视频| 国产五月婷 | 成人av在线影视 | 91人人视频在线观看 | 99久久99视频只有精品 | 亚洲激情视频在线观看 | 五月婷婷在线综合 | 91麻豆国产福利在线观看 | 在线精品观看国产 | 日韩啪啪小视频 | 黄色软件视频大全免费下载 | 欧美日韩另类在线观看 | 色久av| 欧美成人性网 | 欧美了一区在线观看 | 国产精品网红直播 | 国产日本亚洲 | 亚洲成人午夜在线 | 久久一区二区免费视频 | 欧美日韩中文在线视频 | 草免费视频 | av无限看| 激情视频综合网 | 色999五月色 | 国产精品久久久久久久久免费看 | 亚洲一级黄色av | 久久久久中文字幕 | 四川bbb搡bbb爽爽视频 | 999久久久久| 国产精品无av码在线观看 | 奇米7777狠狠狠琪琪视频 | 97理论电影| 天天干天天射天天操 | 久久综合亚洲鲁鲁五月久久 | 精品一区二区三区电影 | 色婷婷电影网 | av成人免费 | 91在线观看欧美日韩 | 精品视频免费观看 | 综合网色 | 久久亚洲区 | 午夜在线日韩 | 国内精品久久久久久久久久久 | 精品国产成人 | 午夜视频一区二区三区 | 日韩极品在线 | 欧美性超爽| 久草精品视频在线观看 | 国产成人福利在线观看 | 亚洲经典视频 | 久久成年人| 日本激情中文字幕 | 精品99在线 | 成人在线视频网 | 国产精品99久久久久久宅男 | 国产日产高清dvd碟片 | 91九色视频网站 | 五月丁香 | 日韩av电影中文字幕 | 亚洲精品免费看 | av不卡免费在线观看 | 正在播放久久 | 欧美日韩在线视频观看 | 丁香5月婷婷久久 | 色播六月天 | 日日夜夜狠狠干 | 四虎影视av| 成年人免费观看在线视频 | 香蕉精品在线观看 | 狠狠狠干 | 国产日韩欧美在线观看 | 91资源在线 | 久久综合给合久久狠狠色 | 国产丝袜高跟 | 黄色影院在线免费观看 | 日日夜夜天天久久 | 国产成人久久精品一区二区三区 | 综合黄色网 | 91精品国产99久久久久久红楼 | 免费精品国产va自在自线 | 国产精品久久久久久久免费观看 | 成人观看 | 97精品国产一二三产区 | 中文字幕亚洲欧美 | 成人中文字幕+乱码+中文字幕 | 97国产精品| 欧美做受69 | 成人免费 在线播放 | 久久精品人 | www.夜夜操.com | www四虎影院| 国产不卡精品视频 | 18久久久久| 天天做夜夜做 | 狠狠gao | 97日日碰人人模人人澡分享吧 | 一区二区视频免费在线观看 | 在线国产观看 | 国产91精品在线播放 | 日韩国产高清在线 | 香蕉视频网站在线观看 | 国产免费大片 | 日韩在线视频观看 | 亚洲理论在线观看电影 | 伊人天天狠天天添日日拍 | www.色午夜| 国内精品免费久久影院 | 91视频免费看网站 | 天天操天天爽天天干 | 综合网在线视频 | a级一a一级在线观看 | 欧美一区二区在线刺激视频 | 亚洲性xxxx | 激情狠狠干 | 日韩在线理论 | av成人亚洲| a√资源在线 | 日韩亚洲欧美中文字幕 | 91精彩视频在线观看 | 在线天堂亚洲 | 韩日三级av | 午夜精品久久久久久 | 人人干天天干 | 午夜色场 | 高清中文字幕 | 日本韩国精品一区二区在线观看 | 在线有码中文字幕 | 国产一级在线播放 | 91九色蝌蚪视频 | 丁香六月在线观看 | 国产精品3| 五月婷婷狠狠 | 日本在线视频一区二区三区 | 九九热在线播放 | 日本动漫做毛片一区二区 | 久久久久一区二区三区四区 | 欧洲视频一区 | 亚洲人成在线观看 | 成人精品一区二区三区中文字幕 | 免费观看视频的网站 | 亚洲黄色在线免费观看 | 欧美一区二区三区在线 | 麻豆国产精品视频 | 国产手机视频在线观看 | 成人午夜毛片 | 中文字幕电影高清在线观看 | 青青河边草观看完整版高清 | 综合色婷婷 | 国产成人久久av免费高清密臂 | 五月天婷亚洲天综合网鲁鲁鲁 | 日韩毛片精品 | 亚洲国产精品一区二区久久,亚洲午夜 | 国产免费二区 | 麻豆视频在线 | 九九热中文字幕 | 91av视屏| 人人爽人人澡 | 中文伊人 | 在线成人欧美 | 欧美色伊人 | 一区二区视频播放 | 精品视频免费久久久看 | 丁香视频免费观看 | av在线播放观看 | 亚洲黄色免费网站 | 国产一区二区在线免费观看 | 国产成人av片 | 亚洲女在线 | 女人18毛片a级毛片一区二区 | 亚洲精品视频第一页 | 四虎在线免费观看 | 日韩免费中文字幕 | 91精品久久久久久久99蜜桃 | 成人精品视频久久久久 | 一区二区三区在线观看 | 午夜一级免费电影 | 国产精品孕妇 | 午夜久久影视 | 国产中文字幕精品 | 免费观看福利视频 | 九九热免费在线视频 | 综合精品久久 | www91在线| 国产精品白虎 | 五月天精品视频 | 亚洲精品中文在线 | 国产做a爱一级久久 | 91成年人视频 | 在线观看一区 | 日韩二区三区在线观看 | 伊甸园av在线 | 日本中文在线观看 | 午夜 在线| 亚洲成人精品影院 | 久久久精品一区二区 | 国产高清在线视频 | 黄色片免费在线 | 特级西西444www大精品视频免费看 | 干综合网| 成人不用播放器 | 国产精品小视频网站 | 精品国产免费人成在线观看 | 四虎成人精品在永久免费 | 伊人午夜视频 | 国产欧美精品一区aⅴ影院 99视频国产精品免费观看 | 有码视频在线观看 | 国产 成人 久久 | 成人免费观看电影 | 99久久精品久久亚洲精品 | 欧美片一区二区三区 | av看片在线 | 欧美性脚交 | 在线观看成人av | 人人插人人舔 | 国产精品岛国久久久久久久久红粉 | 日韩在线网址 | 国产高清精品在线观看 | 高潮毛片无遮挡高清免费 | 久久久久亚洲精品成人网小说 | 亚洲精品国产第一综合99久久 | 91爱在线| 日韩精品国产一区 | 欧美va天堂在线电影 | 免费福利在线视频 | 国产 视频 久久 | 92国产精品久久久久首页 | www.com久久久 | 亚洲精品国产拍在线 | 成人在线观看你懂的 | 欧美粗又大 | 丁香五婷| 深夜免费小视频 | 日韩在线观看第一页 | 蜜桃视频成人在线观看 | 在线播放 日韩专区 | 最近中文字幕大全中文字幕免费 | 色欧美88888久久久久久影院 | 一区二区网 | 青青河边草手机免费 | 中文字幕在线网址 | 色偷偷88888欧美精品久久久 | 日韩精品三区四区 | 操操操人人人 | 成人国产在线 | 婷婷国产v亚洲v欧美久久 | 最新av免费在线 | 日韩av伦理片 | 在线免费观看麻豆 | 天天做天天爱天天综合网 | 欧美日韩免费一区二区三区 | 日本99久久| 91夜夜夜 | 免费成人在线观看 | 亚洲视频免费在线观看 | 久久综合亚洲鲁鲁五月久久 | 国产在线播放观看 | 爱av在线网 | 国产精品久久一卡二卡 | 中文字幕一区二区三区久久蜜桃 | 日韩在线视频在线观看 | 天天综合天天综合 | 欧美日韩国产一区二区三区 | 国产精品国内免费一区二区三区 | 国产精品99精品久久免费 | 一区中文字幕在线观看 | 欧美一二三区在线观看 | 久久久影片 | 亚洲综合色站 | 日韩一区正在播放 | 国模视频一区二区三区 | 97操碰 | 国产精品黑丝在线观看 | 国产精品久久久久久久久久久久久久 | 激情视频区| 日韩成人邪恶影片 | 久久线视频 | 亚洲视频999 | 免费日韩在线 | 久久视频在线免费观看 | 97在线观视频免费观看 | 五月亚洲综合 | 国产乱对白刺激视频在线观看女王 | 国产精品18久久久久久不卡孕妇 | 制服丝袜欧美 | 欧美日韩在线视频观看 | 欧美精品一区在线发布 | 四虎成人精品在永久免费 | 欧美日韩不卡在线观看 | 99久久99久久综合 | 天天草天天摸 | 国产精品久久久久久久久岛 | 在线播放第一页 | 天天操天天色天天射 | 超级碰碰碰免费视频 | 久久国产精品一区二区三区 | 国产精品一区二区三区久久 | 97在线免费视频观看 | 亚洲最新av网址 | 免费看污的网站 | 涩涩网站在线观看 | 日韩高清观看 | 日韩精品欧美视频 | 国产黄色片久久 | av短片在线观看 | 国产精品一区二区久久精品 | 日韩综合一区二区三区 | 美女免费黄网站 | 中文字幕一区在线观看视频 | 国产精品99页 | 欧美另类人妖 | 色com | 天天操天天舔天天爽 | 国产黄色看片 | 成在线播放 | 蜜桃视频日韩 | 亚洲视频专区在线 | 91精品啪在线观看国产线免费 | 成人h在线播放 | 久久超级碰视频 | 最新日本中文字幕 | 一区二区三区在线不卡 | 青青草久草在线 | 久久国产二区 | 成人在线视频在线观看 | 亚洲精品ww | 国产成人一区二区三区在线观看 | 欧美日韩视频在线 | 国产成人91 | 日韩美女久久 | 视频在线一区二区三区 | 国产精品久久久久久久免费观看 | 久久五月网 | 久久久这里有精品 | 天天操夜夜爱 | 91大神在线看 | 东方av在线免费观看 | 成人黄色大片网站 | 99视频在线免费播放 | 久久亚洲福利视频 | 中文字幕在线影视资源 | 成人精品视频久久久久 | 中文字幕国内精品 | 免费人人干 | 国产精品久久亚洲 | 一区 二区电影免费在线观看 | 国产高清免费观看 | 亚洲精品91天天久久人人 | 成人在线电影观看 | 黄色三级网站在线观看 | 九九一级片 | 色中色亚洲 | 成人免费看视频 | 天天射夜夜爽 | 亚洲涩涩网 | 日韩av片无码一区二区不卡电影 | 三上悠亚一区二区在线观看 | 久久久久免费 | 日日射av| 国产精品地址 | 国产成人99久久亚洲综合精品 | 欧美一区二区三区在线观看 | 黄色一区二区在线观看 | 国产69精品久久app免费版 | 日本精品视频一区二区 | 婷婷色 亚洲 | 亚洲精品永久免费视频 | 亚洲精品视频观看 | 日日日视频 | 97av精品| 日韩欧美精品在线观看视频 | 人人澡人人添人人爽一区二区 | 欧美性爽爽 | 国产亚洲无| 综合久久网 | 黄色成人免费电影 | 国产中文 | 国产精品第7页 | 97精品国产aⅴ | 久久伊人精品一区二区三区 | 久艹在线观看视频 | 天天色 天天 | 欧美一区二区精美视频 | 91在线看片 | 亚洲激情在线观看 | 四虎影视成人永久免费观看亚洲欧美 | 99热官网 | 久久婷综合 | 欧美性护士| 在线看污网站 | 蜜臀av网址 | 成人免费观看av | 444av| 欧美成年性 | 国产精品久久久久久999 | 日韩精品欧美一区 | 天天操天天射天天 | 亚洲人天堂 | 精品久久久国产 | 最近中文国产在线视频 | 又黄又爽又色无遮挡免费 | 99色在线视频 | 成人一区二区在线观看 | 一级片免费观看视频 | 四虎免费在线观看视频 | av福利在线免费观看 | 五月激情视频 | 午夜精品视频一区二区三区在线看 | 精精国产xxxx视频在线播放 | 久久久精品 一区二区三区 国产99视频在线观看 | 四虎精品成人免费网站 | 亚洲天堂在线观看完整版 | 亚洲一区在线看 | 久久精品免费电影 | 麻豆免费看片 | 视频高清 | 香蕉在线观看视频 | 九九精品视频在线观看 | 99久久夜色精品国产亚洲 | 超级碰碰碰视频 | 久久久久久久影院 | 国产视频九色蝌蚪 | 久久九九久久精品 | 欧美日韩二三区 | 在线免费观看欧美日韩 | 免费在线激情视频 | 日韩欧美国产精品 | 91av网址 | 免费观看黄 | 日韩亚洲精品电影 | 97成人免费视频 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 91av精品| 国产精品综合久久久 | 一区二区视频电影在线观看 | 中文字幕一区二区三 | 久久久久综合精品福利啪啪 | 久草视频看看 | 久久精品一二三 | 91中文字幕在线观看 | 国产一级二级三级视频 | 亚洲在线看 | 免费观看久久久 | 久久久久久福利 | 国产一区二区在线播放 | 99久久精品免费看国产四区 | 成人国产精品一区 | 97超碰免费| 婷婷亚洲综合五月天小说 | 日韩精品最新在线观看 | 国产精品一区二区三区四 | 日日噜噜噜噜夜夜爽亚洲精品 | 午夜精品视频免费在线观看 | 九九热视频在线播放 | 亚洲精品国产欧美在线观看 | 日韩在线二区 | 午夜精品久久久久久 | 国产 欧美 日产久久 | 国产精品一区二区白浆 | 久久综合射 | 一本色道久久精品 | 久久手机精品视频 | 国产一区二区三区免费视频 | 亚洲黄色小说网 | 午夜精品久久久久久久99婷婷 | 国产黄色精品 | 天天舔夜夜操 | 在线观看激情av | 99色资源 | 国产精品久久三 | 91精品一区二区三区蜜臀 | 久久久www| 一区二区精 | 中文字幕高清有码 | 九九交易行官网 | 中文字幕国产视频 | 麻豆视频在线观看 | 午夜私人影院久久久久 | 美女国产免费 | 国产精品毛片一区二区 | 中文字幕日韩一区二区三区不卡 | 国产一级免费av | 制服丝袜欧美 | www.天天综合 | 国产喷水在线 | 一区二区不卡 | 在线免费观看麻豆视频 | 成年人免费看的视频 | 欧美日韩精品免费观看 | 国产成人高清av | 国产精品女主播一区二区三区 | www.xxx.性狂虐| 久久精品99久久久久久2456 | 四虎影视精品 | 亚洲不卡av一区二区三区 | 精选久久 | 国产色黄网站 | 日韩r级电影在线观看 | 三级视频国产 | 91在线免费公开视频 | ,午夜性刺激免费看视频 | 美女福利视频一区二区 | av电影不卡在线 | 97精品国产97久久久久久 | 国产欧美中文字幕 | 91手机视频在线 | www久久99| 97成人在线观看 | 成人观看 | 91成人精品一区在线播放69 | 成人免费在线视频观看 | 四虎影视8848dvd | 99热这里只有精品8 久久综合毛片 | av免费福利 | 国产一级淫片免费看 | 91在线影院| 人人狠| 国产高清在线观看 | 最新黄色av网址 | 黄网站污| 国产一级h | h文在线观看免费 | 久久久一本精品99久久精品66 | 精品国产1区2区 | 成人超碰在线 | 99热最新 | 欧美激情综合色综合啪啪五月 | 日韩在线免费视频 | 亚洲五月婷婷 | 99国产精品免费网站 | 成人免费在线视频 | 亚洲精品福利在线观看 | av电影免费在线播放 | 亚洲免费a | 性色av香蕉一区二区 | 视频成人永久免费视频 | 国产成人一区二区啪在线观看 | 一区二区三区四区影院 | 99久久99久久精品国产片 | 国产精品久久久久av免费 | 日韩中文字幕第一页 | 亚洲区精品 | www五月天婷婷| 成人久久精品 | 天天天色综合a | 天堂在线视频免费观看 | 日韩理论在线观看 | 中国老女人日b | 欧美精品一区二区在线观看 | 国产美女免费看 | 国产不卡av在线播放 | 色婷婷av一区二 | www.日日操.com| 国产精品av免费 | 久草在线免费电影 | 色综合久久久久久久 | 日韩av一卡二卡三卡 | 亚洲精品国产精品久久99 | 久久黄色免费观看 | 色噜噜在线观看 | 欧洲一区二区三区精品 | 久免费视频 | 亚洲午夜精品久久久久久久久久久久 | 免费在线国产 | 成人午夜剧场在线观看 | 国产精品久久片 | 黄色片网站av | 欧美久久九九 | 一区二区三区电影 | 国产精品一区久久久久 | 久久黄网站| 在线视频日韩精品 | 九九免费在线看完整版 | 在线a视频免费观看 | 国产精品欧美久久久久三级 | 久久av中文字幕片 | 国产视频一二三 | 亚洲一级理论片 | 国产 中文 日韩 欧美 | 久久久久久久av麻豆果冻 | 精品久久久久久久久久 | 婷婷五月在线视频 | 久久免费一级片 | 日韩欧美一区二区三区在线观看 | 亚洲日本在线一区 | 婷婷六月中文字幕 | 夜色成人av| 手机成人免费视频 | 伊人狠狠 | 婷婷色在线视频 | 九九九九九国产 | a视频在线观看免费 | 久精品视频在线 | 久久久影院一区二区三区 | 欧美午夜精品久久久久久孕妇 | 国产精品不卡在线观看 | 国产精品专区在线观看 | 亚洲成a人片综合在线 | 天天躁日日躁狠狠躁av中文 | 亚洲精品福利在线 | 四虎5151久久欧美毛片 | 美女免费视频一区 | 国产精品一区二区三区在线播放 | 日本在线成人 | 亚洲精品一区二区三区四区高清 | 日韩精品一区二区三区电影 | 国内精品久久久久影院日本资源 | 五月色综合 | 久久久久久久久亚洲精品 | 在线观看黄色小视频 | 亚洲女人天堂成人av在线 | va视频在线| 欧美五月婷婷 | av免费看在线 | 国产精品久久久久久久久久不蜜月 | 国产91全国探花系列在线播放 | 91在线麻豆| 亚洲精选久久 | 中文字幕在线免费播放 | 亚洲国产欧美在线人成大黄瓜 | 成人亚洲精品国产www | 伊人六月 | 久久久久久久免费 | 97成人精品区在线播放 | 日本中文字幕在线电影 | 国产精品资源在线观看 | 久久久久女人精品毛片 | 99免费在线视频 | 综合铜03| 亚洲天天在线 | 欧美va在线观看 | 精品女同一区二区三区在线观看 | 国产在线999 | 日韩免费一区二区在线观看 | 四虎永久国产精品 | 看全黄大色黄大片 | 亚洲视频999 | 在线a亚洲视频播放在线观看 | 韩国av电影在线观看 | 亚洲精品www | 久久国产精品免费看 | 成人一区影院 | 国产一级做a爱片久久毛片a | 国产1区在线观看 | 在线免费高清 | 青青河边草免费视频 | 99色国产 | 天天操天天干天天操天天干 | 婷婷色中文网 | 国产日韩欧美网站 | 五月婷婷久 | 人九九精品| 亚洲色图27p | 五月婷婷久草 | 成人a视频片观看免费 | 一区二区三区电影在线播 | 黄色毛片视频免费观看中文 | 日韩在线观看三区 | 欧美精品国产综合久久 | 日韩黄色av网站 | 久久久精品免费看 | 国产精品免费在线视频 | 91九色精品 | 国产精品va在线播放 | 国产精品久久久久久久久软件 | 成人av免费看 | 亚洲成av人片在线观看 | 麻豆久久一区二区 | 国产 日韩 欧美 中文 在线播放 | 国产小视频91| www178ccom视频在线 | 高潮毛片无遮挡高清免费 | x99av成人免费 | 免费日韩一区二区三区 | 亚洲精品小视频 | 欧美一级性生活 | 高清av网站| 亚洲美女精品视频 | 久久草视频 | 精品视频免费看 | 亚洲资源网| 午夜国产一区二区 | 亚洲自拍自偷 | 99亚洲精品视频 | 激情开心站 | 日韩电影在线一区 | 成人毛片在线视频 | 天天操天天爱天天干 | 国产v欧美 | 波多野结衣在线观看一区二区三区 | 日韩在线中文字幕 | 国产69久久久欧美一级 | 国产视频 亚洲视频 | 精品亚洲午夜久久久久91 | 黄色三级免费观看 | 免费观看性生活大片3 | 不卡的av在线 | 国产在线高清精品 | 96久久欧美麻豆网站 | 久久精品久久久久 | 久久精品久久国产 | 综合久久久久久 | 成年人免费在线 | 婷婷干五月 | 天天爽天天爽夜夜爽 | 免费在线激情电影 | www.天天色.com | 久久中文字幕视频 | 亚洲成aⅴ人在线观看 | 97视频网址 | 区一区二区三在线观看 | 国产视频在线免费 | 久久久久免费精品国产 | 国产丝袜一区二区三区 | 中文字幕在线字幕中文 | av一区二区三区在线观看 | 麻豆传媒视频在线播放 | 91中文字幕 | 最近2019年日本中文免费字幕 | 欧美美女视频在线观看 | 久久 国产一区 | 成人久久免费 | 亚洲涩综合 | 亚洲欧洲精品一区 | 99久久久久久国产精品 | 偷拍精品一区二区三区 | 日韩在线电影一区 | 久久久久草| 性色av免费在线观看 | 国产精品嫩草影院99网站 | 亚洲综合最新在线 | 波多在线视频 | 麻豆国产露脸在线观看 | 91激情视频在线观看 | 99热99热 | 免费网址在线播放 | 福利片视频区 | 激情综合色综合久久 | 国产在线视频不卡 | 国产精品成人在线 | 久久久久9999亚洲精品 | 天天综合久久 | 99电影| 久久久久久久影视 | 激情五月视频 | 婷婷色综合网 | 日韩在线国产 | 亚洲欧洲日韩在线观看 | 久久超碰97| 国产.精品.日韩.另类.中文.在线.播放 | 婷婷午夜 | 亚洲成人av一区二区 | 天天操人人干 | 免费观看的黄色 | 成人在线免费小视频 | 久久成人国产精品入口 | 国产成人精品一区在线 | 久久综合久久综合这里只有精品 | 五月婷婷视频在线观看 | 国产黄色高清 | www.夜夜操| 欧美性护士 | 亚洲精品在线观 | 国产伦精品一区二区三区免费 | 日韩av免费大片 | 亚洲伊人av| 成人精品99 | 黄色大片日本 | 久草在线久草在线2 | 狠狠狠狠狠狠狠干 | 婷婷六月激情 | 丁香六月综合网 | 五月天.com| 色婷婷国产在线 | 日韩资源视频 | 国产免费高清 | 91麻豆操 | 日韩一区二区三区不卡 | 亚洲码国产日韩欧美高潮在线播放 | 欧美极品在线播放 | 国产精品国产三级国产不产一地 | 中文字幕色网站 | 国产系列在线观看 | 人人爽人人爽人人片av | 97超碰国产精品 | 久久精品视频在线 | 国内免费久久久久久久久久久 | 日韩一区二区三区免费电影 | 99爱精品在线 | 国产麻豆精品一区 | 欧洲精品亚洲精品 | 中文字幕中文字幕在线中文字幕三区 | 成人国产精品久久久久久亚洲 | 91av在线免费看 | 不卡日韩av | 亚洲人成影院在线 | 色天天综合久久久久综合片 | 探花视频在线观看免费 | 综合色天天| 成人亚洲精品国产www | 免费日韩 精品中文字幕视频在线 | 欧美精选一区二区三区 | 中文字幕在线免费播放 | 国产美腿白丝袜足在线av | 国产精品久久影院 | 天天撸夜夜操 | 97超碰免费 | 一区中文字幕在线观看 | 国产精品黑丝在线观看 | 黄色亚洲免费 | 91免费看黄色 | 精品一区精品二区 | 国产福利91精品张津瑜 | 91超在线 | 精品一区二区6 | 国产在线视频一区二区三区 | 久久精选视频 | 98精品国产自产在线观看 | 欧美a性 | 精品一区二区在线免费观看 | 欧美精品一区二区在线播放 | 天天躁日日躁狠狠躁av麻豆 | 黄色av成人在线观看 | 一级黄色片网站 | 精品 激情 | 亚洲情婷婷 | 亚洲天天摸日日摸天天欢 | 日韩精品第1页 | 日韩伦理片一区二区三区 | 91九色蝌蚪视频 | 日韩精品一区二区三区高清免费 | 久草精品视频在线观看 | 超碰免费av | 国产在线更新 | 中文字幕九九 | 亚洲国产精品久久久 | 日本字幕网 | 毛片网站在线看 | 午夜国产福利在线观看 | 国产精品一区专区欧美日韩 | 99精品亚洲 | 91福利视频免费观看 | 色综合久久久久综合 | 97成人在线视频 | 国产日韩在线播放 | 日韩免费电影 | 午夜精品久久久久久久99热影院 | 日韩.com| 国产一区二区免费看 | 不卡av在线| 99热国内精品 | 成人av网址大全 | 伊人夜夜 | 国产精品一区二区在线免费观看 | 三级在线视频播放 | 九九九热精品 | 少妇自拍av | 色综合久久久久综合99 | 欧美亚洲国产日韩 | 亚洲精品观看 | 最近免费观看的电影完整版 | 欧美视频在线观看免费网址 | 91最新中文字幕 | 精品中文字幕在线播放 | 天天操综合网 | 久久精品视频观看 | 九九视频免费观看视频精品 | 高清精品在线 | 在线视频福利 | 91看片淫黄大片91 | 色吊丝在线永久观看最新版本 | 亚洲永久精品国产 | 亚洲国产中文字幕在线 | 一区二区三区在线播放 | 免费色网站 | 国产只有精品 | 操高跟美女 | 久草精品视频在线观看 | 成人毛片a | 久久久久久欧美二区电影网 | 在线天堂中文在线资源网 | 日韩视频一区二区三区 | 亚洲欧洲视频 | 国产精品午夜久久久久久99热 | 国产免费一区二区三区最新6 | 天天插天天 | 韩国精品在线 | 乱子伦av| 99视频在线免费观看 | 亚洲狠狠操 | 香蕉视频一级 | 欧美成人一区二区 | 免费三级大片 | av在线一| 制服丝袜在线91 | 久久久黄色 | 成年人免费在线观看网站 | 日韩黄色大片在线观看 | 久久夜色网 | 国产福利av在线 | 91高清免费在线观看 | 人人舔人人舔 | 四虎国产精品永久在线国在线 | 国产精品久久久久久久久免费 | 婷婷丁香在线 | 精品国产免费看 | 超碰97人人爱 | 国产精品久久久久久av | 中文字幕在线观看免费观看 | 欧美成人精品欧美一级乱黄 | 99精品免费 | 亚州天堂 | 中文字幕 在线 一 二 | 激情丁香5月 | 激情视频在线高清看 | 西西444www大胆无视频 | 久久久久久网站 |