우리는 Java 메소드를 호출하는 많은 (20-50) "직접"경로가있는 Apache Camel을 사용하여 웹 서비스를 구현하고 있습니다. 모든 방법에는 기본적으로 비즈니스 규칙 처리 또는 DAO 액세스 방법을위한 경로가 있습니다. 모든 경로는 from("direct:").to("direct")
을 사용하지만 다른 구성 요소에는 사용하지 않습니다.Apache Camel의 잘못된 사용 사례일까요?
표준 Controller-> bo-> dao 레이어에서 시스템을 분리하는 것처럼 보일 수도 있지만 불필요한 Camel 루트의 책 보관이 추가됩니다.
보다 나은 대안은 Business Objects 및 Dao 계층에 대한 Java 인터페이스를 정의하고 내부에 종속성이있는 다른 서비스 (시스템 외부의 것, 예 : file://
또는 http://
)에 대한 추가 인터페이스를 정의하는 것일뿐입니다. 비즈니스 개체 또는 컨트롤러. 이 추가 인터페이스 구현은 Apache Camel을 사용하여 외부 서비스와 통신합니다.
나는 현재 동료에게 내 요점을 알도록 설득하는 방법에 대해 생각하고 있습니다.
생각하십니까?
tldr; 응용 프로그램이 1 ~ 2 개 밖에없는 곳에 Apache Camel을 사용해야합니까?
안녕하세요. 불행히도이 형식에 대한 질문은 너무 모호합니다. [스택 오버플로 포럼입니까?] (http://meta.stackexchange.com/q/92107/195481)를 참조하십시오. 여기에 질문을하려면 토론 주제가 아닌 해결책을 찾고자하는 특정 문제가 정말로 필요합니다. – Jeff
죄송합니다. 불쾌감을 유발하면 죄송합니다. 여기에 꽤 차가운 메시지를 남기는 사람들이 많습니다. 나는 그것을 피하기 위해 약간의 성격을 추가하려고합니다. 그러나 그것은 적대적인 태도로 끝날 수 있습니다. 이 질문이 사이트에 적합하지 않다고 말하는 이유는 아마 어느 쪽이든 주장 할 수 있다는 것입니다. 이러한 종류의 상황은 매우 상황이 좋을 수 있습니다. 세부 사항을 제공하고 더 나은 답변을 얻는 것이 훨씬 좋습니다. 당신이 지적한대로, 이것은 나의 전문 분야가 아니므로 나는 틀릴 수도 있습니다. 나는 프로그래밍에 10 년 이상을 투자했지만, 내가 말하는 것에 대해 생각하고있다. – Jeff
코드 예제를 통해 질문이 더 명확해질 수 있다고 생각합니다 (예 : 전체 시스템을 통해 하나의 일반적인 메시지로 단순화 된 경로 표시). 또한, 거의 확실히 [프로그래머 .se] (http://programmers.stackexchange.com/)에 더 적합 할 것입니다. –