174.6. 사전 정의된 표현식


Camel 버전 2.1 부터,ECDHE 구성 요소에는ECDHE Expressions라는 사전 정의된 표현식이 포함되어 있습니다.

Camel 컨텍스트가 아직 시작되지 않은 경우에만 경로에 영향을 주는 지연기를 생성하려면ECDHE Expressions.delayIfContextNotStarted(long delay) 팩토리 방법을 사용합니다. 이 팩토리 메서드에서 생성한 표현식은 Camel 컨텍스트가 시작된 상태와 다른 경우에만 지정된 지연 값을 반환합니다. 이 표현식은 클러스터 내에서 singleton(마스터) 경로를 유지하기 위해ECDHE 구성 요소를 사용하려는 경우에 특히 유용합니다. Camel 컨텍스트가 아직 시작되지 않은 경우 Control Bus start 명령이 singleton 경로를 초기화하지 않습니다. 따라서 마스터 경로 시작 시간을 지연하여 Camel 컨텍스트 시작 후 초기화되었는지 확인해야 합니다. 이러한 시나리오는 클러스터 초기화 중에만 발생할 수 있으므로 슬레이브 노드의 시작을 새 마스터가 되는 것을 지연시키지 않습니다. 따라서 조건부 지연 표현이 필요합니다.

아래 스니펫은 cluster에서 마스터 노드의 초기 시작을 지연하기 위해ECDHE 구성 요소와 조건부 지연을 사용하는 방법을 보여줍니다.

import static java.util.concurrent.TimeUnit.SECONDS;
import static org.apache.camel.component.jgroups.JGroupsExpressions.delayIfContextNotStarted;
import static org.apache.camel.component.jgroups.JGroupsFilters.dropNonCoordinatorViews;
...
from("jgroups:clusterName?enableViewMessages=true").
  filter(dropNonCoordinatorViews()).
  threads().delay(delayIfContextNotStarted(SECONDS.toMillis(5))). // run in separated and delayed thread. Delay only if the context hasn't been started already.
  to("controlbus:route?routeId=masterRoute&action=start&async=true");

from("timer://master?repeatCount=1").routeId("masterRoute").autoStartup(false).to(masterMockUri); 
Copy to Clipboard Toggle word wrap
맨 위로 이동
Red Hat logoGithubredditYoutubeTwitter

자세한 정보

평가판, 구매 및 판매

커뮤니티

Red Hat 문서 정보

Red Hat을 사용하는 고객은 신뢰할 수 있는 콘텐츠가 포함된 제품과 서비스를 통해 혁신하고 목표를 달성할 수 있습니다. 최신 업데이트를 확인하세요.

보다 포괄적 수용을 위한 오픈 소스 용어 교체

Red Hat은 코드, 문서, 웹 속성에서 문제가 있는 언어를 교체하기 위해 최선을 다하고 있습니다. 자세한 내용은 다음을 참조하세요.Red Hat 블로그.

Red Hat 소개

Red Hat은 기업이 핵심 데이터 센터에서 네트워크 에지에 이르기까지 플랫폼과 환경 전반에서 더 쉽게 작업할 수 있도록 강화된 솔루션을 제공합니다.

Theme

© 2025 Red Hat