Camel使用Java DSL设置CXF超时

时间:2013-03-11 09:59:44

标签: cxf apache-camel

我对骆驼很新,并且遇到了问题。

我正在尝试使用cxf端点创建动态Web服务代理(正在运行)。一切进展顺利,但我不知道如何使用Java DSL设置cxf端点超时。

我发现很多关于如何使用Spring配置的文章,但我试图通过仅使用Java DSL来实现这一点。

以下是我目前的情况,请有人指出我如何使用Java DSL操纵CXF超时(连接/接收)的正确方向

public void configure() throws Exception
{

    onException(Exception.class).handled(true).transform()
            .method(MyExceptionHandler.class, "handleException");

    CxfEndpoint inboundCxf = new CxfEndpoint();
    inboundCxf.setAddress(soapProxyConfig.getBaseUrl()
            + soapProxyConfig.getAddress());
    inboundCxf.setCamelContext(camelContext);
    inboundCxf.setDataFormat(DataFormat.RAW);
    inboundCxf.setServiceName(new QName(soapProxyConfig
            .getTargetNamespace(), soapProxyConfig.getRemoteServiceName()));
    inboundCxf.setPortName(new QName(soapProxyConfig.getTargetNamespace(),
            soapProxyConfig.getRemotePortName()));
    inboundCxf.setWsdlURL(soapProxyConfig.getRemoteWsdl());

    SedaEndpoint sedaEndpoint = new SedaEndpoint();
    sedaEndpoint.setConcurrentConsumers(100);
    sedaEndpoint.setExchangePattern(ExchangePattern.InOut);
    sedaEndpoint.setSize(100);
    sedaEndpoint.setCamelContext(camelContext);
    sedaEndpoint.setEndpointUriIfNotSpecified("seda:" + routeId + "-Queue");

    Endpoint[] remoteEndpoints = new Endpoint[soapProxyConfig
            .getRemoteUrls().size()];
    for (int i = 0; i < soapProxyConfig.getRemoteUrls().size(); i++)
    {
        Endpoint endpoint = camelContext.getEndpoint(soapProxyConfig
                .getRemoteUrls().get(i));

        endpoint.setCamelContext(camelContext);
        remoteEndpoints[i] = endpoint;
    }

    from(inboundCxf).routeId(routeId)
            .routePolicy(new WebServiceRoutePolicy()).to(sedaEndpoint);
    from(sedaEndpoint).routeId(routeId + "-Queue").loadBalance()
            .roundRobin().to(remoteEndpoints).id("Out");

1 个答案:

答案 0 :(得分:1)

好的,所以经过一些测试并拔掉我的头发后,我发现我的方式完全是错误的。

我不需要设置入站CXF超时值,我只需要设置出站http超时值,这样就可以获得所需的超时检测。

所以现在我的路线看起来像这样

        onException(Exception.class).handled(true).transform(
            method(SoapExceptionHandler.class, "handleException"));

    SedaEndpoint sedaEnpoint = createSedaEnpoint();
    JettyHttpEndpoint jettyEnpoint = createJettyHttpEndpoint();

    CxfEndpoint cxfEnpoint = createCxfEndpoint();

    from(cxfEnpoint).routeId(getRouteName()).to(sedaEnpoint);
    from(sedaEnpoint).to(jettyEnpoint)
            .routeId(getRouteName() + "-endpoint");

对于想要知道如何设置JettyProducer超时的人,我们去

private JettyHttpEndpoint createJettyHttpEndpoint() throws Exception
{
    JettyHttpComponent jettyComponent = new JettyHttpComponent();
    jettyComponent.setCamelContext(camelContext);
    jettyComponent.setHttpClientMinThreads(proxyConfig
            .getMinRemoteClientThreads());
    jettyComponent.setHttpClientMaxThreads(proxyConfig
            .getMaxRemoteClientThreads());

    JettyHttpEndpoint jettyEnpoint = new JettyHttpEndpoint(jettyComponent,
            "jetty:http", new URI(proxyConfig.getTargetEndpointUrl()));
    jettyEnpoint.setCamelContext(camelContext);
    jettyEnpoint.setExchangePattern(ExchangePattern.InOut);
    jettyEnpoint.setThrowExceptionOnFailure(false);
    jettyEnpoint.getClient().setTimeout(
            proxyConfig.getRemoteEndpointTimeout());

    return jettyEnpoint;
}

使用该配置并在Jetty端点设置超时,我现在可以获得可配置的超时:)