Skip to main content
Version: 0.7.0-incubating

Apache Gravitino configuration

Introduction

Apache Gravitino supports several configurations:

  1. Gravitino server configuration: Used to start up the Gravitino server.
  2. Gravitino catalog properties configuration: Used to make default values for different catalogs.
  3. Some other configurations: Includes HDFS and other configurations.

Apache Gravitino server configurations

You can customize the Gravitino server by editing the configuration file gravitino.conf in the conf directory. The default values are sufficient for most use cases. We strongly recommend that you read the following sections to understand the configuration file, so you can change the default values to suit your specific situation and usage scenario.

The gravitino.conf file lists the configuration items in the following table. It groups those items into the following categories:

Apache Gravitino HTTP Server configuration

Configuration itemDescriptionDefault valueRequiredSince version
gravitino.server.webserver.hostThe host of the Gravitino server.0.0.0.0No0.1.0
gravitino.server.webserver.httpPortThe port on which the Gravitino server listens for incoming connections.8090No0.1.0
gravitino.server.webserver.minThreadsThe minimum number of threads in the thread pool used by the Jetty webserver. minThreads is 8 if the value is less than 8.Math.max(Math.min(Runtime.getRuntime().availableProcessors() * 2, 100), 8)No0.2.0
gravitino.server.webserver.maxThreadsThe maximum number of threads in the thread pool used by the Jetty webserver. maxThreads is 8 if the value is less than 8, and maxThreads must be great or equal to minThreads.Math.max(Runtime.getRuntime().availableProcessors() * 4, 400)No0.1.0
gravitino.server.webserver.threadPoolWorkQueueSizeThe size of the queue in the thread pool used by the Jetty webserver.100No0.1.0
gravitino.server.webserver.stopTimeoutTime in milliseconds to gracefully shut down the Jetty webserver, for more, please see org.eclipse.jetty.server.Server#setStopTimeout.30000No0.2.0
gravitino.server.webserver.idleTimeoutThe timeout in milliseconds of idle connections.30000No0.2.0
gravitino.server.webserver.requestHeaderSizeMaximum size of HTTP requests.131072No0.1.0
gravitino.server.webserver.responseHeaderSizeMaximum size of HTTP responses.131072No0.1.0
gravitino.server.shutdown.timeoutTime in milliseconds to gracefully shut down of the Gravitino webserver.3000No0.2.0
gravitino.server.webserver.customFiltersComma-separated list of filter class names to apply to the API.(none)No0.4.0
gravitino.server.rest.extensionPackagesComma-separated list of REST API packages to expand(none)No0.6.0-incubating

The filter in the customFilters should be a standard javax servlet filter. You can also specify filter parameters by setting configuration entries of the form gravitino.server.webserver.<class name of filter>.param.<param name>=<value>.

Storage configuration

Storage backend configuration

Currently, Gravitino only supports JDBC database backend, and the default implementation is H2 database as it's an embedded database, has no external dependencies and is very suitable for local development or tests. If you are going to use H2 in the production environment, Gravitino will not guarantee the data consistency and durability. It's highly recommended using MySQL as the backend database.

The following table lists the storage configuration items:

