Apache Hive Explained

Apache Hive
Author:Facebook, Inc.
Developer:Contributors
Latest Release Version:3.1.3
Latest Release Date:[1]
Latest Preview Version:4.0.0-beta-1
Operating System:Cross-platform
Programming Language:Java
Genre:Data warehouse
License:Apache License 2.0
Released:[2]
Language:SQL

Apache Hive is a data warehouse software project. It is built on top of Apache Hadoop for providing data query and analysis.[3] [4] Hive gives an SQL-like interface to query data stored in various databases and file systems that integrate with Hadoop. Traditional SQL queries must be implemented in the MapReduce Java API to execute SQL applications and queries over distributed data.

Hive provides the necessary SQL abstraction to integrate SQL-like queries (HiveQL) into the underlying Java without the need to implement queries in the low-level Java API. Hive facilitates the integration of SQL-based querying languages with Hadoop, which is commonly used in data warehousing applications.[5] While initially developed by Facebook, Apache Hive is used and developed by other companies such as Netflix and the Financial Industry Regulatory Authority (FINRA).[6] Amazon maintains a software fork of Apache Hive included in Amazon Elastic MapReduce on Amazon Web Services.[7]

Features

Apache Hive supports the analysis of large datasets stored in Hadoop's HDFS and compatible file systems such as Amazon S3 filesystem and Alluxio. It provides a SQL-like query language called HiveQL[8] with schema on read and transparently converts queries to MapReduce, Apache Tez[9] and Spark jobs. All three execution engines can run in Hadoop's resource negotiator, YARN (Yet Another Resource Negotiator). To accelerate queries, it provided indexes, but this feature was removed in version 3.0[10] Other features of Hive include:

By default, Hive stores metadata in an embedded Apache Derby database, and other client/server databases like MySQL can optionally be used.[11]

The first four file formats supported in Hive were plain text,[12] sequence file, optimized row columnar (ORC) format[13] [14] and RCFile.[15] [16] Apache Parquet can be read via plugin in versions later than 0.10 and natively starting at 0.13.[17] [18]

Architecture

Major components of the Hive architecture are:

HiveQL

While based on SQL, HiveQL does not strictly follow the full SQL-92 standard. HiveQL offers extensions not in SQL, including multi-table inserts, and creates tables as select. HiveQL lacked support for transactions and materialized views, and only limited subquery support.[24] [25] Support for insert, update, and delete with full ACID functionality was made available with release 0.14.[26]

Internally, a compiler translates HiveQL statements into a directed acyclic graph of MapReduce, Tez, or Spark jobs, which are submitted to Hadoop for execution.[27]

Example

The word count program counts the number of times each word occurs in the input. The word count can be written in HiveQL as:

DROP TABLE IF EXISTS docs;CREATE TABLE docs (line STRING);LOAD DATA INPATH 'input_file' OVERWRITE INTO TABLE docs;CREATE TABLE word_counts ASSELECT word, count(1) AS count FROM (SELECT explode(split(line, '\s')) AS word FROM docs) tempGROUP BY wordORDER BY word;A brief explanation of each of the statements is as follows:DROP TABLE IF EXISTS docs;CREATE TABLE docs (line STRING);Checks if table docs exists and drops it if it does. Creates a new table called docs with a single column of type STRING called line.LOAD DATA INPATH 'input_file' OVERWRITE INTO TABLE docs;Loads the specified file or directory (In this case “input_file”) into the table. OVERWRITE specifies that the target table to which the data is being loaded into is to be re-written; Otherwise, the data would be appended.CREATE TABLE word_counts ASSELECT word, count(1) AS count FROM(SELECT explode(split(line, '\s')) AS word FROM docs) tempGROUP BY wordORDER BY word;The query creates a table called word_counts with two columns: word and count. This query draws its input from the inner query . This query serves to split the input words into different rows of a temporary table aliased as temp. The groups the results based on their keys. This results in the count column holding the number of occurrences for each word of the word column. The sorts the words alphabetically.

Comparison with traditional databases

