Release Notes -- Apache Jackrabbit Oak -- Version 1.80.0 Introduction ------------ 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. Apache Jackrabbit Oak 1.80.0 is an incremental feature release based on and compatible with earlier stable Jackrabbit Oak 1.x releases. This release is considered stable and targeted for production use. While Oak 1.80.0 compiles and tests successfully on Java 24. The Oak effort is a part of the Apache Jackrabbit project. Apache Jackrabbit is a project of the Apache Software Foundation. Changes in Oak 1.80.0 --------------------- Sub-task [OAK-11696] - remove (shaded) Guava common.io package Technical task [OAK-11473] - Remove usage of Guava ImmutableSet (again) [OAK-11585] - Add Iterators.contains replacement in IteratorUtils [OAK-11587] - Add Iterators.asEnumeration replacement in IteratorUtils [OAK-11588] - Add Iterators.toArray replacement in IteratorUtils [OAK-11590] - Remove usage of Iterators.getLast() [OAK-11591] - Remove usage of Iterators.contains() [OAK-11592] - Remove usage of Iterators.asEnumeration() [OAK-11593] - Remove usage of Iterators.toArray() [OAK-11612] - Remove usage of Sets.union [2] [OAK-11618] - Remove usage of Guava Stopwatch [OAK-11620] - Create replacement for Guava Stopwatch [OAK-11621] - Reduce usage of Guava Ticker [OAK-11640] - Remove usage of Guava ImmutableSet.Builder [OAK-11646] - Remove usage of Guava ImmutableSet.of [OAK-11652] - Remove usage of Guava Iterators.forArray [OAK-11654] - Remove usage of Guava Suppliers.ofInstance [OAK-11663] - Remove usage of Guava Iterators.filter() [OAK-11664] - Remove usage of Guava Iterators.transform() [OAK-11665] - Remove usage of Guava Iterators.singletonIterator() [OAK-11666] - Remove usage of Guava Iterators.concat() [OAK-11668] - Remove usage of Guava Iterators.mergeSorted() [OAK-11669] - Add Iterators.concat() replacement in IteratorUtils [OAK-11674] - Add Iterators.filter() replacement in IteratorUtils [OAK-11676] - Add Iterators.transform() replacement in IteratorUtils [OAK-11677] - Remove usage of Guava Iterators.elementsEqual() [OAK-11678] - Remove usage of Guava Iterators.cycle() [OAK-11680] - Add Iterators.cycle() replacement in IteratorUtils [OAK-11688] - Remove usage of Guava Iterators.getOnlyElement() [OAK-11689] - Remove usage of Guava Iterators.addAll() [OAK-11690] - Remove usage of Guava Iterators.partition() [OAK-11691] - Add Iterators.partition() replacement in IteratorUtils [OAK-11705] - Remove usage of Guava Iterators.asEnumeration() [OAK-11706] - Add Iterators.limit() replacement in IteratorUtils [OAK-11707] - Remove usage of Guava Iterators.limit() Bug [OAK-9584] - JCR methods only support qualified names but not expanded names for namespace prefix "rep:". [OAK-11452] - Expose FullGC OSGi config via metrics [OAK-11634] - Add Osgi config for FullGC generation value [OAK-11639] - oak-run-commons: IncrementalFlatFileStoreStrategy uses com.google.common classes (instead of shaded ones) [OAK-11673] - Oak-segment-azure v12 CPU increase caused by refreshLease [OAK-11685] - Reduce log level for MongoFullGcNodeBin class [OAK-11695] - Elasticsearch queries might produce inconsistent results [OAK-11704] - Update Mockito dependency to 5.17.0 [OAK-11719] - vector query should not break normal query Epic [OAK-11703] - Oak should compile & test on Java 24 Story [OAK-11671] - [full-gc] Persist the avg object size and avg size of props per document in Mongo settings New Feature [OAK-11720] - Put the usage of exclusive merge lock for large transactions behind a FeatureToggle/OSGI config Improvement [OAK-11545] - oak-search-elastic: implement bulk processor pool to optimize indexing [OAK-11607] - Node.getNodes() not lazy for orderable nodetypes [OAK-11638] - Elastic: ignore standard token filter configurations [OAK-11655] - Do not create redundant instances of ElasticBulkProcessorHandler [OAK-11658] - Indexing job: fix "jcr:uuid" issue [OAK-11687] - DataStore FileCache Memory Usage [OAK-11692] - Add inference config in oak. [OAK-11693] - Parse inference query and extract out inference config and text query [OAK-11694] - Implement inference in oak-search-elastic [OAK-11709] - Merging index definitions: merge "tags" and override "type", "async" [OAK-11721] - experimental and inferenceConfig implementation should be backward compatible [OAK-11722] - Donot read compatibility system property in VectorQuery for each query Task [OAK-11572] - Add api(s) in IteratorUtils to remove guava Iterators usage [OAK-11609] - Add Prometheus metrics export via pushgateway to RevisionsCommand (oak-run) [OAK-11622] - Clock improvements [OAK-11625] - Move o.a.j.o.plugins.bundlor.BundlingConfigInitializer to a suitable API package and export that package. [OAK-11642] - oak-segment-tar uses unmaintained concurrentlinkedhashmap-lru [OAK-11643] - Update (shaded) Guava to 33.4.7 [OAK-11650] - Fix Javadoc errors [OAK-11675] - Clean oak-segment-azure lib exporting [OAK-11681] - Clean oak-segment-azure lib exporting [OAK-11684] - Send fullGC metrics to Prometheus pushgateway on each garbage collection iteration [OAK-11698] - webapp: update Tomcat dependency to 9.0.104 [OAK-11699] - Update commons-collections4 to 4.5.0 [OAK-11700] - Update (shaded) Guava to 33.4.8 [OAK-11701] - Upgrade jackson-databind dependency to 2.17.3 [OAK-11708] - Update Easymock dependency to 5.5 [OAK-11710] - Update jacoco plugin to 0.8.13 [OAK-11714] - Add jmx to expose inferenceConfig [OAK-11716] - Capture inference service stats In addition to the above-mentioned changes, this release contains all changes up to the previous release. For more detailed information about all the changes in this and other Oak releases, please see the Oak issue tracker at https://issues.apache.org/jira/browse/OAK Release Contents ---------------- This release consists of a single source archive packaged as a zip file. The archive can be unpacked with the jar tool from your JDK installation. See the README.md file for instructions on how to build this release. The source archive is accompanied by SHA512 checksums and a PGP signature that you can use to verify the authenticity of your download. The public key used for the PGP signature can be found at https://www.apache.org/dist/jackrabbit/KEYS. About Apache Jackrabbit Oak --------------------------- 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. For more information, visit http://jackrabbit.apache.org/oak About The Apache Software Foundation ------------------------------------ Established in 1999, The Apache Software Foundation provides organizational, legal, and financial support for more than 140 freely-available, collaboratively-developed Open Source projects. The pragmatic Apache License enables individual and commercial users to easily deploy Apache software; the Foundation's intellectual property framework limits the legal exposure of its 3,800+ contributors. For more information, visit http://www.apache.org/