After 10 months of development, with 3 milestones, and 2 RC releases, we are releasing Apache Camel v4 today as LTS release. The Camel 4.0.x
is a LTS release, and we will support it for 1 year.
This blog post highlights some noteworthy new features and improvements in Camel v4.
The features are based on work since January 2023, which was the time when we switched main
branch to be Camel v4 based. Since then, we focused our effort primarily on Camel v4.
1) Major Goals
The need for Camel 4 is mainly driven by Java open source projects migrating from javax
to jakarta
APIs, and to keep up with popular runtimes such as Spring Boot and Quarkus.
- Migrate from
javax
->jakarta
(JEE 10) - Java 17 as minimum
- Spring Boot 3
- Quarkus 3
Camel 4 requires Java 17. We plan to support Java 21 on next LTS released by the end of this year.
2) Dependency updates
We have upgraded all 3rd party dependencies to their latest releases where possible.
3) Performance optimizations
We have improved the performance of the internal Camel routing engine and framework.
You can find more details in this blog post camel 4 performance improvements.
4) Camel Spring Boot
We tested Camel 4 with Spring Boot 3.1.2, the latest release available.
The camel-platform-http-starter
is now using the embedded HTTP server directly from Spring Boot, instead of using Servlet APIs as previously.
This release also comes with our first basic (and very limited) support for Spring Boot native (AOT compilation). See more in the aot-basic example.
5) Camel Quarkus
The Camel Quarkus project is working on a new release with Camel 4 support, expected later this month. Stay tuned for their release announcements.
6) Camel Main
For users who just want to run Camel as a standalone application, we have camel-main
which is constantly being improved. The core in camel-main
is reused by Camel Spring Boot, Camel Quarkus, and Camel JBang as well.
The inclusion of an embedded HTTP server is now made easy with the new camel-platform-http-main
module. See more in the camel-main example.
7) Camel JBang
We made a lot of improvements to Camel JBang. The camel
CLI can now easily run with different Camel versions, for example:
camel run foo.yaml --camel-version=3.21.0
camel run foo.yaml --camel-version=3.20.6
This is very handy when, for example, you need to trouble-shoot when something started failing. For instance, in occasions when it works on version X but not on version Y, now you can quickly try to find out which version in between that started failing.
You can also specify that camel
CLI should use a specific Camel version by default. For example, if you have a newer version of Camel JBang installed, but must develop and use an older release:
camel version set 3.20.6
We added the following new commands:
camel config
: you can use to set custom user configurationcamel log
: you can use to show logs of your running Camel integrations (can show logs for 1 or more Camel apps)camel trace
: you can use to show message tracing of your running Camel integrations (can show logs for 1 or more Camel apps)camel cmd send
: you can use to send messages to an existing running Camel integrationcamel get route-dump
: you can use to dump routes in XML or YAML format
We migrated the maven resolver that Camel JBang uses to the latest version, and Camel JBang will now report more accurately whether a dependency was downloaded or resolved from a local maven repository. The camel run
command also has a --verbose
flag to output more details in dependency resolution that can help during troubleshooting.
The camel-main
runtime now supports exporting with Kubernetes manifest and build support, to make it easier to build container images that are ready to run on Kubernetes.
We made many improvements to Camel JBang, making it a great way to experiment with Camel and a useful companion tool for traditional Camel development.
8) XML DSL with beans
We have been working on unifying the YAML, XML and Java DSL, so that they have feature parity related to configuring beans. For example, in XML DSL (camel-xml-io
) you can now declare beans and Camel routes in the same XML file with <camel>
as the root tag:
<camel>
<bean name="greeter" type="com.foo.Greeter">
<properties>
<property key="message" value="Hello World" />
</properties>
</bean>
<route id="my-route">
<from uri="direct:start"/>
<bean ref="greeter"/>
<to uri="mock:finish"/>
</route>
</camel>
Then Camel handles the dependency injection, among the <beans>
.
You can also use Spring dependency injection (which is more advanced), by inlining Spring <beans>
tag with the spring namespace. See more in the documentation for camel-xml-io-dsl
module.
There is more work to be done, and we are planning to see if we can also use this to simplify migrating from legacy OSGi Blueprint (and Spring XML files, eg <beans>
) to the modern Camel DSL.
9) New components
camel-aws2-step-functions
: Manage and invoke AWS Step functionscamel-azure-files
: Send and receive files on Azure File Storagecamel-dhis2
: Integrate with DHIS2 (health-level)camel-observation
: Observability using Micrometer Observationcamel-opensearch
: Send requests to OpenSearchcamel-parquet-avro
: Parquet Avro serialization and de-serializationcamel-platform-http-main
: Platform HTTP for Camel Main runtimecamel-yaml-io
: YAML DSL route dumpercamel-zeebe
: Integration with Camunda Zeebe
10) Miscellaneous improvements
The Camel maven plugins has been made compatible with Apache Maven 4.
Camel 4 now requires JUnit 5 for unit tests, with the test components that have -junit5 as suffix.
If you work with XML or JSON payloads, then you can log the body in pretty format with:
.log("${prettyBody}")
And in XML:
<log message="${prettyBody}"/>
And in YAML:
- log: "${prettyBody}"
We have added more _dev_console_s that provide insights into your running Camel application, which can be used together with Camel JBang and also visible in the developer web console.
Migrating to Camel 4
Camel 4 is primary supporting Spring Boot, Quarkus, and standalone Camel with camel-main
. Other runtimes are not officially supported. For users that must use Camel 4 as a framework on top of other runtimes, then you can ask for guidance and help in the Camel community.
We have, of course, cleaned up the code base. For instance, we removed all the deprecated APIs and components.
Some components that are not jakarta
API compatible has been removed, until they have new releases, that works with jakarta
APIs. The removed components are listed in the migration guide.
We have also adjusted some APIs used to configure the CamelContext
with custom settings.
In terms of backward compatibility, then Camel 4 is mostly compatible with regular Camel applications.
However, if you are using some of the more advanced features and other plugins in Camel, then migrating the code to the new version might be needed.
Additionally, custom components must be migrated and recompiled.
You can learn about all details can in the migration guide.
Good luck with your migration if you decide to continue your Camel journey. And for new users to Camel then good luck getting onboard.
Roadmap for Camel 4 for the remainder of 2023
We will continue working on Camel 4.x and do non-LTS releases, leading up to the next LTS release by end of this year.
The major goals for this year are to support Java 21, Spring Boot 3.2, and to catch up with newer Quarkus releases.
The following releases are currently scheduled (subject for change) for this year:
Release | Date | Description |
---|---|---|
4.1 | Oct | Non-LTS |
4.2 | Dec | LTS |
An ongoing effort is also to keep stabilizing our CI builds, to ensure commits do not introduce regressions. At this moment, the CI builds are occasionally have a few test errors that are related to flaky tests, that we keep fixing to ensure the CI reports are trustworthy.
Many people helped improve the Camel build and tests for high-end servers like Power and s390x during Camel 4’s development. Users and organizations building and leveraging Apache Camel on those platforms should have a smoother experience with Camel 4. This continues as an ongoing effort and we expect and even better experience for those platforms in subsequent releases.
We will continue to look for areas where we can improve the performance of Camel. At this point, we have identified that we can improve performance in the Camel type converter systems, and we plan to refactor for Camel 4.1 onwards.
And of course all the usual new features and improvements coming in from community users and contributors.
Roadmap for Camel 3 releases
Our focus has shifted to primary work on Camel 4 onwards. We will continue to fix important bugs, CVEs and whatnot for the supported LTS releases of Camel 3. The last Camel 3.x release is Camel 3.22 LTS that is planned for end of this year. This means we will only do patch releases for Camel 3.22 LTS in 2024, and by end of 2024, then all of Camel 3 is EOL.
The Camel 3.22 release will be a small release with only limited new functionality.
Users are encouraged to start new development on Camel 4.