The storage and querying operations of Hive closely resemble those of traditional databases. While Hive is a SQL dialect, there are a lot of differences in structure and working of Hive in comparison to relational databases. The differences are mainly because Hive is built on top of the Hadoop ecosystem, and has to comply with the restrictions of Hadoop and MapReduce.

A schema is applied to a table in traditional databases. In such traditional databases, the table typically enforces the schema when the data is loaded into the table. This enables the database to make sure that the data entered follows the representation of the table as specified by the table definition. This design is called schema on write. In comparison, Hive does not verify the data against the table schema on write. Instead, it subsequently does run time checks when the data is read. This model is called schema on read. The two approaches have their own advantages and drawbacks.

Checking data against table schema during the load time adds extra overhead, which is why traditional databases take a longer time to load data. Quality checks are performed against the data at the load time to ensure that the data is not corrupt. Early detection of corrupt data ensures early exception handling. Since the tables are forced to match the schema after/during the data load, it has better query time performance. Hive, on the other hand, can load data dynamically without any schema check, ensuring a fast initial load, but with the drawback of comparatively slower performance at query time. Hive does have an advantage when the schema is not available at the load time, but is instead generated later dynamically.

Transactions are key operations in traditional databases. As any typical RDBMS, Hive supports all four properties of transactions (ACID): Atomicity, Consistency, Isolation, and Durability. Transactions in Hive were introduced in Hive 0.13 but were only limited to the partition level.[28] The recent version of Hive 0.14 had these functions fully added to support complete ACID properties. Hive 0.14 and later provides different row level transactions such as INSERT, DELETE and UPDATE.[29] Enabling INSERT, UPDATE, and DELETE transactions require setting appropriate values for configuration properties such as hive.support.concurrency, hive.enforce.bucketing, and hive.exec.dynamic.partition.mode.[30]

Security

Hive v0.7.0 added integration with Hadoop security. Hadoop began using Kerberos authorization support to provide security. Kerberos allows for mutual authentication between client and server. In this system, the client's request for a ticket is passed along with the request. The previous versions of Hadoop had several issues such as users being able to spoof their username by setting the hadoop.job.ugi property and also MapReduce operations being run under the same user: Hadoop or mapred. With Hive v0.7.0's integration with Hadoop security, these issues have largely been fixed. TaskTracker jobs are run by the user who launched it and the username can no longer be spoofed by setting the hadoop.job.ugi property. Permissions for newly created files in Hive are dictated by the HDFS. The Hadoop distributed file system authorization model uses three entities: user, group and others with three permissions: read, write and execute. The default permissions for newly created files can be set by changing the unmask value for the Hive configuration variable hive.files.umask.value.

See also

