Skip to content

Graph Configuration

Daniel Kuppitz edited this page Aug 30, 2013 · 33 revisions

This page summarizes Titan’s configurations options. To configure a TitanGraph invoke the TitanFactory.open() method with a commons configuration object or the file name of a properties configuration file. The TitanFactory will return a TitanGraph according to the configuration.

The following example opens a TitanGraph with the configured local storage directory.

Configuration conf = new BaseConfiguration();
conf.setProperty("storage.directory","/tmp/titan");
TitanGraph g = TitanFactory.open(conf);

Alternatively, we could have written the configuration into a properties file and opened a TitanGraph as follows
TitanGraph g = TitanFactory.open("/tmp/titan/configuration.properties");

It is very important to note that some configuration options should NEVER be modified after the TitanGraph is first initialized. Doing so may corrupt the graph or lead to unexpected behavior. The modifiable column indicates whether a particular configuration option can be changed after the graph has been created.

Storage Configuration

Titan leverages various storage backends for persistence. Use the following options to configure one of the pre-defined storage backends or your own. Particular storage backends may provide or require additional configuration options. For more information on how to configure a TitanGraph over Cassandra or HBase please review the respective wiki pages.

Option Description Value Default Modifiable
storage.backend Full class name of the StorageManager implementation defining the storage backend to be used for persistence or one of the following pre-defined storage backends: cassandra, hbase, local Class name or pre-defined short-hand local no
storage.directory Storage directory for those storage backends that require local storage path no
storage.read-only Specifies whether write operations are supported on the graph true or false false yes
storage.batch-loading Enables batch loading which improves write performance but assumes that only one thread is interacting with the graph and that vertices retrieved by id exist. Under these assumptions locking and some read operations can be avoided. Furthermore, the configured storage backend will make backend specific configurations that facilitate loading performance. Be careful: enabling batch loading when the assumptions are violated can result in an inconsistent or partially corrupt graph. true or false false yes
storage.buffer-size Buffers graph mutations locally up to the specified number before persisting them against the storage backend. Set to 0 to disable buffering. Buffering is disabled automatically if the storage backend does not support buffered mutations. >0 1024 yes
storage.write-attempts Number of times the database attempts to persist the transactional state to the storage layer. >0 5 yes
storage.read-attempts Number of times the database attempts to execute a read operation against the storage layer in the current transaction. >0 3 yes
storage.attempt-wait Time in milliseconds that Titan waits after an unsuccessful storage attempt before retrying. >=0 250 yes

ID Management Configuration

These configuration settings how Titan allocates and assigns ids.

Option Description Value Default Modifiable
ids.block-size Size of the id block to be acquired. Larger block sizes require fewer block applications but also leave a larger fraction of the id pool occupied and potentially lost. For write heavy applications, larger block sizes should be chosen. positive integer 10,000 No*
ids.flush If flush ids is enabled, vertices and edges are assigned ids immediately upon creation. If not, then ids are only assigned when the transaction is committed. true or false true yes
ids.renew-timeout Number of milliseconds Titan’s id pool manager will wait while attempting to acquire a new id block before failing. Time in ms 60000 yes
ids.renew-percentage Threshold percentage of ids left in the pool before Titan’s id pool manager starts acquiring a new id block. A smaller percentage reduces potential id waste but can lead to delays when the current id block is exhausted. Percentage 0.3 yes

Distributed Locking and ID Management Configuration

When Titan is used in distributed mode over multiple machines, locking may be required to ensure consistency of certain operations. In particular, locking is required when allocating id blocks for id assignment to individual TitanGraph instances. Locking is also required for certain key type configuration as described in Type Configuration. These options control how locks are acquired.

Option Description Value Default Modifiable
storage.machine-id A unique identifier for the machine running the TitanGraph instance. Ensures that no other machine accessing the storage backend can have the same identifier. String Machine IP Yes
storage.machine-id-appendix A locally unique identifier for a particular TitanGraph instance. This only needs to be configured when multiple TitanGraph instances are running on the same machine. A unique machine specific appendix guarantees a globally unique identifier. short integer 0 Yes
storage.lock-wait-time The number of milliseconds the system waits for a lock application to be acknowledged by the storage backend. Also, the time waited at the end of all lock applications before verifying that the applications were successful. This value should be a small multiple of the average consistent write time. positive integer 100 No
storage.lock-retries Number of times the system attempts to acquire a lock before giving up and throwing an exception. positive integer 3 Yes
storage.lock-expiry-time Number of milliseconds after which a lock is considered to have expired. Lock applications that were not released are considered expired after this time and released. This value should be larger than the maximum time a transaction can take in order to guarantee that no correctly held applications are expired pre-maturely and as small as possible to avoid dead lock. positive integer 300,000 No
storage.idauthority-wait-time The number of milliseconds the system waits for an id block application to be acknowledged by the storage backend. Also, the time waited after the application before verifying that the application was successful. positive integer 300 No
storage.idauthority-retries Number of times the system attempts to acquire a unique id block before giving up and throwing an exception. positive integer 20 Yes

If the modifiable column has a No* this means that the option cannot be adjusted while Titan instances are running. To change the option, all Titan instances must be shutdown and the value must be changed across the entire cluster be starting instances again. Also note, that while all configuration options mentioned on this page must be identical for all Titan instances running in the same cluster, the storage.machine-id and storage.machine-id-appendix must be configured uniquely for each Titan instance individually unless the default values are chosen.

Distributed Storage Backend Configuration

These configuration options apply when Titan is used with a distributed storage backend, i.e. the data is stored across multiple machines. They control how Titan communicates with the storage backend cluster.

Option Description Value Default Modifiable
storage.setup-wait When Titan is started, it will attempt to communicate with the storage backend. If the backend cluster is in the process of starting up or otherwise not yet fully available, Titan will repeatedly re-attempt communication and wait for this long before failing. Time in ms 60000 Yes
storage.page-size Some Titan operations, like retrieving all vertices, require a lot of data to be retrieved from the storage cluster. Such operations are broken down into smaller batches and this option configures their size. The larger this value, the fewer requests need to be made but the longer each request takes. Integer 100 Yes

Index Configuration

Titan can interface with multiple external index systems to provide support for geo, numeric range, and full-text search. This configuration option tells Titan which indexing backend to use for a particular index identified by name.

Option Description Value Default Modifiable
storage.index.INDEX-NAME.backend Implementation of the index backend configured for INDEX-NAME. Additional configuration options specific to this index are configured in the same configuration namespace. Please refer to the documentation page of the index backend for more information elasticsearch or lucene none No

For more information on external indexes and how to configure a particular index system, please refer to Indexing Backend Overview.

General Configuration

This section contains general configuration options to customize Titan’s behavior.

Option Description Value Default Modifiable
autotype Specifies the factory to use when automatically creating types. See Default Type Creation for more details. blueprints or none blueprints Yes

Next Steps

This page lists all the common configuration options for Titan. Learn more about some special purpose configuration:

Each storage backend has additional configuration options which are listed on the following pages:

Each index backend has additional configuration options which are listed on the following pages: