JCR
Поддерживаются как производитель, так и потребитель.
Компонент JCR позволяет добавлять/читать узлы в/из репозитория контента, совместимого с JCR, например, Apache Jackrabbit, с помощью производителя, или зарегистрировать EventListener с помощью потребителя.
Вы можете использовать потребителя в качестве EventListener в JCR или производителя для чтения узла по идентификатору.
Пользователям Maven необходимо добавить следующую зависимость в свой pom.xml для этого компонента:
<dependency>
<groupId>org.apache.camel</groupId>
<artifactId>camel-jcr</artifactId>
<version>x.x.x</version>
<!-- use the same version as your Camel core version -->
</dependency>URI format
<span style="color: rgb(0,0,0);">jcr://user:password@repository/path/to/node</span>
Элемент repository в URI используется для поиска объекта JCR Repository в реестре контекста Camel.
Configuring Options
Компоненты настраиваются на двух отдельных уровнях:
-
component level
-
edpoint level
Configuring Component Options
На уровне компонента задаются основные и общие настройки, которые впоследствии наследуются endpoints. Это самый высокий уровень конфигурации.
Например, компонент может иметь настройки безопасности, учетные данные для аутентификации, URL-адреса для сетевых подключений и т. д.
Некоторые компоненты имеют всего несколько параметров, в то время как у других их может быть много. Поскольку компоненты обычно имеют предварительно настроенные значения по умолчанию, которые используются в большинстве случаев, вам может понадобиться настроить только несколько параметров компонента или вообще ничего не настраивать.
Компоненты можно настроить с использованием:
-
Component DSL.
-
Конфигурационного файла (application.properties, *.yaml files, etc).
-
Напрямую в Java code.
Configuring Endpoint Options
Обычно больше времени уходит на настройку endpoints, так как они обладают множеством параметров. Эти параметры позволяют настроить поведение endpoint в соответствии с вашими потребностями. Кроме того, параметры делятся на категории в зависимости от того, используется ли endpoint как потребитель (from), как производитель (to) или в обеих ролях.
Настройка endpoints чаще всего выполняется непосредственно в URI endpoint в виде параметров пути и запроса. Также вы можете использовать Endpoint DSL и DataFormat DSL как типобезопасный способ настройки endpoints и форматов данных в Java.
Хорошей практикой при настройке параметров является использование Property Placeholders.
Property placeholders предоставляют несколько преимуществ:
-
Помогают избежать использования жестко закодированных URL-адресов, номеров портов, конфиденциальной информации и других настроек.
-
Позволяют вынести конфигурацию за пределы кода.
-
Делают код более гибким и удобным для повторного использования.
Component properties
Base
-
Получает базовый узел при доступе к репозиторию.
-
По умолчанию:
-
Тип: String
Deep
-
Когда isDeep имеет значение true, события, связанные с родительским узлом на пути absPath или в его подграфе, будут получены.
-
По умолчанию: false
-
Тип: boolean
Event Types
-
eventTypes (комбинация одного или нескольких типов событий, закодированных как битовая маска, например, javax.jcr.observation.Event.NODE_ADDED, javax.jcr.observation.Event.NODE_REMOVED и т.д.).
-
По умолчанию:
-
Тип: int
Host
-
Обязательный параметр - Имя javax.jcr.Repository для поиска в реестре Camel, который будет использоваться.
-
По умолчанию:
-
Тип: String
No Local
-
Тип: Если noLocal имеет значение true, то события, сгенерированные сессией, через которую был зарегистрирован слушатель, игнорируются. В противном случае они не игнорируются.
-
По умолчанию: false
-
Тип: boolean
Node Type Names
-
Когда задана строка списка nodeTypeName, разделённого запятыми, будут получены только те события, связанные с родительским узлом, который имеет один из типов узлов (или подтип одного из типов узлов) в этом списке.
-
По умолчанию:
-
Тип: String
Password
-
Пароль для входа.
-
По умолчанию:
-
Тип: String
Session Live Check Interval
-
Тип: Интервал в миллисекундах для ожидания перед каждой проверкой активности сессии. Значение по умолчанию -- 60000 мс.
-
По умолчанию: 60000
-
Тип: long
Session Live Check Interval On Start
-
Интервал в миллисекундах для ожидания перед первой проверкой активности сессии. Значение по умолчанию -- 3000 мс.
-
По умолчанию: 3000
-
Тип: long
Username
-
Имя пользователя для входа.
-
По умолчанию:
-
Тип: String
Uuids
-
Когда задана строка списка uuid, разделённого запятыми, будут получены только те события, связанные с родительским узлом, который имеет один из идентификаторов в этом списке.
-
По умолчанию:
-
Тип: String
Workspace Name
-
Тип: Рабочая область для доступа. Если она не указана, будет использована область по умолчанию.
-
По умолчанию:
-
Тип: String
Component advanced properties
Bridge Error Handler
-
Предоставляет возможность связать потребителя с маршрутизатором Error Handler Camel. Это позволяет обрабатывать исключения (если возможно), возникающие при получении входящих сообщений потребителем Camel, в виде сообщений, передаваемых в маршрутизатор Error Handler.
Важно: Это возможно только в том случае, если сторонний компонент позволяет Camel получать уведомления о возникших исключениях. Некоторые компоненты обрабатывают исключения только внутренне, из-за чего использование bridgeErrorHandler становится невозможным. В некоторых случаях мы можем доработать компонент Camel, чтобы интегрировать его со сторонним компонентом и сделать такую возможность доступной в будущих выпусках. По умолчанию потребитель использует org.apache.camel.spi.ExceptionHandler для обработки исключений, которые логируются с уровнем WARN или ERROR и игнорируются.
-
По умолчанию: false
-
Тип: boolean
Exception Handler
-
Позволяет потребителю использовать собственный ExceptionHandler.
Обратите внимание, что если включена опция bridgeErrorHandler, то эта настройка не используется. По умолчанию потребитель обрабатывает исключения, которые логируются с уровнем WARN или ERROR и игнорируются.
-
По умолчанию:
-
Тип: ExceptionHandler
Exchange Pattern
-
Определяет шаблон взаимодействия, который применяется, когда потребитель создает новый обмен (exchange).
Возможные значения:
-
InOnly
-
InOut
-
-
По умолчанию:
-
Тип: ExchangePattern