이 콘텐츠는 선택한 언어로 제공되지 않습니다.
Chapter 201. LDIF Component
Available as of Camel version 2.20
The ldif component allows you to do updates on an LDAP server from a LDIF body content.
This component uses a basic URL syntax to access the server. It uses the Apache DS LDAP library to process the LDIF. After processing the LDIF, the response body will be a list of statuses for success/failure of each entry.
The Apache LDAP API is very sensitive to LDIF syntax errors. If in doubt, refer to the unit tests to see an example of each change type.
Maven users will need to add the following dependency to their pom.xml
for this component:
201.1. URI format 링크 복사링크가 클립보드에 복사되었습니다!
ldap:ldapServerBean[?options]
ldap:ldapServerBean[?options]
The ldapServerBean portion of the URI refers to a LdapConnection. This should be constructed from a factory at the point of use to avoid connection timeouts. The LDIF component only supports producer endpoints, which means that an ldif
URI cannot appear in the from
at the start of a route.
For SSL configuration, refer to the camel-ldap
component where there is an example of setting up a custom SocketFactory instance.
You can append query options to the URI in the following format, ?option=value&option=value&…
201.2. Options 링크 복사링크가 클립보드에 복사되었습니다!
The LDIF component has no options.
The LDIF endpoint is configured using URI syntax:
ldif:ldapConnectionName
ldif:ldapConnectionName
with the following path and query parameters:
201.2.1. Path Parameters (1 parameters): 링크 복사링크가 클립보드에 복사되었습니다!
Name | Description | Default | Type |
---|---|---|---|
ldapConnectionName | Required The name of the LdapConnection bean to pull from the registry. Note that this must be of scope prototype to avoid it being shared among threads or using a connection that has timed out. | String |
201.2.2. Query Parameters (1 parameters): 링크 복사링크가 클립보드에 복사되었습니다!
Name | Description | Default | Type |
---|---|---|---|
synchronous (advanced) | Sets whether synchronous processing should be strictly used, or Camel is allowed to use asynchronous processing (if supported). | false | boolean |
201.3. Body types: 링크 복사링크가 클립보드에 복사되었습니다!
The body can be a URL to an LDIF file or an inline LDIF file. To signify the difference in body types, an inline LDIF must start with:
version: 1
version: 1
If not, the component will try to parse the body as a URL.
201.4. Result 링크 복사링크가 클립보드에 복사되었습니다!
The result is returned in the Out body as a ArrayList<java.lang.String>
object. This contains either "success" or an Exception message for each LDIF entry.
201.5. LdapConnection 링크 복사링크가 클립보드에 복사되었습니다!
The URI, ldif:ldapConnectionName
, references a bean with the ID, ldapConnectionName
. The ldapConnection can be configured using a LdapConnectionConfig
bean. Note that the scope must have a scope of prototype
to avoid the connection being shared or picking up a stale connection.
The LdapConnection
bean may be defined as follows in Spring XML:
or in a OSGi blueprint.xml:
201.6. Samples 링크 복사링크가 클립보드에 복사되었습니다!
Following on from the Spring configuration above, the code sample below sends an LDAP request to filter search a group for a member. The Common Name is then extracted from the response.
201.7. LevelDB 링크 복사링크가 클립보드에 복사되었습니다!
Available as of Camel 2.10
Leveldb is a very lightweight and embedable key value database. It allows together with Camel to provide persistent support for various Camel features such as Aggregator.
Current features it provides:
- LevelDBAggregationRepository
201.7.1. Using LevelDBAggregationRepository 링크 복사링크가 클립보드에 복사되었습니다!
LevelDBAggregationRepository
is an AggregationRepository
which on the fly persists the aggregated messages. This ensures that you will not loose messages, as the default aggregator will use an in memory only AggregationRepository
.
It has the following options:
Option | Type | Description |
---|---|---|
| String |
A mandatory repository name. Allows you to use a shared |
| String | Filename for the persistent storage. If no file exists on startup a new file is created. |
| LevelDBFile |
Use an existing configured |
| boolean | Camel 2.12: Whether or not the LevelDBFile should sync on write or not. Default is false. By sync on write ensures that its always waiting for all writes to be spooled to disk and thus will not loose updates. See LevelDB docs for more details about async vs sync writes. |
| boolean |
Whether the get operation should return the old existing Exchange if any existed. By default this option is |
| boolean |
Whether or not recovery is enabled. This option is by default |
| long | If recovery is enabled then a background task is run every x’th time to scan for failed exchanges to recover and resubmit. By default this interval is 5000 millis. |
| int |
Allows you to limit the maximum number of redelivery attempts for a recovered exchange. If enabled then the Exchange will be moved to the dead letter channel if all redelivery attempts failed. By default this option is disabled. If this option is used then the |
| String |
An endpoint uri for a Dead Letter Channel where exhausted recovered Exchanges will be moved. If this option is used then the |
The repositoryName
option must be provided. Then either the persistentFileName
or the levelDBFile
must be provided.
201.7.2. What is preserved when persisting 링크 복사링크가 클립보드에 복사되었습니다!
LevelDBAggregationRepository
will only preserve any Serializable
compatible message body data types. Message headers must be primitive / string / numbers / etc. If a data type is not such a type its dropped and a WARN
is logged. And it only persists the Message
body and the Message
headers. The Exchange
properties are not persisted.
201.7.3. Recovery 링크 복사링크가 클립보드에 복사되었습니다!
The LevelDBAggregationRepository
will by default recover any failed Exchange. It does this by having a background tasks that scans for failed Exchanges in the persistent store. You can use the checkInterval
option to set how often this task runs. The recovery works as transactional which ensures that Camel will try to recover and redeliver the failed Exchange. Any Exchange which was found to be recovered will be restored from the persistent store and resubmitted and send out again.
The following headers is set when an Exchange is being recovered/redelivered:
Header | Type | Description |
---|---|---|
| Boolean | Is set to true to indicate the Exchange is being redelivered. |
| Integer | The redelivery attempt, starting from 1. |
Only when an Exchange has been successfully processed it will be marked as complete which happens when the confirm
method is invoked on the AggregationRepository
. This means if the same Exchange fails again it will be kept retried until it success.
You can use option maximumRedeliveries
to limit the maximum number of redelivery attempts for a given recovered Exchange. You must also set the deadLetterUri
option so Camel knows where to send the Exchange when the maximumRedeliveries
was hit.
You can see some examples in the unit tests of camel-leveldb, for example this test.
201.7.3.1. Using LevelDBAggregationRepository in Java DSL 링크 복사링크가 클립보드에 복사되었습니다!
In this example we want to persist aggregated messages in the target/data/leveldb.dat
file.
201.7.3.2. Using LevelDBAggregationRepository in Spring XML 링크 복사링크가 클립보드에 복사되었습니다!
The same example but using Spring XML instead:
201.7.4. Dependencies 링크 복사링크가 클립보드에 복사되었습니다!
To use LevelDB in your camel routes you need to add the a dependency on camel-leveldb.
If you use maven you could just add the following to your pom.xml, substituting the version number for the latest & greatest release (see the download page for the latest versions).
<dependency> <groupId>org.apache.camel</groupId> <artifactId>camel-leveldb</artifactId> <version>2.10.0</version> </dependency>
<dependency>
<groupId>org.apache.camel</groupId>
<artifactId>camel-leveldb</artifactId>
<version>2.10.0</version>
</dependency>
201.7.5. See Also 링크 복사링크가 클립보드에 복사되었습니다!
- Configuring Camel
- Component
- Endpoint
- Getting Started
- Aggregator
- HawtDB
- Components