Configuration itemDescriptionDefault valueRequiredSince version
gravitino.entity.storeWhich entity storage implementation to use. Onlyrelational storage is currently supported.relationalNo0.1.0
gravitino.entity.serdeThe serialization/deserialization class used to support entity storage. `proto' is currently supported.protoNo0.1.0
gravitino.entity.store.maxTransactionSkewTimeMsThe maximum skew time of transactions in milliseconds.2000No0.3.0
gravitino.entity.store.kv.deleteAfterTimeMsIt is deprecated since Gravitino 0.5.0. Please use gravitino.entity.store.deleteAfterTimeMs instead.604800000(7 days)No0.3.0
gravitino.entity.store.deleteAfterTimeMsThe maximum time in milliseconds that deleted and old-version data is kept. Set to at least 10 minutes and no longer than 30 days.604800000(7 days)No0.5.0
gravitino.entity.store.versionRetentionCountThe Count of versions allowed to be retained, including the current version, used to delete old versions data. Set to at least 1 and no greater than 10.1No0.5.0
gravitino.entity.store.relationalDetailed implementation of Relational storage. H2, MySQL and PostgreSQL is currently supported, and the implementation is JDBCBackend.JDBCBackendNo0.5.0
gravitino.entity.store.relational.jdbcUrlThe database url that the JDBCBackend needs to connect to. If you use MySQL or PostgreSQL, you should firstly initialize the database tables yourself by executing the ddl scripts in the ${GRAVITINO_HOME}/scripts/{DATABASE_TYPE}/ directory.jdbc:h2No0.5.0
gravitino.entity.store.relational.jdbcDriverThe jdbc driver name that the JDBCBackend needs to use. You should place the driver Jar package in the ${GRAVITINO_HOME}/libs/ directory.org.h2.DriverYes if the jdbc connection url is not jdbc:h20.5.0
gravitino.entity.store.relational.jdbcUserThe username that the JDBCBackend needs to use when connecting the database. It is required for MySQL.gravitinoYes if the jdbc connection url is not jdbc:h20.5.0
gravitino.entity.store.relational.jdbcPasswordThe password that the JDBCBackend needs to use when connecting the database. It is required for MySQL.gravitinoYes if the jdbc connection url is not jdbc:h20.5.0
gravitino.entity.store.relational.storagePathThe storage path for embedded JDBC storage implementation. It supports both absolute and relative path, if the value is a relative path, the final path is ${GRAVITINO_HOME}/${PATH_YOU_HAVA_SET}, default value is ${GRAVITINO_HOME}/data/jdbc${GRAVITINO_HOME}/data/jdbcNo0.6.0-incubating
caution

We strongly recommend that you change the default value of gravitino.entity.store.relational.storagePath, as it's under the deployment directory and future version upgrades may remove it.

Create JDBC backend schema and table

For H2 database, All tables needed by Gravitino are created automatically when the Gravitino server starts up. For MySQL, you should firstly initialize the database tables yourself by executing the ddl scripts in the ${GRAVITINO_HOME}/scripts/mysql/ directory.

Tree lock configuration

Gravitino server uses tree lock to ensure the consistency of the data. The tree lock is a memory lock (Currently, Gravitino only supports in memory lock) that can be used to ensure the consistency of the data in Gravitino server. The configuration items are as follows:

Configuration itemDescriptionDefault valueRequiredSince Version
gravitino.lock.maxNodesThe maximum number of tree lock nodes to keep in memory100000No0.5.0
gravitino.lock.minNodesThe minimum number of tree lock nodes to keep in memory1000No0.5.0
gravitino.lock.cleanIntervalInSecsThe interval in seconds to clean up the stale tree lock nodes60No0.5.0

Catalog configuration

Configuration itemDescriptionDefault valueRequiredSince version
gravitino.catalog.cache.evictionIntervalMsThe interval in milliseconds to evict the catalog cache; default 3600000ms(1h).3600000No0.1.0
gravitino.catalog.classloader.isolatedWhether to use an isolated classloader for catalog. If true, an isolated classloader loads all catalog-related libraries and configurations, not the AppClassLoader. The default value is true.trueNo0.1.0

Auxiliary service configuration

Configuration itemDescriptionDefault valueSince Version
gravitino.auxService.names The auxiliary service name of the Gravitino Iceberg REST server. Use iceberg-rest for the Gravitino Iceberg REST server.(none)0.2.0

Refer to Iceberg REST catalog service for configuration details.

Event listener configuration

Gravitino provides event listener mechanism to allow users to capture the events which are provided by Gravitino server to integrate some custom operations.

To leverage the event listener, you must implement the EventListenerPlugin interface and place the JAR file in the classpath of the Gravitino server. Then, add configurations to gravitino.conf to enable the event listener.

Property nameDescriptionDefault valueRequiredSince Version
gravitino.eventListener.namesThe name of the event listener, For multiple listeners, separate names with a comma, like "audit,sync"(none)Yes0.5.0
gravitino.eventListener.{name}.classThe class name of the event listener, replace {name} with the actual listener name.(none)Yes0.5.0
gravitino.eventListener.{name}.{key}Custom properties that will be passed to the event listener plugin.(none)Yes0.5.0

Event

Gravitino triggers a pre-event before the operation, a post-event after the completion of the operation and a failure event after the operation failed.

Post-event
Operation typePost-eventSince Version
table operationCreateTableEvent, AlterTableEvent, DropTableEvent, LoadTableEvent, ListTableEvent, PurgeTableFailureEvent, CreateTableFailureEvent, AlterTableFailureEvent, DropTableFailureEvent, LoadTableFailureEvent, ListTableFailureEvent, PurgeTableFailureEvent0.5.0
fileset operationCreateFileSetEvent, AlterFileSetEvent, DropFileSetEvent, LoadFileSetEvent, ListFileSetEvent, CreateFileSetFailureEvent, AlterFileSetFailureEvent, DropFileSetFailureEvent, LoadFileSetFailureEvent, ListFileSetFailureEvent0.5.0
topic operationCreateTopicEvent, AlterTopicEvent, DropTopicEvent, LoadTopicEvent, ListTopicEvent, CreateTopicFailureEvent, AlterTopicFailureEvent, DropTopicFailureEvent, LoadTopicFailureEvent, ListTopicFailureEvent0.5.0
schema operationCreateSchemaEvent, AlterSchemaEvent, DropSchemaEvent, LoadSchemaEvent, ListSchemaEvent, CreateSchemaFailureEvent, AlterSchemaFailureEvent, DropSchemaFailureEvent, LoadSchemaFailureEvent, ListSchemaFailureEvent0.5.0
catalog operationCreateCatalogEvent, AlterCatalogEvent, DropCatalogEvent, LoadCatalogEvent, ListCatalogEvent, CreateCatalogFailureEvent, AlterCatalogFailureEvent, DropCatalogFailureEvent, LoadCatalogFailureEvent, ListCatalogFailureEvent0.5.0
metalake operationCreateMetalakeEvent, AlterMetalakeEvent, DropMetalakeEvent, LoadMetalakeEvent, ListMetalakeEvent, CreateMetalakeFailureEvent, AlterMetalakeFailureEvent, DropMetalakeFailureEvent, LoadMetalakeFailureEvent, ListMetalakeFailureEvent0.5.0
Iceberg REST server table operationIcebergCreateTableEvent, IcebergUpdateTableEvent, IcebergDropTableEvent, IcebergLoadTableEvent, IcebergListTableEvent, IcebergTableExistsEvent, IcebergRenameTableEvent, IcebergCreateTableFailureEvent, IcebergUpdateTableFailureEvent, IcebergDropTableFailureEvent, IcebergLoadTableFailureEvent, IcebergListTableFailureEvent, IcebergRenameTableFailureEvent, IcebergTableExistsFailureEvent0.7.0-incubating
Pre-event

Pre-event is only generated before Iceberg REST server table operations, the other operation doesn't generate pre-event for now.

Operation typePre-eventSince Version
Iceberg REST server table operationIcebergCreateTablePreEvent, IcebergUpdateTablePreEvent, IcebergDropTablePreEvent, IcebergLoadTablePreEvent, IcebergListTablePreEvent, IcebergTableExistsPreEvent, IcebergRenameTablePreEvent0.7.0-incubating

Event listener plugin

The EventListenerPlugin defines an interface for event listeners that manage the lifecycle and state of a plugin. This includes handling its initialization, startup, and shutdown processes, as well as handing events triggered by various operations.

The plugin provides several operational modes for how to process event, supporting both synchronous and asynchronous processing approaches.

  • SYNC: Events are processed synchronously, immediately following the associated operation. This mode ensures events are processed before the operation's result is returned to the client, but it may delay the main process if event processing takes too long.

  • ASYNC_SHARED: This mode employs a shared queue and dispatcher for asynchronous event processing. It prevents the main process from being blocked, though there's a risk events might be dropped if not promptly consumed. Sharing a dispatcher can lead to poor isolation in case of slow listeners.

  • ASYNC_ISOLATED: Events are processed asynchronously, with each listener having its own dedicated queue and dispatcher thread. This approach offers better isolation but at the expense of multiple queues and dispatchers.

When processing pre-event, you could throw a ForbiddenException to skip the following executions. For more details, please refer to the definition of the plugin.

Audit log configuration

The audit log framework defines how audit logs are formatted and written to various storages. The formatter defines an interface that transforms different Event types into a unified AuditLog. The writer defines an interface to writing AuditLog to different storages.

Gravitino provides a default implement to log basic audit information to a file, you could extend the audit system by implementation corresponding interfaces.

Property nameDescriptionDefault valueRequiredSince Version
gravitino.audit.enabledThe audit log enable flag.falseNO0.7.0-incubating
gravitino.audit.writer.classNameThe class name of audit log writer.org.apache.gravitino.audit.FileAuditWriterNO0.7.0-incubating
gravitino.audit.formatter.classNameThe class name of audit log formatter.org.apache.gravitino.audit.SimpleFormatterNO0.7.0-incubating

Audit log formatter

The Formatter defines an interface that formats metadata audit logs into a unified format. SimpleFormatter is a default implement to format audit information, you don't need to do extra configurations.

Audit log writer

The AuditLogWriter defines an interface that enables the writing of metadata audit logs to different storage mediums such as files, databases, etc.

Writer configuration begins with gravitino.audit.writer.${name}, where ${name} is replaced with the actual writer name defined in method name(). FileAuditWriter is a default implement to log audit information, whose name is file.

Property nameDescriptionDefault valueRequiredSince Version
gravitino.audit.writer.file.fileNameThe audit log file name, the path is ${sys:gravitino.log.path}/${fileName}.gravitino_audit.logNO0.7.0-incubating
gravitino.audit.writer.file.flushIntervalSecsThe flush interval time of the audit file in seconds.10NO0.7.0-incubating
gravitino.audit.writer.file.appendWhether the log will be written to the end or the beginning of the file.trueNO0.7.0-incubating

Security configuration

Refer to security for HTTPS and authentication configurations.

Metrics configuration

Property nameDescriptionDefault valueRequiredSince Version
gravitino.metrics.timeSlidingWindowSecsThe seconds of Gravitino metrics time sliding window60No0.5.1

Apache Gravitino catalog properties configuration

There are three types of catalog properties:

  1. Gravitino defined properties: Gravitino defines these properties as the necessary configurations for the catalog to work properly.
  2. Properties with the gravitino.bypass. prefix: These properties are not managed by Gravitino and pass directly to the underlying system for advanced usage.
  3. Other properties: Gravitino doesn't leverage these properties, just store them. Users can use them for their own purposes.

Catalog properties are either defined in catalog configuration files as default values or specified as properties explicitly when creating a catalog.

info

The catalog properties explicitly specified in the properties field take precedence over the default values in the catalog configuration file.

These rules only apply to the catalog properties and don't affect the schema or table properties.

Below is a list of catalog properties that will be used by all Gravitino catalogs:

Configuration itemDescriptionDefault valueRequiredSince version
packageThe path of the catalog package, Gravitino leverages this path to load the related catalog libs and configurations. The package should consist two folders, conf (for catalog related configurations) and libs (for catalog related dependencies/jars)(none)No0.5.0
cloud.nameThe property to specify the cloud that the catalog is running on. The valid values are aws, azure, gcp, on_premise and other.(none)No0.6.0-incubating
cloud.region-codeThe property to specify the region code of the cloud that the catalog is running on.(none)No0.6.0-incubating

The following table lists the catalog specific properties and their default paths:

catalog providercatalog propertiescatalog properties configuration file path
hiveHive catalog propertiescatalogs/hive/conf/hive.conf
lakehouse-icebergLakehouse Iceberg catalog propertiescatalogs/lakehouse-iceberg/conf/lakehouse-iceberg.conf
lakehouse-paimonLakehouse Paimon catalog propertiescatalogs/lakehouse-paimon/conf/lakehouse-paimon.conf
lakehouse-hudiLakehouse Hudi catalog propertiescatalogs/lakehouse-hudi/conf/lakehouse-hudi.conf
jdbc-mysqlMySQL catalog propertiescatalogs/jdbc-mysql/conf/jdbc-mysql.conf
jdbc-postgresqlPostgreSQL catalog propertiescatalogs/jdbc-postgresql/conf/jdbc-postgresql.conf
jdbc-dorisDoris catalog propertiescatalogs/jdbc-doris/conf/jdbc-doris.conf
jdbc-oceanbaseOceanBase catalog propertiescatalogs/jdbc-oceanbase/conf/jdbc-oceanbase.conf
kafkaKafka catalog propertiescatalogs/kafka/conf/kafka.conf
info

The Gravitino server automatically adds the catalog properties configuration directory to classpath.

Some other configurations

You could put HDFS configuration file to the catalog properties configuration dir, like catalogs/lakehouse-iceberg/conf/.

How to set up runtime environment variables

The Gravitino server lets you set up runtime environment variables by editing the gravitino-env.sh file, located in the conf directory.

How to access Apache Hadoop

Currently, due to the absence of a comprehensive user permission system, Gravitino can only use a single username for Apache Hadoop access. Ensure that the user starting the Gravitino server has Hadoop (HDFS, YARN, etc.) access permissions; otherwise, you may encounter a Permission denied error. There are two ways to resolve this error:

  • Grant Gravitino startup user permissions in Hadoop
  • Specify the authorized Hadoop username in the environment variables HADOOP_USER_NAME before starting the Gravitino server.