The Carbondata connector allows querying data stored in a Carbondata warehouse. Carbondata is a combination of three components:
- Data files in carbondata storage formats that are typically stored in the Hadoop Distributed File System (HDFS).
- This metadata is only for table and column schema validation. carbondata metadata is stored along with the data files and is accessed via the Hive Metastore Service(HMS).
- A query language called HiveQL/SparkSQL. This query language is executed on a distributed computing framework such as MapReduce or Spark.
openLooKeng only uses the first two components: the data and the metadata. It does not use HiveQL/SparkSQL or any part of Hive’s execution environment.
Note: Carbondata 2.0.1 is supported from openLooKeng
The Carbondata connector supports Apache Hadoop 2.x and above.
etc/catalog/carbondata.properties with the following contents to mount the
carbondata connector as the
carbondata catalog, replacing
example.net:9083 with the correct host and port for your Hive Metastore Thrift service:
For basic setups, openLooKeng configures the HDFS client automatically and does not require any configuration files. In some cases, such as when using federated HDFS or NameNode high availability, it is necessary to specify additional HDFS client options in order to access HDFS cluster. To do so, add the
hive.config.resources property to reference your HDFS config files:
Only specify additional configuration files if necessary for setup. It is also recommended reducing the configuration files to have the minimum set of required properties, as additional properties may cause problems.
The configuration files must exist on all openLooKeng nodes. If user is referencing existing Hadoop config files, make sure to copy them to any openLooKeng nodes that are not running Hadoop.
HDFS Username and Permissions
Before running any
CREATE TABLE or
CREATE TABLE AS statements for Carbondata tables, openLooKeng should have access to Hive and HDFS. The Hive warehouse directory is specified by the configuration variable
hive-site.xml, and the default value is
When not using Kerberos with HDFS, openLooKeng will access HDFS using the OS user of the openLooKeng process. For example, if openLooKeng is running as
nobody, it will access HDFS as
nobody. You can override this username by setting the
HADOOP_USER_NAME system property in the openLooKeng JVM Config, replacing
hdfs_user with the appropriate username:
hive user generally works, since Hive is often started with the
hive user and this user has access to the Hive warehouse.
Whenever you change the user which openLooKeng is using to access HDFS, remove
/tmp/openlookeng-*,/tmp/presto-*,/tmp/hetu-* on HDFS, as new user may not have access to the existing temporary directories.
Accessing Hadoop clusters protected with Kerberos authentication
Kerberos authentication is supported for both HDFS and the Hive metastore. However, Kerberos authentication by ticket cache is not yet supported.
The properties that apply to Carbondata connector security are listed in the Carbondata Configuration Properties table. Please see the Hive Security Configuration section for a more detailed discussion of the security options.
Carbondata Configuration Properties
|Specifies the location of the storage for carbondata warehouse. If not specified, it uses default hive warehouse path, i.e /user/hive/warehouse/carbon.store|
|Specifies the number of segments that may be considered for Minor Vacuum on a Carbondata table. If not specified or set to a number < 2, all available segments are considered|
|Specifies the size limit (in GB) for Major Vacuum on a Carbondata table. All segments whose cumulative size is less than this threshold will be considered. If not specified, it uses default Vacuum value, i.e 1GB|
|The type of Hive metastore to use. openLooKeng currently supports the default Hive Thrift metastore (|
|A comma-separated list of HDFS configuration files. These files must exist on the machines running openLooKeng. Example: |
|HDFS authentication type. Possible values are |
|Enable HDFS end user impersonation.|
|The Kerberos principal that openLooKeng will use when connecting to HDFS.|
|HDFS client keytab location.|
|Enables automatic column level statistics collection on write. See Table Statistics for details.|
|Specifies number of threads for Auto-Vacuum & Auto-cleanup. Min value is 1.||2|
|Enable auto-vacuum on carbondata tables. To enable auto-vacuum on engine side, add ||false|
Hive Thrift Metastore Configuration Properties
|The URI(s) of the Hive metastore to connect to using the Thrift protocol. If multiple URIs are provided, the first URI is used by default and the rest of the URIs are fallback metastores. This property is required. Example: |
|The username openLooKeng will use to access the Hive metastore.|
|Hive metastore authentication type. Possible values are |
|The Kerberos principal of the Hive metastore service.|
|The Kerberos principal that openLooKeng will use when connecting to the Hive metastore service.|
|Hive metastore client keytab location.|
When writing data, the Carbondata connector always collects basic statistics (
totalSize) and by default will also collect column level statistics:
|Column Type||Null-Count||Distinct values count||Min/Max|
After the vacuum operation is completed on carbon tables, there will be unused base/stale folders & files (Ex: Segment folders, .segment and .lock files) which are left in HDFS. So Carbondata Auto cleanup is used to cleanup those files automatically. Segment folders and .segment files are deleted at the time of insert, update, delete and vacuum after 60min (.lock files after 48 hours) of vacuum operation is completed.
The Carbondata connector supports querying and manipulating Carbondata tables and schemas (databases). Most operations can be performed using openLooKeng, while some uncommon operations will need to be performed using Spark::Carbondata directly.
Create a new table
CREATE TABLE orders ( orderkey bigint, orderstatus varchar, totalprice double, orderdate varchar );
|location||Specified directory is used to store table data.|
If absent, default file system location will be used.
Create a new table
orders at specified location:
CREATE TABLE orders_with_store_location ( orderkey bigint, orderstatus varchar, totalprice double, orderdate varchar ) WITH ( location = '/store/path' );
- If path is not fully qualified domain name, it will be stored in default file system.
Create Table as Select
Creates a new table based on the output of a SELECT statement
CREATE TABLE delivered_orders AS SELECT * FROM orders WHERE orderstatus = 'Delivered';
CREATE TABLE backup_orders WITH ( location = '/backup/store/path' ) AS SELECT * FROM orders_with_store_location;
Load additional rows into the
INSERT INTO orders VALUES (BIGINT '101', 'Ready', 1000.25, '2020-06-08');
Load additional rows into the
orders table by overwriting the existing rows:
INSERT OVERWRITE orders VALUES (BIGINT '101', 'Delivered', 1040.25, '2020-06-26');
Load additional rows into the
orders table with values from another table;
INSERT INTO orders SELECT * FROM delivered_orders;
Update all rows of table
UPDATE orders SET orderstatus = 'Ready';
orders with filter condition:
UPDATE orders SET orderstatus = 'Delivered' WHERE totalprice >1000 AND totalprice < 2000;
Delete all rows in table
DELETE FROM orders;
orders with filter condition::
DELETE FROM orders WHERE orderstatus = 'Not Available';
Drop an existing table.
DROP TABLE orders;
Vacuum operation translates to
compaction in Carbondata. In Carbondata there are two types of vacuum operation,
The following is a short description of the mapping between VACUUM and Carbondata compaction-
VACUUM TABLE table_name FULLtranslates to Major compaction which compacts segments based on a cumulative size restriction.
VACUUM TABLE table_nametranslates to Minor compaction which compacts segments based on a count restriction.
The below operation triggers Minor Vacuum on a table with name,
carbondata_table to merge multiple segments to a single segment.
VACUUM TABLE carbondata_table;
Major Vacuum merges the segments based on their sizes. As long as the total size of all segments being merged doesn’t exceed a certain value, they are all compacted into a single new segment.
VACUUM TABLE carbondata_table FULL;
Support for AND WAIT
Both Minor and Major Vacuum operations can be executed in a synchronous manner using the following commands-
VACUUM TABLE carbondata_table (FULL) AND WAIT;
This will also display the number of rows in the table that are being compacted.
Carbondata Connector Limitations
The following operations are not supported currently with Carbondata connector:
partitioned_bytable properties are not supported while
- Materialized views are not supported.
- Complex data types such as Arrays, Lists and Maps are not supported.
- Alter table usage is not supported.
- Operation on partitioned tables is not supported.