Mirror of Apache Jackrabbit Oak
Java Groovy JavaScript CSS Shell Perl
Latest commit 4a48052 Oct 25, 2016 @mduerig mduerig OAK-5003: no output from oak-run check
Add missing logger configuration for oak-segment-tar

git-svn-id: https://svn.apache.org/repos/asf/jackrabbit/oak/trunk@1766589 13f79535-47bb-0310-9956-ffa450edef68
Failed to load latest commit information.
oak-auth-external OAK-4930: External Principal Management: DynamicSyncContext makes red… Oct 14, 2016
oak-auth-ldap OAK-4931: LdapIdentityProvider doesn't use configured custom attribut… Oct 13, 2016
oak-authorization-cug [maven-release-plugin] prepare for next development iteration Oct 11, 2016
oak-blob-cloud OAK-4870: removed surplus semicolon causing Eclipse compilation failu… Oct 25, 2016
oak-blob OAK-4979: Caching sub-system implementation for DataStore Oct 24, 2016
oak-commons OAK-4467: Upgrade io-commons to 2.5 and remove ReversedLinesFileReader Oct 12, 2016
oak-core OAK-4986: RDBDocumentStore: potential NPE in document read Oct 25, 2016
oak-doc OAK-4900: Enable persistent caches by default Oct 19, 2016
oak-examples OAK-4467: Upgrade io-commons to 2.5 and remove ReversedLinesFileReader Oct 12, 2016
oak-exercise [maven-release-plugin] prepare for next development iteration Oct 11, 2016
oak-http [maven-release-plugin] prepare for next development iteration Oct 11, 2016
oak-it-osgi OAK-4971: Implement caching for FileDataStore Oct 24, 2016
oak-it OAK-4868: Update SegmentS3DataStoreBlobGCTest in oak-it once oak-segm… Oct 25, 2016
oak-jcr OAK-4993: Report plan when QueryTest.nodeType() fails Oct 25, 2016
oak-lucene OAK-4929 Clean GCMonitor#compacted method arguments Oct 17, 2016
oak-parent OAK-4985: Upgrade Oak Segment Tar dependency to 0.0.16 Oct 24, 2016
oak-pojosr OAK-4862 - Provide a MemoryNodeStoreService Oct 25, 2016
oak-remote [maven-release-plugin] prepare for next development iteration Oct 11, 2016
oak-run OAK-5003: no output from oak-run check Oct 25, 2016
oak-segment-tar OAK-5002: NPE when creating read only store Oct 25, 2016
oak-segment OAK-4992 - Use the role name as prefix for directory used by SegmentN… Oct 25, 2016
oak-solr-core [maven-release-plugin] prepare for next development iteration Oct 11, 2016
oak-solr-osgi [maven-release-plugin] prepare for next development iteration Oct 11, 2016
oak-tarmk-standby [maven-release-plugin] prepare for next development iteration Oct 11, 2016
oak-upgrade OAK-4983: Add --verify mode to the RepositorySidegrade Oct 25, 2016
.gitignore [trivia] ignored derby.log Apr 7, 2016
.travis.yml OAK-2629: Cleanup Oak Travis jobs Sep 9, 2015
LICENSE.txt OAK-1: Setup basic build structure Mar 6, 2012
NOTICE.txt Update trunk version to 1.1-SNAPSHOT Apr 16, 2014
README.md OAK-4189: Increase Java language level to 1.7 Jul 6, 2016
RELEASE-NOTES.txt Apache Jackrabbit Oak 1.5.12 Oct 11, 2016
analyze-hprof.pl OAK-641: Improved benchmark tooling Sep 19, 2013
assembly.xml OAK-42: Prepare for first release Mar 29, 2012
check_staged_release.sh OAK-3483 - progress indicator for check_staged_release script Oct 6, 2015
pom.xml [maven-release-plugin] prepare for next development iteration Oct 11, 2016


Jackrabbit Oak - the next generation content repository

Jackrabbit Oak is a scalable, high-performance hierarchical content repository designed for use as the foundation of modern world-class web sites and other demanding content applications.

The Oak effort is a part of the Apache Jackrabbit project. Apache Jackrabbit is a project of the Apache Software Foundation.

Getting Started

To get started with Oak, build the latest sources with Maven 3 and Java 7 (or higher) like this:

mvn clean install

To enable all integration tests, including the JCR TCK, use:

mvn clean install -PintegrationTesting

Before committing changes or submitting a patch, please make sure that the above integration testing build passes without errors. If you like, you can enable integration tests by default by setting the OAK_INTEGRATION_TESTING environment variable.

MongoDB integration

Parts of the Oak build expects a MongoDB instance to be available for testing. By default a MongoDB instance running on localhost is expected, and the relevant tests are simply skipped if such an instance is not found. You can also configure the build to use custom MongoDB settings with the following properties (shown with their default values):


Note that the configured test databases will be dropped by the test cases.


The build consists of the following main components:

  • oak-parent - parent POM
  • oak-doc - Oak documentation
  • oak-commons - shared utility code
  • oak-core - Oak repository API and implementation
  • oak-jcr - JCR binding for the Oak repository
  • oak-sling - integration with Apache Sling
  • oak-solr-core - Apache Solr indexing and search
  • oak-solr-embedded - Apache Solr on an embedded Solr instance
  • oak-solr-remote - Apache Solr on an remote (HTTP) Solr instance
  • oak-http - HTTP binding for Oak
  • oak-lucene - Lucene-based query index
  • oak-run - runnable jar packaging
  • oak-pojosr - integration with PojoSR
  • oak-upgrade - tooling for upgrading Jackrabbit repositories to Oak
  • oak-it - integration tests
    • oak-it/osgi - integration tests for OSGi
  • oak-exercise - Oak training material


The following components have been moved to the Jackrabbit Attic:

  • oak-mk-api - MicroKernel API (deprecated, see OAK-2701)
  • oak-mk - MicroKernel implementation (see OAK-2702)
  • oak-mk-remote - MicroKernel remoting (see OAK-2693)
  • oak-it/mk - integration tests for MicroKernel


(see LICENSE.txt for full license details)

Collective work: Copyright 2014 The Apache Software Foundation.

Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements. See the NOTICE file distributed with this work for additional information regarding copyright ownership. The ASF licenses this file to You under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at


Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.