Mirror of Apache Karaf

Clone this repo:
  1. df02ef6 Merge pull request #1885 from gnodet/maven-4-main by JB Onofré · 14 days ago main
  2. 5fe3530 Pin plugins in archetypes so that they don't use the latest 4.x ones by Guillaume Nodet · 2 weeks ago
  3. a8d9901 Merge pull request #1880 from jbonofre/KARAF-7853 by JB Onofré · 5 weeks ago
  4. 0ba29ae Cleanup commons-collections dependency by JB Onofré · 6 weeks ago
  5. 5a8d99f Merge pull request #1875 from jbonofre/KARAF-7845 by JB Onofré · 6 weeks ago

Apache Karaf

Apache Karaf is a modulith runtime, supporting several frameworks and programming model (REST/API, web, spring boot, ...). It provides turnkey features that you can directly leverage without effort, packaged as mutable or immutable application.

Overview

  • Hot deployment: Karaf supports hot deployment of applications (in the deploy directory).
  • Dynamic configuration: Karaf uses a central location (etc directory) for configuration (in different format, properties, json) and can be plug on existing configuration backend.
  • Logging System: using a centralized logging back end supported by Log4J, Karaf supports a number of different APIs (JDK 1.4, JCL, SLF4J, Avalon, Tomcat, ...)
  • Provisioning: Provisioning of libraries or applications can be done through a number of different ways, by which they will be downloaded locally, installed and started. It interacts with the resolver to automatically install the required components.
  • Extensible Shell console: Karaf features a nice text console where you can manage the services, install new applications or libraries and manage their state. This shell is easily extensible by deploying new commands dynamically along with new features or applications.
  • Remote access: use any SSH client to connect to the kernel and issue commands in the console
  • Security & ACL framework based on JAAS providing complete RBAC solution.
  • Managing instances: Karaf provides simple commands for managing instances of Karaf. You can easily create, delete, start and stop instances of Karaf through the console.
  • Enterprise features: Karaf provides a bunch of enterprise features that you can use in your applications (JDBC, JPA, JTA, JMS, ...).
  • HTTP Service: Karaf provides a full features web container, allowing you to deploy your web applications.
  • REST & Services: Karaf supports different service frameworks as Apache CXF allowing you to easily implements your services.
  • Karaf Extensions: Karaf project is a complete ecosystem. The runtime can be extended by other Karaf subprojects such as Karaf Decanter, Karaf Cellar, Karaf Cave, ...
  • Third Party Extensions: Karaf is a supported runtime for a lot of other projects as Apache Camel, and much more.

Getting Started

For an Apache Karaf source distribution, please read BUILDING.md for instructions on building Apache Karaf.

For an Apache Karaf binary distribution, please read RELEASE-NOTES.md for installation instructions and list of supported and unsupported features.

The PDF manual is the right place to find any information about Karaf.

The examples provide a bunch of turnkey minimal applications that you can deploy in Apache Karaf and extend/template as you want.

[NOTE]

Windows users should use 7zip or other unzip tool to support files longer than 255 characters.

Contact Us

To get involved in Apache Karaf:

We also have a contributor's guide.

More Information

Many thanks for using Apache Karaf.

The Apache Karaf Team