Issue tracker | Getting started
If you are interested in YouTrackDB, consider joining our Zulip community. Tell us about exciting applications you are building, ask for help, or just chat with friends 😃
YouTrackDB is a general use object-oriented graph database. YouTrackDB is being supported and developed by JetBrains and is used internally in production.
YouTrackDB's key features are:
- Fast data processing: Links traversal is processed with O(1) complexity. There are no expensive run-time JOINs.
- Object-oriented API: This API implements rich graph and object-oriented data models. Fundamental concepts of inheritance and polymorphism are implemented on the database level.
- Snapshot isolation by default: All transactions run under snapshot isolation. Each transaction sees a stable snapshot of the database as of its start time, eliminating dirty reads, non-repeatable reads, and phantom reads.
- Implementation of TinkerPop API and Gremlin query language:
You can use both Gremlin query language for your queries and TinkerPop API out of the box.
Support of
GQLwith seamless integration withGremlinis in progress. For maximum query performance, we suggest using YQL for initial data prefetching. - YQL (YouTrackDB Query Language): A SQL-based query language with extensions for graph functionality. YQL uses intuitive dot notation for link traversal instead of JOINs, supports the powerful MATCH statement for graph pattern matching, and includes automatic index usage for query optimization.
- Scalable development workflow: YouTrackDB works in schema-less, schema-mixed, and schema-full modes.
- Strong security: A strong security profiling system based on user, role, and predicate security policies.
- Encryption of data at rest: Optionally encrypts all data stored on disk.
YouTrackDB can run on any platform without configuration and installation.
If you want to experiment with YouTrackDB, please check out our REPL console.
docker run -it youtrackdb/youtrackdb-consoleTo install YouTrackDB as an embedded database, add the following dependency to your Maven project:
<dependency>
<groupId>io.youtrackdb</groupId>
<artifactId>youtrackdb-embedded</artifactId>
<version>0.5.0-SNAPSHOT</version>
</dependency>The youtrackdb-embedded artifact is a shaded uber-jar that relocates all third-party
dependencies (Guava, Jackson, Groovy, etc.) under com.jetbrains.youtrackdb.shade,
so they won't conflict with versions used by your application.
You also need to add a YTDB snapshot repository to your Maven pom.xml file:
<repositories>
<repository>
<name>Central Portal Snapshots</name>
<id>central-portal-snapshots</id>
<url>https://central.sonatype.com/repository/maven-snapshots/</url>
<releases>
<enabled>false</enabled>
</releases>
<snapshots>
<enabled>true</enabled>
</snapshots>
</repository>
</repositories>or in case of Gradle:
dependencies {
implementation 'io.youtrackdb:youtrackdb-embedded:0.5.0-SNAPSHOT'
}
and
repositories {
maven {
url = uri("https://central.sonatype.com/repository/maven-snapshots/")
mavenContent {
snapshotsOnly()
}
}
}
If you want to work with YouTrackDB server, you can start it using the Docker image:
docker run -p 8182:8182 \
-v $(pwd)/secrets:/opt/ytdb-server/secrets \
-v $(pwd)/databases:/opt/ytdb-server/databases \
-v $(pwd)/conf:/opt/ytdb-server/conf \
-v $(pwd)/log:/opt/ytdb-server/log \
youtrackdb/youtrackdb-serverand provide root password for the database in the secrets/root_password file.
YouTrackDB requires at least JDK 21.
To learn how to use YouTrackDB, see the Getting Started guide.
For more examples covering both server and embedded deployments, check out the examples project.