273.8. reactive 프레임워크로 Camel 데이터 처리


티브 스트림 게시자를 통해 양방향 방식으로 데이터를 교환할 수 있지만 Camel 경로는 종종 in-out exchange 패턴을 사용합니다(예: REST 엔드포인트 정의 및 일반적으로 각 요청에 응답 필요).

이러한 상황에서 사용자는 실시간 처리 단계를 흐름에 추가하여 Camel 경로를 개선하거나 반응형 프레임워크를 사용하여 전체 변환을 정의할 수 있습니다.

예를 들어 다음 경로가 제공됩니다.

from("timer:clock")
.setBody().header(Exchange.TIMER_COUNTER)
.to("direct:reactive")
.log("Continue with Camel route... n=${body}");
Copy to Clipboard Toggle word wrap

reactive processing step은 "direct:reactive" 엔드포인트에 연결될 수 있습니다.

CamelReactiveStreamsService camel = CamelReactiveStreams.get(context);

camel.process("direct:reactive", Integer.class, items ->
    Flowable.fromPublisher(items) // RxJava2
        .map(n -> -n)); // make every number negative
Copy to Clipboard Toggle word wrap

Camel 경로에서 데이터 흐름은 외부 반응 프레임워크에서 처리한 후 Camel 내부의 처리 흐름을 계속합니다.

이 메커니즘은 완전히 반응형 방식으로 인-Out exchange를 정의하는 데에도 사용할 수 있습니다.

CamelReactiveStreamsService camel = CamelReactiveStreams.get(context);

// requires a rest-capable Camel component
camel.process("rest:get:orders", exchange ->
                    Flowable.fromPublisher(exchange)
                            .flatMap(ex -> allOrders())); // retrieve orders asynchronously
Copy to Clipboard Toggle word wrap

자세한 내용은 Camel 예제(camel-example-reactive-streams)를 참조하십시오.

맨 위로 이동
Red Hat logoGithubredditYoutubeTwitter

자세한 정보

평가판, 구매 및 판매

커뮤니티

Red Hat 문서 정보

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

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

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

Red Hat 소개

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

Theme

© 2025 Red Hat