Author: buildbot
Date: Mon Sep 7 11:19:04 2015
New Revision: 964628
Log:
Production update by buildbot for camel
Modified:
websites/production/camel/content/cache/main.pageCache
websites/production/camel/content/camel-2160-release.html
Modified: websites/production/camel/content/cache/main.pageCache
==============================================================================
Binary files - no diff available.
Modified: websites/production/camel/content/camel-2160-release.html
==============================================================================
--- websites/production/camel/content/camel-2160-release.html (original)
+++ websites/production/camel/content/camel-2160-release.html Mon Sep 7
11:19:04 2015
@@ -84,7 +84,7 @@
<tbody>
<tr>
<td valign="top" width="100%">
-<div class="wiki-content maincontent"><h1
id="Camel2.16.0Release-Camel2.16.0release(currentlyinprogress)">Camel
2.16.0 release (currently in progress)</h1><div
style="padding-right:20px;float:left;margin-left:-20px;"><p><span
class="confluence-embedded-file-wrapper"><img class="confluence-embedded-image
confluence-external-resource"
src="http://camel.apache.org/download.data/camel-box-v1.0-150x200.png"
data-image-src="http://camel.apache.org/download.data/camel-box-v1.0-150x200.png"></span></p></div><div
style="min-height:200px"> </div><h2
id="Camel2.16.0Release-NewandNoteworthy">New and Noteworthy</h2><p>Welcome to
the 2.16.0 release which approx XXX issues resolved (new features, improvements
and bug fixes such as...)</p><p>Noteworthy improvements:</p><ul><li>The route
models (definition classes) preserve property placeholders, which allows round
trip editing, and also prevents showing potential sensitive
information</li><li>Added onPrepareFailure option to <a shape
="rect" href="dead-letter-channel.html">Dead Letter Channel</a> to allow a
custom processor to prepare the Exchange before sending to the dead letter
queue.</li><li><a shape="rect" href="mongodb.html">MongoDB</a> tailable
consumers now allow setting the <code>readPreference</code>
option.</li><li>Using setFaultBody / setFaultHeader behaves similar to setBody
/ setHeader to preserve existing headers/attachments by setting on existing IN
or OUT message.</li><li>Java DSL using choice with end vs endChoice now
validates you use them as intended. Any misconfiguration now throws an
exception explaining the problem.</li><li><a shape="rect"
href="pojo-producing.html">POJO Producing</a> and <a shape="rect"
href="pojo-consuming.html">POJO Consuming</a> lifecycle is now in sync with <a
shape="rect" href="camelcontext.html">CamelContext</a> which ensures it
works as similar to Camel <a shape="rect" href="routes.html">Routes</a>
does. Also the created producer/consumer is stopped
when <a shape="rect" href="camelcontext.html">CamelContext</a> is
stopping to cleanup properly.</li><li><a shape="rect"
href="jms.html">JMS</a> component now allows configuring
concurrentConsumers/maxConcurrentConsumers separately between from(jms) vs
to(jms) using request/reply over JMS</li><li><span><a shape="rect"
class="external-link"
href="https://issues.apache.org/jira/browse/CAMEL-8506">Added SEARCH</a>
operation to Elasticsearch component</span></li><li><span>The <a
shape="rect" href="properties.html">Properties</a> component (property
placeholder) now supports an encoding option to allow reading the .properties
files using a specific charset such as UTF-8. By default ISO-8859-1 is used
(latin1)</span></li><li><span>Added <code>receviveBufferSize</code> option
to the <a shape="rect" href="ftp.html">FTP</a> component to make download
faster. The size is by default 32kb buffer.</span></li><li><span>The <a
shape="rect" href="aggregator2.html">
Aggregator2</a> EIP now allows an external source using
a <code>AggregateController</code> to control the aggregator, such as for
forcing completing a group or all groups, or query runtime information from the
aggregator. A default controller is provided out of the box if none has been
configured.</span></li><li><span>The <a shape="rect"
href="aggregator2.html">Aggregator2</a> now enlists in JMX using
a <code>ManagedAggregateProcessorMBean</code> which has more information,
and also allows using the aggregate controller to control
it.</span></li><li><span>The <a shape="rect"
href="aggregator2.html">Aggregator2</a> now includes more runtime statistics
which can be accessed from Java and JMX about number of incoming and completed
exchanges, and per different completion
triggers.</span></li><li><span>The <a shape="rect"
href="aggregator2.html">Aggregator2</a> now supports pre-completion mode if the
aggregation strategy implements <code>PreCompletionAwareAg
gregationStrategy</code>. This supports the use-case where an incoming
Exchange are used to determine if the current aggregated group is completed or
not. If completed the group is emitted as-is, and the new incoming Exchange is
used to start a new group from scratch.</span></li><li><span>Added options
to <a shape="rect" href="mail.html">Mail</a> consumer so it can skip or
handle a mail message that cannot be read from the mail server in the batch;
and then move on to read the next message. This ensures the consumer can deal
with mail boxes that has problematic mails that otherwise will cause no mails
to be retrieve by the consumer in the batch.</span></li><li>The runtime route
processors and their corresponding model definition are now linked by their id
using <code>HasId</code>, so its easier to obtain the processor or model
definition from the <code>getProcessor(id)</code> and
<code>getProcessorDefintion(id)</code> api on
CamelContext.</li><li>CamelContext now also
includes a getManagedProcessor API to easily get the mbean client api for the
processor, so you can access the runtime JMX statistics from Java
code. </li><li><span><a shape="rect" href="spring-boot.html">Spring
Boot</a> applications now <a shape="rect" class="external-link"
href="https://issues.apache.org/jira/browse/CAMEL-8532">block the main thread
of the execution</a></span></li><li><span><a shape="rect"
href="spring-boot.html">Spring Boot</a> automagically <a shape="rect"
class="external-link"
href="https://issues.apache.org/jira/browse/CAMEL-8523">loads XML routes
definitions</a> from
classpath</span></li><li><span>Added <code>MainListener</code> to make it
easier for Camel Boot / Standalone Camel to implement custom logic to trigger
during the starting and stopping of the
application.</span></li><li><span><span>Camel Jackson now provides <a
shape="rect" class="external-link"
href="https://issues.apache.org/jira/browse/CAMEL-8554"><code>Map</code> to
<code>Object</c
ode> converter</a></span></span></li><li><span>Ability to refer to existing
hazelcast instance by id, using <a shape="rect"
href="hazelcast-component.html">Hazelcast Component</a></span></li><li><a
shape="rect" href="direct.html">Direct</a> and <a shape="rect"
href="direct-vm.html">Direct-VM</a> now supports
the <span>failIfNoConsumers option</span></li><li>Making it easier to add
custom <a shape="rect" href="type-converter.html">Type Converter</a> to
your Camel applications without having to use the META-INF file. In Spring or
Blueprint just add them as <bean>s. See more details at <a
shape="rect" href="type-converter.html">Type Converter</a>
documentation.</li><li>camel-cxf PAYLOAD supports stream cache out of
box.</li><li><p><code>BridgePropertyPlaceholderConfigurer</code> supports to
handle the <span><a shape="rect" href="jasypt.html">jasypt </a>encryption
inside and outside of the camelContext.</span></p></li><li><p>The camel-aws
component now sup
port Amazon DynamoDB version 2<span><br
clear="none"></span></p></li><li><p>The <a shape="rect"
href="wire-tap.html">Wire Tap</a> eip now also emits event notifications when
sending the Exchange to the wire tap destination</p></li><li><a shape="rect"
href="camel-test.html">Camel Test</a> has new option isDumpRouteStats that
dumps all route usage statistics as XML files in target/camel-route-stats
directory, which can be used to inspect "route coverage" reports.</li><li>Now
<a shape="rect" href="netty4.html">Camel Netty</a> component doesn't intercept
consumers with <code>httpMethodRestrict=OPTIONS</code></li><li><span>Now <a
shape="rect" href="netty4-http.html">Netty HTTP</a> resolves OPTIONS prefix
matches earlier</span></li><li>Using <a shape="rect"
href="load-balancer.html">Load Balancer</a> with Java DSL now builds the route
model using the specific model types, which renders a more accurate route
model</li><li>Enhanced the PredicateBuilder to support vargs and list in
the "or" builder method</li><li>Using custom <code>HttpBinding</code>
with <a shape="rect" href="http.html">HTTP</a> and <a shape="rect"
href="http4.html">HTTP4</a> is now easier as they can be instantiated using a
default no-arg constructor</li><li>Added <code>readLock=idempotent</code>
to the <a shape="rect" href="file2.html">File2</a> consumer which allows
to reuse an idempotent repository as read-lock which enables Camel to run
reliable in clustered mode, where each node competes for the same files from a
shared file system. This requires that the idempotent repository supports
clustering such as <a shape="rect"
href="hazelcast-component.html">Hazelcast Component</a> or <a shape="rect"
href="infinispan.html">Infinispan</a> - or using the JDBC for a shared database
table.</li><li><a shape="rect" href="rx.html">Camel RX</a> now ensures that
observe and subscribe are done within an unit of work to ensure on completions
is executed, such as they a
re done when you use regular Camel routes.</li><li>The <a shape="rect"
href="jms.html">JMS</a> component now includes the
underlying <code>javax.jms.Session</code> instance on the Camel message
which allows end users to easier to use client acknowledge mode, in case the
client wants to use the session to call recover or rollback.</li><li>Added
<code>completionEager</code> option to <a shape="rect"
href="idempotent-consumer.html">Idempotent Consumer</a> to whether to complete
the idempotent consumer eager or when the exchange is done.</li><li>Working
with the Camel source code in Eclipse with m2eclipse plugin improved to avoid
endless file changed detection and recompile the source.</li><li>Add
option <code>suppressExceptions</code> to <a shape="rect"
href="jsonpath.html">JSonPath</a> which allows to ignore exceptions such as
NoSuchPathException when the json payload does not contain the path defined in
the json expression.</li><li><a shape="rect" h
ref="spring-boot.html">Spring Boot</a> now creates <code>CamelContext</code>,
<code>ProducerTemplate</code> and <code>ConsumerTemplate</code> beans only if
those are not defined by the
user.  </li><li>New <code>camel-archetype-spring-boot</code> to
create a new Camel Spring Boot project using
Maven.</li><li>New <code>camel-archetype-cdi</code> to create a new
Camel CDI project using Maven.</li><li><a shape="rect"
href="ftp2.html">FTP2</a> doesn't support absolute directories in endpoint
URIs. In such cases, paths will be treated as relative and WARN message will be
printed in logs. In future versions, there'll be no such assumption and
validation exception will be thrown instead.</li><li><a shape="rect"
href="swagger.html">Swagger</a> module now supports getting api-docs from
multiple camel contexts in the JVM. The entry point at /api-docs now lists the
contexts detected, and you need to append the context id in the path, eg
/api-docs/myCamel</li><li><a shap
e="rect" href="ftp2.html">FTP2</a> supports <code>autoCreate=true</code>
for ftp consumers</li><li><a shape="rect" href="rest-dsl.html">Rest DSL</a> now
supports to define parameter using fine grained details for the <a shape="rect"
href="swagger.html">Swagger</a> api documentation. For an example see
the <code>camel-example-servlet-rest-tomcat</code> in the Apache Camel
distribution.</li><li>The <a shape="rect" href="simple.html">Simple</a>
language now has a equals ignore case operator (=~) when comparing with string
values </li><li>If using <contextScan> with Spring or Blueprint to
filter RouteBuilder classes, then Camel will now by default only look for
singleton beans. You can turn on the old behavior to include prototype scoped
with the new option <pre>includeNonSingletons</pre></li><li>The <a
shape="rect" class="external-link"
href="http://camel.apache.org/maven/current/camel-core/apidocs/org/apache/camel/spi/IdempotentRepository.html">Idem
potentRepository</a> now supports clear operation, to clear the repository,
and expose it over JMX.</li><li><a shape="rect"
href="netty4.html">Netty4</a> in clientMode will now automatic re-connect
if the connection was disconnected to the
server.</li><li>The <code>throwException</code> EIP now supports
creating a new exception instance from a simple language expressions, which
allows to make it dynamic based on information from the current
Exchange.</li><li>When using <a shape="rect"
href="expression.html">Expression</a> or <a shape="rect"
href="predicate.html">Predicate</a> in the routes, you can refer to the value
as an external resource by using <strong>resource:classpath:path</strong> or
<strong>resource:file:path</strong> - for example
<code>resource:classpath:com/foo/myscript.groovy</code>.</li><li>Added option
useMessageBodyForSql to the <a shape="rect" href="sql-component.html">SQL
Component</a> which allows to use more dynamic SQL queries inst
ead of the fixed SQL defined in the endpoint uri.</li><li>Added sticky option
to failover <a shape="rect" href="load-balancer.html">Load
Balancer</a> so the load balancer can start from the last known good
endpoint.</li><li>Added option <code>shareUnitOfWork</code> to <a
shape="rect" href="content-enricher.html">Content Enricher</a> eip</li><li><a
shape="rect" href="content-enricher.html">Content Enricher</a> with enrich and
pollEnrich now supports dynamic endpoint uris computed using an <a
shape="rect" href="expression.html">Expression</a> that allows to use values
from the current <a shape="rect" href="exchange.html">Exchange</a> so you
for example can poll a file which name is computed from data from the <a
shape="rect" href="exchange.html">Exchange</a> etc. This change breaks the XML
DSL a little bit and there is an easy migration effort. The Java DSL stays
backwards compatible.</li><li>The Camel Karaf commands about routes now no
longer requir
e the context-id as 2nd parameter that is optional - if none provided then the
command is a bulk operation for all Camel contexts.</li><li>A simpler version
of dynamic to with the new <toD> and toD in the DSL, documented at <a
shape="rect" href="message-endpoint.html">Message Endpoint</a></li><li><a
shape="rect" href="wire-tap.html">Wire Tap</a> now supports dynamic endpoint
uris, in similar way the new <toD> and toD does</li><li><a shape="rect"
href="rest-dsl.html">Rest DSL</a> now supports the new <toD> and toD in
the rest-dsl.</li><li>The <a shape="rect" href="eip.html">EIP</a>'s now
have more specialized processor mbeans in <a shape="rect"
href="camel-jmx.html">Camel JMX</a> and you can also dump the processor as xml
source to represent how it would <em>appear in xml
dsl</em> </li><li>Configuring <a shape="rect"
href="camel-jmx.html">Camel JMX</a> using JVM system properties now all take
precedence over any existing configuration (some optio
n was not doing that)</li><li>Introduced Extended JMX statistics level to
gather additional metrics during runtime.</li><li>All the <a shape="rect"
href="aws.html">Camel-AWS</a> components now support the definition (through
URI options) of Proxy Host and Proxy Port.</li><li>The HTTP based consumers no
longer include Camel headers in the responses by default (they already did this
for the producers to not include Camel headers when calling a HTTP
service).</li><li><a shape="rect" href="bindy.html">Bindy</a> now supports
having multiple pojos as models in the same java package. Instead of
configuring using package names, you configure using class names.</li><li>You
can configure on the <a shape="rect" href="type-converter.html">Type
Converter</a> registry what should happen if a duplicate type converter is
being added (override, ignore or fail) as well configure the logging
level.</li><li><a shape="rect" href="using-camelproxy.html">Using
CamelProxy</a> now binds the method para
meters to the message body/header using Camel annotations to define the
binding rules. If no annotations is defined the the parameter is assumed the
message body. You can turn this off to have the old behavior.</li><li><a
shape="rect" href="camel-jmx.html">Camel JMX</a> using custom JMX
operations/attributes with <code>@ManagedResource</code> now also includes
the default set of JMX from Camel, so you have both
worlds.</li><li>Added <code>completeAllOnStop</code> option to <a
shape="rect" href="aggregator2.html">Aggregator2</a> to allow to complete all
pending exchanges from the aggregation repository when stopping. For example
when using a memory based repository to ensure all of those exchanges are
processed when stopping.</li><li>Allow to configure the OK status code ranges
for <a shape="rect" href="http.html">HTTP</a>, <a shape="rect"
href="http4.html">HTTP4</a>, <a shape="rect" href="netty-http.html">Netty
HTTP</a>, <a shape="rect" href="netty
4-http.html">Netty4 HTTP</a>, and <a shape="rect"
href="jetty.html">Jetty</a> components for their producers. The default range
is 200-299.</li><li>Now <a shape="rect"
href="vertx.html">Vert.x</a> endpoints support <a shape="rect"
class="external-link"
href="https://issues.apache.org/jira/browse/CAMEL-8987">multiple
consumers</a>. </li><li>Support for TAR files: marshalling and
unmarshalling via a data format; splitting; aggregating. See <em>Data
Formats</em> section below.</li><li><a shape="rect" href="sjms.html">SJMS</a>
component has been aligned to bind between Camel Message and JMS Message in the
same way as <a shape="rect" href="jms.html">JMS</a> component does
that.</li></ul><p>Fixed the following issues:</p><ul><li>File language now
properly supports file extensions having double dots, such as
.tar.gz</li><li>Fixed issue with doTry not stopping routing if a fault message
was set using setFaultBody within the doTry.</li><li>Fixed <a sha
pe="rect" href="bean.html">Bean</a> language to support end parenthesis
in quoted string literals as part of method parameters, and not as end of
method signature. </li><li>Fixed <a shape="rect"
href="ftp2.html">FTP2</a> using <code>pollEnrich</code> with
disconnect=true and delete=true, would disconnect before deleting the file. Now
we disconnect last.</li><li>Various EIPs such as <a shape="rect"
href="splitter.html">Splitter</a>, <a shape="rect"
href="recipient-list.html">Recipient List</a>, <a shape="rect"
href="multicast.html">Multicast</a> no longer reuse message id in their sub
messages, but each sub message has its own unique message id (just as the
exchange has).</li><li>Fixed an issue with the circuit breaker <a
shape="rect" href="load-balancer.html">Load Balancer</a> not honoring the half
open after period after an error was detected.</li><li>Fixed <a
shape="rect" href="ftp2.html">FTP2</a> now calling disconnect if there was no
messages to poll, even when disconnect=true configured.</li><li>Fixed <a
shape="rect" href="throttler.html">Throttler</a> using method call expression
in XML DSL was not working</li><li>Fixed stopping a route may stop context
scoped OnException that would otherwise send message to an endpoint, now
been stopped and an IllegalStateException was thrown while handling the
exception.</li><li>Fixed using a <a shape="rect"
href="load-balancer.html">Load Balancer</a> from a context
scoped onException may double up its processors participating in the
balancer per route in the
context.</li><li>Fixed <code>parallelAggregate</code> on
multicast/splitter/recipient list to use a thread pool for running
concurrently. </li><li>Fixed <a shape="rect"
href="stream-caching.html">Stream caching</a> to not delete data that was
spooled to disk before both exchanges are done routing.</li><li>Fixed <a
shape="rect" href="defaulterrorhandler.html">DefaultErrorHandler</a
> to use 1 sec redelivery delay out of the box as the other error handlers
> does. </li><li>Fixed
> setting <code>logExhaustedMessageHistory=true</code> on <a
> shape="rect" href="dead-letter-channel.html">Dead Letter Channel</a> to log
> the message history. This option is by default false on DLC as it would be
> as before (not noisy).</li><li>Fixed double refresh of the parent Spring
> Boot Application Context</li><li>Fixed configuring endpoint uri's with
> primitive types when the value is looked up in the registry using #notation
> would not work.</li><li>Fixed using transacted in the Scala
> DSL</li><li>camel-swagger now filters out older Camel releases that do not
> support rest-dsl when it discovers Camel's in the JVM</li><li>Fixed <a
> shape="rect" href="mail.html">Mail</a> consumer to use the default
> value of 60 seconds as poll interval again, instead of 0.5
> sec.</li><li>Fixed <a shape="rect" href="netty.html">Netty</a>
> and <a shape="rect" href="netty4.html">Ne
tty4</a> may perform x2 redelivery when attempting to redeliver to a netty
producer endpoint</li><li>Fixed <a shape="rect"
href="recipient-list.html">Recipient List</a> would not work if using RAW()
syntax in endpoint uri</li><li>Fixed Camel Commands to not show correct route
status for suspended routes in the routes-list command.</li><li>Fixed
using <a shape="rect" href="http.html">HTTP</a>
and <code>Exchange.HTTP_QUERY</code> or
<code>Exchange.HTTP_URI</code> may double encode the value.</li><li>Fixed
starting a route from a file endpoint, and then do
a <code>pollEnrich</code> from another file endpoint, and both using the
same readLock=marker, would only delete one of the marker files when
done.</li><li><span style="line-height: 1.42857;">Fixed </span><a
shape="rect" href="jgroups.html">JGroups</a><span style="line-height:
1.42857;"> managed routes starting too early.</span></li><li><span
style="line-height: 1.42857;">Fixed <a shape="r
ect" href="http4.html">HTTP4</a>, <a shape="rect"
href="http.html">HTTP</a>, <a shape="rect" href="netty4-http.html">Netty4
HTTP</a>, <a shape="rect" href="netty-http.html">Netty HTTP</a> producers
forming URLs badly when using Exchange.HTTP_PATH and query parameters inside
the endpoint URI.</span></li><li><span style="line-height:
1.42857;">Fixed <a shape="rect" href="mqtt.html">MQTT</a> receiving
duplicates in some cases when the connection to the broker was
lost.</span></li></ul><h3 id="Camel2.16.0Release-New">New <a shape="rect"
href="enterprise-integration-patterns.html">Enterprise Integration
Patterns</a></h3><h3 id="Camel2.16.0Release-New.1">New <a shape="rect"
href="components.html">Components</a></h3><ul><li><a shape="rect"
href="paho.html">camel-paho</a> - For MQTT messaging using Eclipse Paho
client</li><li><a shape="rect" href="pdf.html">camel-pdf</a> - For creating PDF
documents</li><li><a shape="rect" href="grape.html">camel-grape</a>
- allows
you to fetch, load and manage additional jars when CamelContext is
running.</li><li><a shape="rect" href="slack.html">camel-slack</a>
- allows you to connect to an instance of Slack and delivers a
message contained in the message body via a pre established Slack incoming
webhook.</li><li><a shape="rect" href="aws-ec2.html">camel-aws-ec2</a> -
Component providing support to Amazon Web Services EC2 </li><li><a
shape="rect" href="undertow.html">camel-undertow</a> - To use <a shape="rect"
class="external-link" href="http://undertow.io/index.html"
rel="nofollow">Undertow</a> as HTTP server or client.</li><li>camel-git - A
generic Git component</li><li><a shape="rect"
href="sjms-batch.html">camel-sjms</a> - <span style="color:
rgb(0,0,0);">SJMS Batch is a specialized component for highly performant,
transactional batch consumption from a JMS queue</span></li><li><span
style="color: rgb(0,0,0);">camel-http-common - A common base component for
reuse among all the various
HTTP components we have.</span></li></ul><h3
id="Camel2.16.0Release-NewDSL">New DSL</h3><ul><li><a shape="rect"
href="script.html">Script</a> - to execute a script during routing</li><li><a
shape="rect" href="message-endpoint.html">Dynamic To </a>- to send a message to
a dynamic computed endpoint. This is a simpler version than using <a
shape="rect" href="recipient-list.html">Recipient List</a></li></ul><h3
id="Camel2.16.0Release-NewAnnotations">New Annotations</h3><h3
id="Camel2.16.0Release-NewDataFormats">New <a shape="rect"
href="data-format.html">Data Formats</a></h3><ul><li><a shape="rect"
href="boon.html">camel-boon</a> - For mapping POJO to/from
json.</li><li>camel-tarfile (pending documentation) - For compressing and
extracting TAR files; also offers a Splitter (for processing TAR entries
individually) and an Aggregation Strategy (for collecting the TAR entries into
an archive).</li></ul><h3 id="Camel2.16.0Release-New.2">New <a shape="rect"
href="languages.html">Langua
ges</a></h3><h3 id="Camel2.16.0Release-New.3">New <a shape="rect"
href="examples.html">Examples</a></h3><h3 id="Camel2.16.0Release-New.4">New <a
shape="rect" href="tutorials.html">Tutorials</a></h3><h2
id="Camel2.16.0Release-APIbreaking">API breaking</h2><ul><li><p
class="p1"> org.apache.camel.mode.LoadBalancerDefinition no longer
implements org.apache.camel.processor.loadbalancer.LoadBalancer which is
the runtime processor (this was never
intended).</p></li><li>The <code>ref</code> attribute
on <code><loadBalance></code> has been removed, as it has been
deprecated for a long time, and you should use
a <code><customLoadBalancer></code> to refer to a custom load
balancer.</li><li>The <code>copy</code> method
on <code>StreamCache</code> now takes an <code>Exchange</code> as
parameter.</li><li>Various APIs in <code>camel-jms</code> has been
adjusted to support including the JMS session parameter -
<code>javax.jms.Session</code>.
Though these API changes are mostly internal facing, and we do not expect end
users problems.</li><li>The <code>resourceUri</code>
and <code>resourceRef</code> attributes
on <code><enrich></code> and <code><pollEnrich></code>
has been removed as they now support a dynamic uris computed from an <a
shape="rect" href="expression.html">Expression</a>.</li><li>Various APIs from
camel-http in the package <code>org.apache.camel.component.http</code> has
been moved to the camel-http-common module in the
package <code>org.apache.camel.http.common</code> which mean you may need
to change the imports.</li><li>Renamed <code>All</code> enum
on <code>org.apache.camel.ManagementStatisticsLevel</code>
to <code>Default</code> </li><li>Renamed
<code>org.apache.camel.component.sjms.jms.KeyFormatStrategy</code> to <code>org.apache.camel.component.sjms.jms.JmsKeyFormatStrategy</code></li></ul><h2
id="Camel2.16.0Release-Kno
wnIssues">Known Issues</h2><h2
id="Camel2.16.0Release-Dependencyupgrades">Dependency
upgrades</h2><ul><li>Amazon Web Service Java SDK from 1.8.9.1 to
1.10.8</li><li>Apache Commons Cli from 1.2 to 1.3.1</li><li>Apache Commons
Compress from 1.5 to 1.10</li><li>Apache Commons Lang from 3.3.2 to
3.4</li><li>Apache Commons Math3 from 3.3 to 3.5</li><li>Apache Commons Pool
from 2.3 to 2.4.2</li><li>Apache Deltaspike from 1.3.0 to 1.5.0</li><li>Apache
DS from 2.0.0-M19 to 2.0.0-M20</li><li>Apache HttpComponents Core from 4.3.3 to
4.4.1</li><li>Apache HttpComponents Client from 4.3.6 to 4.4.1</li><li>Apache
JClouds from 1.8.1 to 1.9.1</li><li>Apache Olingo Odata from 2.0.0 to
2.0.4</li><li>Apns from 0.2.3 to 1.0.0.Beta6</li><li>AspectJ from 1.6.2 to
1.8.6</li><li>Async-http-client from 1.9.8 to 1.9.30</li><li>Atmosphere from
2.2.6 to 2.3.4</li><li>Cassandra from 2.1.2 to 2.1.8</li><li><p>Cassandra
Datastax Java Driver from 2.1.2 to 2.1.7.1</p></li><li>Cglib from 2.2 to
3.1</li><li>Chunk Tem
plates from 2.6.3 to 3.0.1</li><li>Classmate from 1.0.0 to 1.2.0</li><li>CMIS
0.8.0 to 0.13.0</li><li>DNSJava from 2.1.6 to 2.1.7</li><li>Docker-java from
0.10.5 to 1.3.0</li><li>Dropbox core Java SDK from 1.7.6 to
1.7.7</li><li>Dropwizard Metrics from 3.1.0 to 3.1.2</li><li>Ehcache from 2.9.1
to 2.10.0</li><li>Expression Language from 2.2.4 to 2.2.5</li><li>Facebook4j
from 1.1.12 to 2.3.0</li><li>Felix Config Admin from 1.8.0 to
1.8.6</li><li>Felix SCR annotations from 1.9.8 to 1.9.12</li><li>Freemarker
from 2.3.21 to 2.3.23</li><li>Flapdoodle Embedded MongoDB from 1.46.4 to
1.50.0</li><li>Google App Engine from 1.8.3 to 1.9.24</li><li>Gson from 3.2 to
3.2.1</li><li>Guice from 3.0 to 4.0</li><li>iCal4j from 1.5.0.2 to
1.6.0</li><li>Hazelcast from 3.4.2 to 3.5.1</li><li>Hibernate Validator from
5.0.3.Final to 5.2.1.Final</li><li>Hsqldb from 2.3.2 to
2.3.3</li><li>Infinispan from 6.0.2.Final to 7.2.4.Final</li><li><span>Jackson2
from 2.4.3 to 2.6.0</span></li><li><span>Jackrabbit fro
m 2.10.0 to 2.11.0</span></li><li>Jboss AS Maven Plugin from 7.4.Final to
7.7.Final<span><br clear="none"></span></li><li>Jboss Logging from 3.1.4.GA to
3.3.0.Final</li><li><span>Jboss Marshalling from 1.4.4.Final to
1.4.10.Final</span></li><li><span>Jboss Weld from 2.2.4.Final to
2.2.15.Final</span><span><br clear="none"></span></li><li><span>Jgroups from
3.6.1.Final to 3.6.4.Final</span></li><li><span>Jibx from 1.2.5 to
1.2.6</span></li><li><span>Joda-time from 2.5 to
2.8.1</span></li><li><span>Jruby from 1.7.18 to
1.7.21</span></li><li><span>Jsch from 0.1.51 to 0.1.53</span></li><li>Jsonpath
from 1.2.0 to 2.0.0</li><li>Jt400 from 6.7 to 8.5</li><li>Kafka from 0.8.1.1 to
0.8.2.0</li><li>LightCouch from 0.1.3 to 0.1.8</li><li>Minimal JSON from 0.9.1
to 0.9.3</li><li>MongoDB Java Driver from 2.12.4 to 3.0.3</li><li>Mvel2 from
2.2.1.Final to 2.2.6.Final</li><li>OGNL from 3.0.8 to 3.0.11</li><li>OpenEJB
from 4.6.0.2 to 4.7.2</li><li>OpenJPA from 2.3.0 to 2.4.0</li><li>Openshift
Java C
lient 2.5.0.Final to 2.7.0.Final</li><li>Pax Exam from 4.3.0 to
4.6.0</li><li>Pax Logging from 1.8.1 to 1.8.3</li><li>Pax Swissbox Tinybundles
from 1.3.1 to 1.3.2</li><li>PDFBox from 1.6.0 to 1.8.10</li><li>Rabbitmq Amqp
client from 3.3.4 to 3.5.4</li><li>Restlet from 2.2.x to 2.3.1<span><br
clear="none"></span></li><li>Scala from 2.11.5 to 2.11.7</li><li>Scala Maven
Plugin from 3.2.0 to 3.2.2</li><li>Scalatest from 2.2.0 to 2.2.5</li><li>Shade
Maven Plugin from 2.1 to 2.4</li><li>SLF4J from 1.7.10 to 1.7.12</li><li>Snappy
from <span>1.1.</span><span class="x x-first x-last">0.1 to
1.1.1.7</span></li><li>Snakeyaml from 1.14 to 1.16</li><li>Spring
upgrades</li><li>Sshd from 0.13.0 to 0.14.0</li><li>TestNG from 6.8.8 to
6.8.21</li><li>Twitter4J from 4.0.2 to 4.0.4</li><li>Univocity Parsers from
1.2.1 to 1.5.6</li><li>VertX from 2.2.5 to 3.0.0</li><li>Xmlunit from 1.5 to
1.6</li><li>XStream from 1.4.7 to 1.4.8</li><li>ZXing from 3.0.1 to
3.2.0</li></ul><h2 id="Camel2.16.0Release-I
mportantchangestoconsiderwhenupgrading">Important changes to consider when
upgrading</h2><ul><li>The dumpRoutesAsXml operation now preserve property
placeholder used in the route models. </li><li>Using setFaultBody /
setFaultHeader behaves similar to setBody / setHeader to preserve existing
headers/attachments by setting on existing IN or OUT message.</li><li>If using
concurrent consumer on <a shape="rect"
href="jms.html">JMS</a> endpoints for request/reply over JMS then you must
use the new replyToConcurrentConsumers, replyToMaxConcurrentConsumers options
to configure the values. </li><li>When the <a shape="rect"
href="aggregator2.html">Aggregator2</a> is forced completed the exchange
property <code>Exchange.AGGREGATED_COMPLETED_BY</code> value has been
changed from "forceCompletion" to "force" so its named like the other
completion triggers.</li><li>Removed unsupported modules camel-web and
camel-web-standalone.</li><li>Removed unsupported camel:dot f
unctionality from camel:run plugin.</li><li>Removed unsupported
camel-archetype-scala-component from maven archetypes.</li><li>The Maven
coordinate for linkedin and olingo2 components changed to be aligned like all
the others having groupId as just org.apache.camel.</li><li>If using MongoDB
component, the option<em> invokeGetLastError</em> doesn't exist anymore. The
option invokeGetLastError instructs the MongoDB Java driver to invoke
<em>getLastError()</em> after every call. In the 3.0.0 MongoDB driver
implementation, the <em>getLastError()</em> method in WriteResult has been
removed. So, if needed, use an acknowledged WriteConcern when executing the
write operation and then verify the correctness of the operation with the
method <em>wasAcknowledged()</em> of WriteResult.</li><li>The <a
shape="rect" href="jing.html">Jing</a> component now
uses <code>jing</code> as schema name in uris, instead
of <code>rng</code> or <code>rnc</code>. Those names has been removed.
</li><li><a shape="rect" href="swagger.html">Swagger</a> module now supports
getting api-docs from multiple camel contexts in the JVM. The entry point at
/api-docs now lists the contexts detected, and you need to append the context
id in the path, eg /api-docs/myCamel</li><li>If using <contextScan> with
Spring or Blueprint to filter RouteBuilder classes, then Camel will now by
default only look for singleton beans. You can turn on the old behavior to
include prototype scoped with the new
option <pre>includeNonSingletons</pre></li><li>camel-vertx has been
upgraded to vertx 3.0 which requires Java 8 at
runtime.</li><li><code>camel-cdi</code> is now using CDI 1.1 api - support for
1.0 has been dropped.</li><li><a shape="rect"
href="content-enricher.html">Content Enricher</a> with enrich and pollEnrich
now supports dynamic endpoint uris computed using an <a shape="rect"
href="expression.html">Expression</a> that allows to use values from the
current <a shape="r
ect" href="exchange.html">Exchange</a> so you for example can poll a file
which name is computed from data from the <a shape="rect"
href="exchange.html">Exchange</a> etc. This change breaks the XML DSL a little
bit and there is an easy migration effort. The Java DSL stays backwards
compatible.</li><li>Support for CXF 2.7 is dropped.</li><li>camel-jetty8 is
being considered deprecated and we would like to drop this in a nearby future
release as Jetty 8.x is EOL. </li><li>If you have explicit configured the
JMX statistics level to All then that option is now called
Default. </li><li>The HTTP based consumers no longer include Camel headers
in the responses by default (they already did this for the producers to not
include Camel headers when calling a HTTP service).</li><li><a shape="rect"
href="bindy.html">Bindy</a> requires to be configured using class names instead
of package names, as it now supports having multiple model classes in the same
java packages now.</li><li
><a shape="rect" href="using-camelproxy.html">Using CamelProxy</a> now binds
>the method parameters to the message body/header using Camel annotations to
>define the binding rules. If no annotations is defined the the parameter is
>assumed the message body. You can turn this off to have the old
>behavior.</li><li><a shape="rect" href="sjms.html">SJMS</a> component has
>been aligned to bind between Camel Message and JMS Message in the same way
>as <a shape="rect" href="jms.html">JMS</a> component does that, in the
>process a few APIs and behavior has been changed.</li></ul><h2
>id="Camel2.16.0Release-GettingtheDistributions">Getting the
>Distributions</h2><h3 id="Camel2.16.0Release-BinaryDistributions">Binary
>Distributions</h3><div class="table-wrap"><table
>class="confluenceTable"><tbody><tr><th colspan="1" rowspan="1"
>class="confluenceTh"><p>Description</p></th><th colspan="1" rowspan="1"
>class="confluenceTh"><p>Download Link</p></th><th colspan="1" rowspan="1"
>class="confluenceTh"><p>P
GP Signature file of download</p></th></tr><tr><td colspan="1" rowspan="1"
class="confluenceTd"><p>Windows Distribution</p></td><td colspan="1"
rowspan="1" class="confluenceTd"><p><a shape="rect" class="external-link"
href="http://www.apache.org/dyn/closer.cgi/camel/apache-camel/2.16.0/apache-camel-2.16.0.zip">apache-camel-2.16.0.zip</a></p></td><td
colspan="1" rowspan="1" class="confluenceTd"><p><a shape="rect"
class="external-link"
href="http://www.apache.org/dist/camel/apache-camel/2.16.0/apache-camel-2.16.0.zip.asc">apache-camel-2.16.0.zip.asc</a></p></td></tr><tr><td
colspan="1" rowspan="1" class="confluenceTd"><p>Unix/Linux/Cygwin
Distribution</p></td><td colspan="1" rowspan="1" class="confluenceTd"><p><a
shape="rect" class="external-link"
href="http://www.apache.org/dyn/closer.cgi/camel/apache-camel/2.16.0/apache-camel-2.16.0.tar.gz">apache-camel-2.16.0.tar.gz</a></p></td><td
colspan="1" rowspan="1" class="confluenceTd"><p><a shape="rect"
class="external-link" href="http://ww
w.apache.org/dist/camel/apache-camel/2.16.0/apache-camel-2.16.0.tar.gz.asc">apache-camel-2.16.0.tar.gz.asc</a></p></td></tr></tbody></table></div><div
class="confluence-information-macro
confluence-information-macro-information"><p class="title">The above URLs use
redirection</p><span class="aui-icon aui-icon-small aui-iconfont-info
confluence-information-macro-icon"></span><div
class="confluence-information-macro-body"><p>The above URLs use the Apache
Mirror system to redirect you to a suitable mirror for your download. Some
users have experienced issues with some versions of browsers (e.g. some Safari
browsers). If the download doesn't seem to work for you from the above URL then
try using <a shape="rect" class="external-link"
href="http://www.mozilla.com/en-US/firefox/"
rel="nofollow">FireFox</a></p></div></div><h3
id="Camel2.16.0Release-SourceDistributions">Source Distributions</h3><div
class="table-wrap"><table class="confluenceTable"><tbody><tr><th colspan="1"
rowspan="1" clas
s="confluenceTh"><p>Description</p></th><th colspan="1" rowspan="1"
class="confluenceTh"><p>Download Link</p></th><th colspan="1" rowspan="1"
class="confluenceTh"><p>PGP Signature file of download</p></th></tr><tr><td
colspan="1" rowspan="1" class="confluenceTd"><p>Source for Windows</p></td><td
colspan="1" rowspan="1" class="confluenceTd"><p><a shape="rect"
class="external-link"
href="http://www.apache.org/dyn/closer.cgi/camel/apache-camel/x.y.x/apache-camel-x.y.x-src.zip">apache-camel-x.y.x-src.zip</a></p></td><td
colspan="1" rowspan="1" class="confluenceTd"><p><a shape="rect"
class="external-link"
href="http://www.apache.org/dist/camel/apache-camel/x.y.x/apache-camel-x.y.x-src.zip.asc">apache-camel-x.y.x-src.zip.asc</a></p></td></tr></tbody></table></div><div
class="table-wrap"><table class="confluenceTable"><tbody><tr><td colspan="1"
rowspan="1" class="confluenceTd"><p>Source for Unix/Linux/Cygwin</p></td><td
colspan="1" rowspan="1" class="confluenceTd"><p><a shape="rect" class=
"external-link"
href="http://www.apache.org/dyn/closer.cgi/camel/apache-camel/x.y.x/apache-camel-x.y.x-src.tar.gz">apache-camel-x.y.x-src.tar.gz</a></p></td><td
colspan="1" rowspan="1" class="confluenceTd"><p><a shape="rect"
class="external-link"
href="http://www.apache.org/dist/camel/apache-camel/x.y.x/apache-camel-x.y.x-src.tar.gz.asc">apache-camel-x.y.x-src.tar.gz.asc</a></p></td></tr></tbody></table></div><h3
id="Camel2.16.0Release-GettingtheBinariesusingMaven2">Getting the Binaries
using Maven 2</h3><p>To use this release in your maven project, the proper
dependency configuration that you should use in your <a shape="rect"
class="external-link"
href="http://maven.apache.org/guides/introduction/introduction-to-the-pom.html">Maven
POM</a> is:</p><div class="code panel pdl" style="border-width: 1px;"><div
class="codeContent panelContent pdl">
+<div class="wiki-content maincontent"><h1
id="Camel2.16.0Release-Camel2.16.0release(currentlyinprogress)">Camel
2.16.0 release (currently in progress)</h1><div
style="padding-right:20px;float:left;margin-left:-20px;"><p><span
class="confluence-embedded-file-wrapper"><img class="confluence-embedded-image
confluence-external-resource"
src="http://camel.apache.org/download.data/camel-box-v1.0-150x200.png"
data-image-src="http://camel.apache.org/download.data/camel-box-v1.0-150x200.png"></span></p></div><div
style="min-height:200px"> </div><h2
id="Camel2.16.0Release-NewandNoteworthy">New and Noteworthy</h2><p>Welcome to
the 2.16.0 release which approx XXX issues resolved (new features, improvements
and bug fixes such as...)</p><p>Noteworthy improvements:</p><ul><li>The route
models (definition classes) preserve property placeholders, which allows round
trip editing, and also prevents showing potential sensitive
information</li><li>Added onPrepareFailure option to <a shape
="rect" href="dead-letter-channel.html">Dead Letter Channel</a> to allow a
custom processor to prepare the Exchange before sending to the dead letter
queue.</li><li><a shape="rect" href="mongodb.html">MongoDB</a> tailable
consumers now allow setting the <code>readPreference</code>
option.</li><li>Using setFaultBody / setFaultHeader behaves similar to setBody
/ setHeader to preserve existing headers/attachments by setting on existing IN
or OUT message.</li><li>Java DSL using choice with end vs endChoice now
validates you use them as intended. Any misconfiguration now throws an
exception explaining the problem.</li><li><a shape="rect"
href="pojo-producing.html">POJO Producing</a> and <a shape="rect"
href="pojo-consuming.html">POJO Consuming</a> lifecycle is now in sync with <a
shape="rect" href="camelcontext.html">CamelContext</a> which ensures it
works as similar to Camel <a shape="rect" href="routes.html">Routes</a>
does. Also the created producer/consumer is stopped
when <a shape="rect" href="camelcontext.html">CamelContext</a> is
stopping to cleanup properly.</li><li><a shape="rect"
href="jms.html">JMS</a> component now allows configuring
concurrentConsumers/maxConcurrentConsumers separately between from(jms) vs
to(jms) using request/reply over JMS</li><li><span><a shape="rect"
class="external-link"
href="https://issues.apache.org/jira/browse/CAMEL-8506">Added SEARCH</a>
operation to Elasticsearch component</span></li><li><span>The <a
shape="rect" href="properties.html">Properties</a> component (property
placeholder) now supports an encoding option to allow reading the .properties
files using a specific charset such as UTF-8. By default ISO-8859-1 is used
(latin1)</span></li><li><span>Added <code>receviveBufferSize</code> option
to the <a shape="rect" href="ftp.html">FTP</a> component to make download
faster. The size is by default 32kb buffer.</span></li><li><span>The <a
shape="rect" href="aggregator2.html">
Aggregator2</a> EIP now allows an external source using
a <code>AggregateController</code> to control the aggregator, such as for
forcing completing a group or all groups, or query runtime information from the
aggregator. A default controller is provided out of the box if none has been
configured.</span></li><li><span>The <a shape="rect"
href="aggregator2.html">Aggregator2</a> now enlists in JMX using
a <code>ManagedAggregateProcessorMBean</code> which has more information,
and also allows using the aggregate controller to control
it.</span></li><li><span>The <a shape="rect"
href="aggregator2.html">Aggregator2</a> now includes more runtime statistics
which can be accessed from Java and JMX about number of incoming and completed
exchanges, and per different completion
triggers.</span></li><li><span>The <a shape="rect"
href="aggregator2.html">Aggregator2</a> now supports pre-completion mode if the
aggregation strategy implements <code>PreCompletionAwareAg
gregationStrategy</code>. This supports the use-case where an incoming
Exchange are used to determine if the current aggregated group is completed or
not. If completed the group is emitted as-is, and the new incoming Exchange is
used to start a new group from scratch.</span></li><li><span>Added options
to <a shape="rect" href="mail.html">Mail</a> consumer so it can skip or
handle a mail message that cannot be read from the mail server in the batch;
and then move on to read the next message. This ensures the consumer can deal
with mail boxes that has problematic mails that otherwise will cause no mails
to be retrieve by the consumer in the batch.</span></li><li>The runtime route
processors and their corresponding model definition are now linked by their id
using <code>HasId</code>, so its easier to obtain the processor or model
definition from the <code>getProcessor(id)</code> and
<code>getProcessorDefintion(id)</code> api on
CamelContext.</li><li>CamelContext now also
includes a getManagedProcessor API to easily get the mbean client api for the
processor, so you can access the runtime JMX statistics from Java
code. </li><li><span><a shape="rect" href="spring-boot.html">Spring
Boot</a> applications now <a shape="rect" class="external-link"
href="https://issues.apache.org/jira/browse/CAMEL-8532">block the main thread
of the execution</a></span></li><li><span><a shape="rect"
href="spring-boot.html">Spring Boot</a> automagically <a shape="rect"
class="external-link"
href="https://issues.apache.org/jira/browse/CAMEL-8523">loads XML routes
definitions</a> from
classpath</span></li><li><span>Added <code>MainListener</code> to make it
easier for Camel Boot / Standalone Camel to implement custom logic to trigger
during the starting and stopping of the
application.</span></li><li><span><span>Camel Jackson now provides <a
shape="rect" class="external-link"
href="https://issues.apache.org/jira/browse/CAMEL-8554"><code>Map</code> to
<code>Object</c
ode> converter</a></span></span></li><li><span>Ability to refer to existing
hazelcast instance by id, using <a shape="rect"
href="hazelcast-component.html">Hazelcast Component</a></span></li><li><a
shape="rect" href="direct.html">Direct</a> and <a shape="rect"
href="direct-vm.html">Direct-VM</a> now supports
the <span>failIfNoConsumers option</span></li><li>Making it easier to add
custom <a shape="rect" href="type-converter.html">Type Converter</a> to
your Camel applications without having to use the META-INF file. In Spring or
Blueprint just add them as <bean>s. See more details at <a
shape="rect" href="type-converter.html">Type Converter</a>
documentation.</li><li>camel-cxf PAYLOAD supports stream cache out of
box.</li><li><p><code>BridgePropertyPlaceholderConfigurer</code> supports to
handle the <span><a shape="rect" href="jasypt.html">jasypt </a>encryption
inside and outside of the camelContext.</span></p></li><li><p>The camel-aws
component now sup
port Amazon DynamoDB version 2<span><br
clear="none"></span></p></li><li><p>The <a shape="rect"
href="wire-tap.html">Wire Tap</a> eip now also emits event notifications when
sending the Exchange to the wire tap destination</p></li><li><a shape="rect"
href="camel-test.html">Camel Test</a> has new option isDumpRouteStats that
dumps all route usage statistics as XML files in target/camel-route-stats
directory, which can be used to inspect "route coverage" reports.</li><li>Now
<a shape="rect" href="netty4.html">Camel Netty</a> component doesn't intercept
consumers with <code>httpMethodRestrict=OPTIONS</code></li><li><span>Now <a
shape="rect" href="netty4-http.html">Netty HTTP</a> resolves OPTIONS prefix
matches earlier</span></li><li>Using <a shape="rect"
href="load-balancer.html">Load Balancer</a> with Java DSL now builds the route
model using the specific model types, which renders a more accurate route
model</li><li>Enhanced the PredicateBuilder to support vargs and list in
the "or" builder method</li><li>Using custom <code>HttpBinding</code>
with <a shape="rect" href="http.html">HTTP</a> and <a shape="rect"
href="http4.html">HTTP4</a> is now easier as they can be instantiated using a
default no-arg constructor</li><li>Added <code>readLock=idempotent</code>
to the <a shape="rect" href="file2.html">File2</a> consumer which allows
to reuse an idempotent repository as read-lock which enables Camel to run
reliable in clustered mode, where each node competes for the same files from a
shared file system. This requires that the idempotent repository supports
clustering such as <a shape="rect"
href="hazelcast-component.html">Hazelcast Component</a> or <a shape="rect"
href="infinispan.html">Infinispan</a> - or using the JDBC for a shared database
table.</li><li><a shape="rect" href="rx.html">Camel RX</a> now ensures that
observe and subscribe are done within an unit of work to ensure on completions
is executed, such as they a
re done when you use regular Camel routes.</li><li>The <a shape="rect"
href="jms.html">JMS</a> component now includes the
underlying <code>javax.jms.Session</code> instance on the Camel message
which allows end users to easier to use client acknowledge mode, in case the
client wants to use the session to call recover or rollback.</li><li>Added
<code>completionEager</code> option to <a shape="rect"
href="idempotent-consumer.html">Idempotent Consumer</a> to whether to complete
the idempotent consumer eager or when the exchange is done.</li><li>Working
with the Camel source code in Eclipse with m2eclipse plugin improved to avoid
endless file changed detection and recompile the source.</li><li>Add
option <code>suppressExceptions</code> to <a shape="rect"
href="jsonpath.html">JSonPath</a> which allows to ignore exceptions such as
NoSuchPathException when the json payload does not contain the path defined in
the json expression.</li><li><a shape="rect" h
ref="spring-boot.html">Spring Boot</a> now creates <code>CamelContext</code>,
<code>ProducerTemplate</code> and <code>ConsumerTemplate</code> beans only if
those are not defined by the
user.  </li><li>New <code>camel-archetype-spring-boot</code> to
create a new Camel Spring Boot project using
Maven.</li><li>New <code>camel-archetype-cdi</code> to create a new
Camel CDI project using Maven.</li><li><a shape="rect"
href="ftp2.html">FTP2</a> doesn't support absolute directories in endpoint
URIs. In such cases, paths will be treated as relative and WARN message will be
printed in logs. In future versions, there'll be no such assumption and
validation exception will be thrown instead.</li><li><a shape="rect"
href="swagger.html">Swagger</a> module now supports getting api-docs from
multiple camel contexts in the JVM. The entry point at /api-docs now lists the
contexts detected, and you need to append the context id in the path, eg
/api-docs/myCamel</li><li><a shap
e="rect" href="ftp2.html">FTP2</a> supports <code>autoCreate=true</code>
for ftp consumers</li><li><a shape="rect" href="rest-dsl.html">Rest DSL</a> now
supports to define parameter using fine grained details for the <a shape="rect"
href="swagger.html">Swagger</a> api documentation. For an example see
the <code>camel-example-servlet-rest-tomcat</code> in the Apache Camel
distribution.</li><li>The <a shape="rect" href="simple.html">Simple</a>
language now has a equals ignore case operator (=~) when comparing with string
values </li><li>If using <contextScan> with Spring or Blueprint to
filter RouteBuilder classes, then Camel will now by default only look for
singleton beans. You can turn on the old behavior to include prototype scoped
with the new option <pre>includeNonSingletons</pre></li><li>The <a
shape="rect" class="external-link"
href="http://camel.apache.org/maven/current/camel-core/apidocs/org/apache/camel/spi/IdempotentRepository.html">Idem
potentRepository</a> now supports clear operation, to clear the repository,
and expose it over JMX.</li><li><a shape="rect"
href="netty4.html">Netty4</a> in clientMode will now automatic re-connect
if the connection was disconnected to the
server.</li><li>The <code>throwException</code> EIP now supports
creating a new exception instance from a simple language expressions, which
allows to make it dynamic based on information from the current
Exchange.</li><li>When using <a shape="rect"
href="expression.html">Expression</a> or <a shape="rect"
href="predicate.html">Predicate</a> in the routes, you can refer to the value
as an external resource by using <strong>resource:classpath:path</strong> or
<strong>resource:file:path</strong> - for example
<code>resource:classpath:com/foo/myscript.groovy</code>.</li><li>Added option
useMessageBodyForSql to the <a shape="rect" href="sql-component.html">SQL
Component</a> which allows to use more dynamic SQL queries inst
ead of the fixed SQL defined in the endpoint uri.</li><li>Added sticky option
to failover <a shape="rect" href="load-balancer.html">Load
Balancer</a> so the load balancer can start from the last known good
endpoint.</li><li>Added option <code>shareUnitOfWork</code> to <a
shape="rect" href="content-enricher.html">Content Enricher</a> eip</li><li><a
shape="rect" href="content-enricher.html">Content Enricher</a> with enrich and
pollEnrich now supports dynamic endpoint uris computed using an <a
shape="rect" href="expression.html">Expression</a> that allows to use values
from the current <a shape="rect" href="exchange.html">Exchange</a> so you
for example can poll a file which name is computed from data from the <a
shape="rect" href="exchange.html">Exchange</a> etc. This change breaks the XML
DSL a little bit and there is an easy migration effort. The Java DSL stays
backwards compatible.</li><li>The Camel Karaf commands about routes now no
longer requir
e the context-id as 2nd parameter that is optional - if none provided then the
command is a bulk operation for all Camel contexts.</li><li>A simpler version
of dynamic to with the new <toD> and toD in the DSL, documented at <a
shape="rect" href="message-endpoint.html">Message Endpoint</a></li><li><a
shape="rect" href="wire-tap.html">Wire Tap</a> now supports dynamic endpoint
uris, in similar way the new <toD> and toD does</li><li><a shape="rect"
href="rest-dsl.html">Rest DSL</a> now supports the new <toD> and toD in
the rest-dsl.</li><li>The <a shape="rect" href="eip.html">EIP</a>'s now
have more specialized processor mbeans in <a shape="rect"
href="camel-jmx.html">Camel JMX</a> and you can also dump the processor as xml
source to represent how it would <em>appear in xml
dsl</em> </li><li>Configuring <a shape="rect"
href="camel-jmx.html">Camel JMX</a> using JVM system properties now all take
precedence over any existing configuration (some optio
n was not doing that)</li><li>Introduced Extended JMX statistics level to
gather additional metrics during runtime.</li><li>All the <a shape="rect"
href="aws.html">Camel-AWS</a> components now support the definition (through
URI options) of Proxy Host and Proxy Port.</li><li>The HTTP based consumers no
longer include Camel headers in the responses by default (they already did this
for the producers to not include Camel headers when calling a HTTP
service).</li><li><a shape="rect" href="bindy.html">Bindy</a> now supports
having multiple pojos as models in the same java package. Instead of
configuring using package names, you configure using class names.</li><li>You
can configure on the <a shape="rect" href="type-converter.html">Type
Converter</a> registry what should happen if a duplicate type converter is
being added (override, ignore or fail) as well configure the logging
level.</li><li><a shape="rect" href="using-camelproxy.html">Using
CamelProxy</a> now binds the method para
meters to the message body/header using Camel annotations to define the
binding rules. If no annotations is defined the the parameter is assumed the
message body. You can turn this off to have the old behavior.</li><li><a
shape="rect" href="camel-jmx.html">Camel JMX</a> using custom JMX
operations/attributes with <code>@ManagedResource</code> now also includes
the default set of JMX from Camel, so you have both
worlds.</li><li>Added <code>completeAllOnStop</code> option to <a
shape="rect" href="aggregator2.html">Aggregator2</a> to allow to complete all
pending exchanges from the aggregation repository when stopping. For example
when using a memory based repository to ensure all of those exchanges are
processed when stopping.</li><li>Allow to configure the OK status code ranges
for <a shape="rect" href="http.html">HTTP</a>, <a shape="rect"
href="http4.html">HTTP4</a>, <a shape="rect" href="netty-http.html">Netty
HTTP</a>, <a shape="rect" href="netty
4-http.html">Netty4 HTTP</a>, and <a shape="rect"
href="jetty.html">Jetty</a> components for their producers. The default range
is 200-299.</li><li>Now <a shape="rect"
href="vertx.html">Vert.x</a> endpoints support <a shape="rect"
class="external-link"
href="https://issues.apache.org/jira/browse/CAMEL-8987">multiple
consumers</a>. </li><li>Support for TAR files: marshalling and
unmarshalling via a data format; splitting; aggregating. See <em>Data
Formats</em> section below.</li><li><a shape="rect" href="sjms.html">SJMS</a>
component has been aligned to bind between Camel Message and JMS Message in the
same way as <a shape="rect" href="jms.html">JMS</a> component does
that.</li></ul><p>Fixed the following issues:</p><ul><li>File language now
properly supports file extensions having double dots, such as
.tar.gz</li><li>Fixed issue with doTry not stopping routing if a fault message
was set using setFaultBody within the doTry.</li><li>Fixed <a sha
pe="rect" href="bean.html">Bean</a> language to support end parenthesis
in quoted string literals as part of method parameters, and not as end of
method signature. </li><li>Fixed <a shape="rect"
href="ftp2.html">FTP2</a> using <code>pollEnrich</code> with
disconnect=true and delete=true, would disconnect before deleting the file. Now
we disconnect last.</li><li>Various EIPs such as <a shape="rect"
href="splitter.html">Splitter</a>, <a shape="rect"
href="recipient-list.html">Recipient List</a>, <a shape="rect"
href="multicast.html">Multicast</a> no longer reuse message id in their sub
messages, but each sub message has its own unique message id (just as the
exchange has).</li><li>Fixed an issue with the circuit breaker <a
shape="rect" href="load-balancer.html">Load Balancer</a> not honoring the half
open after period after an error was detected.</li><li>Fixed <a
shape="rect" href="ftp2.html">FTP2</a> now calling disconnect if there was no
messages to poll, even when disconnect=true configured.</li><li>Fixed <a
shape="rect" href="throttler.html">Throttler</a> using method call expression
in XML DSL was not working</li><li>Fixed stopping a route may stop context
scoped OnException that would otherwise send message to an endpoint, now
been stopped and an IllegalStateException was thrown while handling the
exception.</li><li>Fixed using a <a shape="rect"
href="load-balancer.html">Load Balancer</a> from a context
scoped onException may double up its processors participating in the
balancer per route in the
context.</li><li>Fixed <code>parallelAggregate</code> on
multicast/splitter/recipient list to use a thread pool for running
concurrently. </li><li>Fixed <a shape="rect"
href="stream-caching.html">Stream caching</a> to not delete data that was
spooled to disk before both exchanges are done routing.</li><li>Fixed <a
shape="rect" href="defaulterrorhandler.html">DefaultErrorHandler</a
> to use 1 sec redelivery delay out of the box as the other error handlers
> does. </li><li>Fixed
> setting <code>logExhaustedMessageHistory=true</code> on <a
> shape="rect" href="dead-letter-channel.html">Dead Letter Channel</a> to log
> the message history. This option is by default false on DLC as it would be
> as before (not noisy).</li><li>Fixed double refresh of the parent Spring
> Boot Application Context</li><li>Fixed configuring endpoint uri's with
> primitive types when the value is looked up in the registry using #notation
> would not work.</li><li>Fixed using transacted in the Scala
> DSL</li><li>camel-swagger now filters out older Camel releases that do not
> support rest-dsl when it discovers Camel's in the JVM</li><li>Fixed <a
> shape="rect" href="mail.html">Mail</a> consumer to use the default
> value of 60 seconds as poll interval again, instead of 0.5
> sec.</li><li>Fixed <a shape="rect" href="netty.html">Netty</a>
> and <a shape="rect" href="netty4.html">Ne
tty4</a> may perform x2 redelivery when attempting to redeliver to a netty
producer endpoint</li><li>Fixed <a shape="rect"
href="recipient-list.html">Recipient List</a> would not work if using RAW()
syntax in endpoint uri</li><li>Fixed Camel Commands to not show correct route
status for suspended routes in the routes-list command.</li><li>Fixed
using <a shape="rect" href="http.html">HTTP</a>
and <code>Exchange.HTTP_QUERY</code> or
<code>Exchange.HTTP_URI</code> may double encode the value.</li><li>Fixed
starting a route from a file endpoint, and then do
a <code>pollEnrich</code> from another file endpoint, and both using the
same readLock=marker, would only delete one of the marker files when
done.</li><li><span style="line-height: 1.42857;">Fixed </span><a
shape="rect" href="jgroups.html">JGroups</a><span style="line-height:
1.42857;"> managed routes starting too early.</span></li><li><span
style="line-height: 1.42857;">Fixed <a shape="r
ect" href="http4.html">HTTP4</a>, <a shape="rect"
href="http.html">HTTP</a>, <a shape="rect" href="netty4-http.html">Netty4
HTTP</a>, <a shape="rect" href="netty-http.html">Netty HTTP</a> producers
forming URLs badly when using Exchange.HTTP_PATH and query parameters inside
the endpoint URI.</span></li><li><span style="line-height:
1.42857;">Fixed <a shape="rect" href="mqtt.html">MQTT</a> receiving
duplicates in some cases when the connection to the broker was
lost.</span></li></ul><h3 id="Camel2.16.0Release-New">New <a shape="rect"
href="enterprise-integration-patterns.html">Enterprise Integration
Patterns</a></h3><h3 id="Camel2.16.0Release-New.1">New <a shape="rect"
href="components.html">Components</a></h3><ul><li><a shape="rect"
href="paho.html">camel-paho</a> - For MQTT messaging using Eclipse Paho
client</li><li><a shape="rect" href="pdf.html">camel-pdf</a> - For creating PDF
documents</li><li><a shape="rect" href="grape.html">camel-grape</a>
- allows
you to fetch, load and manage additional jars when CamelContext is
running.</li><li><a shape="rect" href="slack.html">camel-slack</a>
- allows you to connect to an instance of Slack and delivers a
message contained in the message body via a pre established Slack incoming
webhook.</li><li><a shape="rect" href="aws-ec2.html">camel-aws-ec2</a> -
Component providing support to Amazon Web Services EC2 </li><li><a
shape="rect" href="undertow.html">camel-undertow</a> - To use <a shape="rect"
class="external-link" href="http://undertow.io/index.html"
rel="nofollow">Undertow</a> as HTTP server or client.</li><li>camel-git - A
generic Git component</li><li><a shape="rect"
href="sjms-batch.html">camel-sjms</a> - <span style="color:
rgb(0,0,0);">SJMS Batch is a specialized component for highly performant,
transactional batch consumption from a JMS queue</span></li><li><span
style="color: rgb(0,0,0);">camel-http-common - A common base component for
reuse among all the various
HTTP components we have.</span></li></ul><h3
id="Camel2.16.0Release-NewDSL">New DSL</h3><ul><li><a shape="rect"
href="script.html">Script</a> - to execute a script during routing</li><li><a
shape="rect" href="message-endpoint.html">Dynamic To </a>- to send a message to
a dynamic computed endpoint. This is a simpler version than using <a
shape="rect" href="recipient-list.html">Recipient List</a></li></ul><h3
id="Camel2.16.0Release-NewAnnotations">New Annotations</h3><h3
id="Camel2.16.0Release-NewDataFormats">New <a shape="rect"
href="data-format.html">Data Formats</a></h3><ul><li><a shape="rect"
href="boon.html">camel-boon</a> - For mapping POJO to/from
json.</li><li>camel-tarfile (pending documentation) - For compressing and
extracting TAR files; also offers a Splitter (for processing TAR entries
individually) and an Aggregation Strategy (for collecting the TAR entries into
an archive).</li></ul><h3 id="Camel2.16.0Release-New.2">New <a shape="rect"
href="languages.html">Langua
ges</a></h3><h3 id="Camel2.16.0Release-New.3">New <a shape="rect"
href="examples.html">Examples</a></h3><h3 id="Camel2.16.0Release-New.4">New <a
shape="rect" href="tutorials.html">Tutorials</a></h3><h2
id="Camel2.16.0Release-APIbreaking">API breaking</h2><ul><li><p
class="p1"> org.apache.camel.mode.LoadBalancerDefinition no longer
implements org.apache.camel.processor.loadbalancer.LoadBalancer which is
the runtime processor (this was never
intended).</p></li><li>The <code>ref</code> attribute
on <code><loadBalance></code> has been removed, as it has been
deprecated for a long time, and you should use
a <code><customLoadBalancer></code> to refer to a custom load
balancer.</li><li>The <code>copy</code> method
on <code>StreamCache</code> now takes an <code>Exchange</code> as
parameter.</li><li>Various APIs in <code>camel-jms</code> has been
adjusted to support including the JMS session parameter -
<code>javax.jms.Session</code>.
Though these API changes are mostly internal facing, and we do not expect end
users problems.</li><li>The <code>resourceUri</code>
and <code>resourceRef</code> attributes
on <code><enrich></code> and <code><pollEnrich></code>
has been removed as they now support a dynamic uris computed from an <a
shape="rect" href="expression.html">Expression</a>.</li><li>Various APIs from
camel-http in the package <code>org.apache.camel.component.http</code> has
been moved to the camel-http-common module in the
package <code>org.apache.camel.http.common</code> which mean you may need
to change the imports.</li><li>Renamed <code>All</code> enum
on <code>org.apache.camel.ManagementStatisticsLevel</code>
to <code>Default</code> </li><li>Renamed
<code>org.apache.camel.component.sjms.jms.KeyFormatStrategy</code> to <code>org.apache.camel.component.sjms.jms.JmsKeyFormatStrategy</code></li></ul><h2
id="Camel2.16.0Release-Kno
wnIssues">Known Issues</h2><h2
id="Camel2.16.0Release-Dependencyupgrades">Dependency
upgrades</h2><ul><li>Amazon Web Service Java SDK from 1.8.9.1 to
1.10.8</li><li>Apache Commons Cli from 1.2 to 1.3.1</li><li>Apache Commons
Compress from 1.5 to 1.10</li><li>Apache Commons Lang from 3.3.2 to
3.4</li><li>Apache Commons Math3 from 3.3 to 3.5</li><li>Apache Commons Pool
from 2.3 to 2.4.2</li><li>Apache Deltaspike from 1.3.0 to 1.5.0</li><li>Apache
DS from 2.0.0-M19 to 2.0.0-M20</li><li>Apache HttpComponents Core from 4.3.3 to
4.4.1</li><li>Apache HttpComponents Client from 4.3.6 to 4.4.1</li><li>Apache
JClouds from 1.8.1 to 1.9.1</li><li>Apache Olingo Odata from 2.0.0 to
2.0.4</li><li>Apns from 0.2.3 to 1.0.0.Beta6</li><li>AspectJ from 1.6.2 to
1.8.6</li><li>Async-http-client from 1.9.8 to 1.9.30</li><li>Atmosphere from
2.2.6 to 2.3.4</li><li>Cassandra from 2.1.2 to 2.1.8</li><li><p>Cassandra
Datastax Java Driver from 2.1.2 to 2.1.7.1</p></li><li>Cglib from 2.2 to
3.1</li><li>Chunk Tem
plates from 2.6.3 to 3.0.1</li><li>Classmate from 1.0.0 to 1.2.0</li><li>CMIS
0.8.0 to 0.13.0</li><li>DNSJava from 2.1.6 to 2.1.7</li><li>Docker-java from
0.10.5 to 1.3.0</li><li>Dropbox core Java SDK from 1.7.6 to
1.7.7</li><li>Dropwizard Metrics from 3.1.0 to 3.1.2</li><li>Ehcache from 2.9.1
to 2.10.0</li><li>Expression Language from 2.2.4 to 2.2.5</li><li>Facebook4j
from 1.1.12 to 2.3.0</li><li>Felix Config Admin from 1.8.0 to
1.8.6</li><li>Felix SCR annotations from 1.9.8 to 1.9.12</li><li>Freemarker
from 2.3.21 to 2.3.23</li><li>Flapdoodle Embedded MongoDB from 1.46.4 to
1.50.0</li><li>Google App Engine from 1.8.3 to 1.9.24</li><li>Gson from 3.2 to
3.2.1</li><li>Guice from 3.0 to 4.0</li><li>iCal4j from 1.5.0.2 to
1.6.0</li><li>Hazelcast from 3.4.2 to 3.5.1</li><li>Hibernate Validator from
5.0.3.Final to 5.2.1.Final</li><li>Hsqldb from 2.3.2 to
2.3.3</li><li>Infinispan from 6.0.2.Final to 7.2.4.Final</li><li><span>Jackson2
from 2.4.3 to 2.6.0</span></li><li><span>Jackrabbit fro
m 2.10.0 to 2.11.0</span></li><li>Jboss AS Maven Plugin from 7.4.Final to
7.7.Final<span><br clear="none"></span></li><li>Jboss Logging from 3.1.4.GA to
3.3.0.Final</li><li><span>Jboss Marshalling from 1.4.4.Final to
1.4.10.Final</span></li><li><span>Jboss Weld from 2.2.4.Final to
2.2.15.Final</span><span><br clear="none"></span></li><li><span>Jgroups from
3.6.1.Final to 3.6.4.Final</span></li><li><span>Jibx from 1.2.5 to
1.2.6</span></li><li><span>Joda-time from 2.5 to
2.8.1</span></li><li><span>Jruby from 1.7.18 to
1.7.21</span></li><li><span>Jsch from 0.1.51 to 0.1.53</span></li><li>Jsonpath
from 1.2.0 to 2.0.0</li><li>Jt400 from 6.7 to 8.5</li><li>Kafka from 0.8.1.1 to
0.8.2.0</li><li>LightCouch from 0.1.3 to 0.1.8</li><li>Minimal JSON from 0.9.1
to 0.9.3</li><li>MongoDB Java Driver from 2.12.4 to 3.0.3</li><li>Mvel2 from
2.2.1.Final to 2.2.6.Final</li><li>OGNL from 3.0.8 to 3.0.11</li><li>OpenEJB
from 4.6.0.2 to 4.7.2</li><li>OpenJPA from 2.3.0 to 2.4.0</li><li>Openshift
Java C
lient 2.5.0.Final to 2.7.0.Final</li><li>Pax Exam from 4.3.0 to
4.6.0</li><li>Pax Logging from 1.8.1 to 1.8.3</li><li>Pax Swissbox Tinybundles
from 1.3.1 to 1.3.2</li><li>PDFBox from 1.6.0 to 1.8.10</li><li>Rabbitmq Amqp
client from 3.3.4 to 3.5.4</li><li>Restlet from 2.2.x to 2.3.1<span><br
clear="none"></span></li><li>Scala from 2.11.5 to 2.11.7</li><li>Scala Maven
Plugin from 3.2.0 to 3.2.2</li><li>Scalatest from 2.2.0 to 2.2.5</li><li>Shade
Maven Plugin from 2.1 to 2.4</li><li>SLF4J from 1.7.10 to 1.7.12</li><li>Snappy
from <span>1.1.</span><span class="x x-first x-last">0.1 to
1.1.1.7</span></li><li>Snakeyaml from 1.14 to 1.16</li><li>Spring
upgrades</li><li>Sshd from 0.13.0 to 0.14.0</li><li>TestNG from 6.8.8 to
6.8.21</li><li>Twitter4J from 4.0.2 to 4.0.4</li><li>Univocity Parsers from
1.2.1 to 1.5.6</li><li>VertX from 2.2.5 to 3.0.0</li><li>Xmlunit from 1.5 to
1.6</li><li>XStream from 1.4.7 to 1.4.8</li><li>ZXing from 3.0.1 to
3.2.0</li></ul><h2 id="Camel2.16.0Release-I
mportantchangestoconsiderwhenupgrading">Important changes to consider when
upgrading</h2><ul><li>The dumpRoutesAsXml operation now preserve property
placeholder used in the route models. </li><li>Using setFaultBody /
setFaultHeader behaves similar to setBody / setHeader to preserve existing
headers/attachments by setting on existing IN or OUT message.</li><li>If using
concurrent consumer on <a shape="rect"
href="jms.html">JMS</a> endpoints for request/reply over JMS then you must
use the new replyToConcurrentConsumers, replyToMaxConcurrentConsumers options
to configure the values. </li><li>When the <a shape="rect"
href="aggregator2.html">Aggregator2</a> is forced completed the exchange
property <code>Exchange.AGGREGATED_COMPLETED_BY</code> value has been
changed from "forceCompletion" to "force" so its named like the other
completion triggers.</li><li>Removed unsupported modules camel-web and
camel-web-standalone.</li><li>Removed unsupported camel:dot f
unctionality from camel:run plugin.</li><li>Removed unsupported
camel-archetype-scala-component from maven archetypes.</li><li>The Maven
coordinate for linkedin and olingo2 components changed to be aligned like all
the others having groupId as just org.apache.camel.</li><li>If using MongoDB
component, the option<em> invokeGetLastError</em> doesn't exist anymore. The
option invokeGetLastError instructs the MongoDB Java driver to invoke
<em>getLastError()</em> after every call. In the 3.0.0 MongoDB driver
implementation, the <em>getLastError()</em> method in WriteResult has been
removed. So, if needed, use an acknowledged WriteConcern when executing the
write operation and then verify the correctness of the operation with the
method <em>wasAcknowledged()</em> of WriteResult.</li><li>The <a
shape="rect" href="jing.html">Jing</a> component now
uses <code>jing</code> as schema name in uris, instead
of <code>rng</code> or <code>rnc</code>. Those names has been removed.
</li><li><a shape="rect" href="swagger.html">Swagger</a> module now supports
getting api-docs from multiple camel contexts in the JVM. The entry point at
/api-docs now lists the contexts detected, and you need to append the context
id in the path, eg /api-docs/myCamel</li><li>If using <contextScan> with
Spring or Blueprint to filter RouteBuilder classes, then Camel will now by
default only look for singleton beans. You can turn on the old behavior to
include prototype scoped with the new
option <pre>includeNonSingletons</pre></li><li>camel-vertx has been
upgraded to vertx 3.0 which requires Java 8 at
runtime.</li><li><code>camel-cdi</code> is now using CDI 1.1 api - support for
1.0 has been dropped.</li><li><a shape="rect"
href="content-enricher.html">Content Enricher</a> with enrich and pollEnrich
now supports dynamic endpoint uris computed using an <a shape="rect"
href="expression.html">Expression</a> that allows to use values from the
current <a shape="r
ect" href="exchange.html">Exchange</a> so you for example can poll a file
which name is computed from data from the <a shape="rect"
href="exchange.html">Exchange</a> etc. This change breaks the XML DSL a little
bit and there is an easy migration effort. The Java DSL stays backwards
compatible.</li><li>Support for CXF 2.7 is dropped.</li><li>camel-jetty8 is
being considered deprecated and we would like to drop this in a nearby future
release as Jetty 8.x is EOL. </li><li>If you have explicit configured the
JMX statistics level to All then that option is now called
Default. </li><li>The HTTP based consumers no longer include Camel headers
in the responses by default (they already did this for the producers to not
include Camel headers when calling a HTTP service).</li><li><a shape="rect"
href="bindy.html">Bindy</a> requires to be configured using class names instead
of package names, as it now supports having multiple model classes in the same
java packages now.</li><li
><a shape="rect" href="using-camelproxy.html">Using CamelProxy</a> now binds
>the method parameters to the message body/header using Camel annotations to
>define the binding rules. If no annotations is defined the the parameter is
>assumed the message body. You can turn this off to have the old
>behavior.</li><li><a shape="rect" href="sjms.html">SJMS</a> component has
>been aligned to bind between Camel Message and JMS Message in the same way
>as <a shape="rect" href="jms.html">JMS</a> component does that, in the
>process a few APIs and behavior has been
>changed.</li><li><code>DefaultExchangeHolder</code> now only keep
>primitive / String type headers / exchange properties (like JMS component)
>and filter out other types such as java instances.</li></ul><h2
>id="Camel2.16.0Release-GettingtheDistributions">Getting the
>Distributions</h2><h3 id="Camel2.16.0Release-BinaryDistributions">Binary
>Distributions</h3><div class="table-wrap"><table
>class="confluenceTable"><tbody><tr><th colspan
="1" rowspan="1" class="confluenceTh"><p>Description</p></th><th colspan="1"
rowspan="1" class="confluenceTh"><p>Download Link</p></th><th colspan="1"
rowspan="1" class="confluenceTh"><p>PGP Signature file of
download</p></th></tr><tr><td colspan="1" rowspan="1"
class="confluenceTd"><p>Windows Distribution</p></td><td colspan="1"
rowspan="1" class="confluenceTd"><p><a shape="rect" class="external-link"
href="http://www.apache.org/dyn/closer.cgi/camel/apache-camel/2.16.0/apache-camel-2.16.0.zip">apache-camel-2.16.0.zip</a></p></td><td
colspan="1" rowspan="1" class="confluenceTd"><p><a shape="rect"
class="external-link"
href="http://www.apache.org/dist/camel/apache-camel/2.16.0/apache-camel-2.16.0.zip.asc">apache-camel-2.16.0.zip.asc</a></p></td></tr><tr><td
colspan="1" rowspan="1" class="confluenceTd"><p>Unix/Linux/Cygwin
Distribution</p></td><td colspan="1" rowspan="1" class="confluenceTd"><p><a
shape="rect" class="external-link"
href="http://www.apache.org/dyn/closer.cgi/camel/apac
he-camel/2.16.0/apache-camel-2.16.0.tar.gz">apache-camel-2.16.0.tar.gz</a></p></td><td
colspan="1" rowspan="1" class="confluenceTd"><p><a shape="rect"
class="external-link"
href="http://www.apache.org/dist/camel/apache-camel/2.16.0/apache-camel-2.16.0.tar.gz.asc">apache-camel-2.16.0.tar.gz.asc</a></p></td></tr></tbody></table></div><div
class="confluence-information-macro
confluence-information-macro-information"><p class="title">The above URLs use
redirection</p><span class="aui-icon aui-icon-small aui-iconfont-info
confluence-information-macro-icon"></span><div
class="confluence-information-macro-body"><p>The above URLs use the Apache
Mirror system to redirect you to a suitable mirror for your download. Some
users have experienced issues with some versions of browsers (e.g. some Safari
browsers). If the download doesn't seem to work for you from the above URL then
try using <a shape="rect" class="external-link"
href="http://www.mozilla.com/en-US/firefox/" rel="nofollow">FireFox</a
></p></div></div><h3 id="Camel2.16.0Release-SourceDistributions">Source
>Distributions</h3><div class="table-wrap"><table
>class="confluenceTable"><tbody><tr><th colspan="1" rowspan="1"
>class="confluenceTh"><p>Description</p></th><th colspan="1" rowspan="1"
>class="confluenceTh"><p>Download Link</p></th><th colspan="1" rowspan="1"
>class="confluenceTh"><p>PGP Signature file of download</p></th></tr><tr><td
>colspan="1" rowspan="1" class="confluenceTd"><p>Source for
>Windows</p></td><td colspan="1" rowspan="1" class="confluenceTd"><p><a
>shape="rect" class="external-link"
>href="http://www.apache.org/dyn/closer.cgi/camel/apache-camel/x.y.x/apache-camel-x.y.x-src.zip">apache-camel-x.y.x-src.zip</a></p></td><td
> colspan="1" rowspan="1" class="confluenceTd"><p><a shape="rect"
>class="external-link"
>href="http://www.apache.org/dist/camel/apache-camel/x.y.x/apache-camel-x.y.x-src.zip.asc">apache-camel-x.y.x-src.zip.asc</a></p></td></tr></tbody></table></div><div
> class="table-wrap"><table class="con
fluenceTable"><tbody><tr><td colspan="1" rowspan="1"
class="confluenceTd"><p>Source for Unix/Linux/Cygwin</p></td><td colspan="1"
rowspan="1" class="confluenceTd"><p><a shape="rect" class="external-link"
href="http://www.apache.org/dyn/closer.cgi/camel/apache-camel/x.y.x/apache-camel-x.y.x-src.tar.gz">apache-camel-x.y.x-src.tar.gz</a></p></td><td
colspan="1" rowspan="1" class="confluenceTd"><p><a shape="rect"
class="external-link"
href="http://www.apache.org/dist/camel/apache-camel/x.y.x/apache-camel-x.y.x-src.tar.gz.asc">apache-camel-x.y.x-src.tar.gz.asc</a></p></td></tr></tbody></table></div><h3
id="Camel2.16.0Release-GettingtheBinariesusingMaven2">Getting the Binaries
using Maven 2</h3><p>To use this release in your maven project, the proper
dependency configuration that you should use in your <a shape="rect"
class="external-link"
href="http://maven.apache.org/guides/introduction/introduction-to-the-pom.html">Maven
POM</a> is:</p><div class="code panel pdl" style="border-width: 1
px;"><div class="codeContent panelContent pdl">
<script class="brush: xml; gutter: false; theme: Default"
type="syntaxhighlighter"><![CDATA[<dependency>
<groupId>org.apache.camel</groupId>
<artifactId>camel-core</artifactId>