Notes and References

  1. Web site: Apache Hive - Downloads. 21 November 2022.
  2. Web site: Release release-1.0.0 · apache/Hive. GitHub.
  3. Book: Venner, Jason . Pro Hadoop . registration . . 2009 . 978-1-4302-1942-2.
  4. Yin Huai, Ashutosh Chauhan, Alan Gates, Gunther Hagleitner, Eric N.Hanson, Owen O'Malley, Jitendra Pandey, Yuan Yuan, Rubao Lee, and Xiaodong Zhang. "Major Technical Advancements in Apache Hive" . SIGMOD' 14 . 2014 . 1235–1246. 10.1145/2588555.2595630.
  5. Book: Programming Hive [Book]].
  6. http://www.slideshare.net/evamtse/hive-user-group-presentation-from-netflix-3182010-3483386 Use Case Study of Hive/Hadoop
  7. http://s3.amazonaws.com/awsdocs/ElasticMapReduce/latest/emr-dg.pdf Amazon Elastic MapReduce Developer Guide
  8. https://cwiki.apache.org/confluence/display/Hive/LanguageManual HiveQL Language Manual
  9. http://tez.apache.org/ Apache Tez
  10. https://cwiki.apache.org/confluence/display/Hive/LanguageManual+Indexing#LanguageManualIndexing-IndexingIsRemovedsince3.0 Hive Language Manual
  11. Book: Lam, Chuck . Hadoop in Action . . 2010 . 978-1-935182-19-1.
  12. Web site: Optimising Hadoop and Big Data with Text and HiveOptimising Hadoop and Big Data with Text and Hive . 2014-11-16 . 2014-11-15 . https://web.archive.org/web/20141115010328/http://www.semantikoz.com/blog/optimising-hadoop-big-data-text-hive . dead .
  13. Web site: ORC Language Manual . Hive project wiki . April 24, 2017 .
  14. Yin Huai, Siyuan Ma, Rubao Lee, Owen O'Malley, and Xiaodong Zhang. "Understanding Insights into the Basic Structure and Essential Issues of Table Placement Methods in Clusters " . VLDB' 39 . 1750–1761. 2013 . 10.14778/2556549.2556559 . 10.1.1.406.4342 .
  15. Web site: Facebook's Petabyte Scale Data Warehouse using Hive and Hadoop . 2011-09-09 . https://web.archive.org/web/20110728063630/http://www.sfbayacm.org/wp/wp-content/uploads/2010/01/sig_2010_v21.pdf . 2011-07-28 . dead .
  16. Yongqiang He, Rubao Lee, Yin Huai, Zheng Shao, Namit Jain, Xiaodong Zhang, and Zhiwei Xu . "RCFile: A Fast and Space-efficient Data Placement Structure in MapReduce-based Warehouse Systems" . IEEE 27th International Conference on Data Engineering . 2011 .
  17. Web site: Parquet. 2 February 2015. https://web.archive.org/web/20150202145641/https://cwiki.apache.org/confluence/display/Hive/Parquet. 2 February 2015. 18 Dec 2014.
  18. Web site: Massie. Matt. A Powerful Big Data Trio: Spark, Parquet and Avro. zenfractal.com. 2 February 2015. https://web.archive.org/web/20150202145026/http://zenfractal.com/2013/08/21/a-powerful-big-data-trio/. 2 February 2015. 21 August 2013.
  19. Web site: Design - Apache Hive - Apache Software Foundation. cwiki.apache.org. 2016-09-12.
  20. Web site: Abstract Syntax Tree. c2.com. 2016-09-12.
  21. Dokeroglu. Tansel. Ozal. Serkan. Bayir. Murat Ali. Cinar. Muhammet Serkan. Cosar. Ahmet. 2014-07-29. Improving the performance of Hadoop Hive by sharing scan and computation tasks. Journal of Cloud Computing. en. 3. 1. 1–11. 10.1186/s13677-014-0012-6. free.
  22. Rubao Lee, Tian Luo, Yin Huai, Fusheng Wang, Yongqiang He, and Xiaodong Zhang. "YSmart: Yet Another SQL-to-MapReduce Translator" . 31st International Conference on Distributed Computing Systems . 2011 . 25–36.
  23. Web site: HiveServer - Apache Hive - Apache Software Foundation. cwiki.apache.org. 2016-09-12.
  24. Book: White, Tom . Hadoop: The Definitive Guide . registration . . 2010 . 978-1-4493-8973-4.
  25. https://cwiki.apache.org/confluence/display/Hive/LanguageManual Hive Language Manual
  26. https://cwiki.apache.org/confluence/display/Hive/Hive+Transactions ACID and Transactions in Hive
  27. Web site: Hive A Warehousing Solution Over a MapReduce Framework . 2011-09-03 . https://web.archive.org/web/20131008161608/http://www.vldb.org/pvldb/2/vldb09-938.pdf . 2013-10-08 . dead .
  28. Web site: Introduction to Hive transactions. datametica.com. 2016-09-12. https://web.archive.org/web/20160903210039/http://datametica.com/introduction-to-hive-transactions. 2016-09-03. dead.
  29. Web site: Hive Transactions - Apache Hive - Apache Software Foundation. cwiki.apache.org. 2016-09-12.
  30. Web site: Configuration Properties - Apache Hive - Apache Software Foundation. cwiki.apache.org. 2016-09-12.