blob: 4c0342b039c60854b48f0dd8494de58a62753a19 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.camel.example.netty;
import java.util.Random;
import org.apache.camel.ExchangeTimedOutException;
import org.apache.camel.LoggingLevel;
import org.apache.camel.builder.RouteBuilder;
import org.apache.camel.main.Main;
/**
* Netty client which calls the server every half-second with a random word.
*/
public final class MyClient {
private MyClient() {
}
public static void main(String[] args) throws Exception {
Main main = new Main();
main.addRouteBuilder(new MyRouteBuilder());
// setup correlation manager and its timeout (when a request has not received a response within the given time millis)
MyCorrelationManager manager = new MyCorrelationManager();
// set timeout for each request message that did not receive a reply message
manager.setTimeout(5000);
// set the logging level when a timeout was hit, ny default its DEBUG
manager.setTimeoutLoggingLevel(LoggingLevel.INFO);
main.bind("myEncoder", new MyCodecEncoderFactory());
main.bind("myDecoder", new MyCodecDecoderFactory());
main.bind("myManager", manager);
main.run(args);
}
public static class MyRouteBuilder extends RouteBuilder {
private String[] words = new String[]{"foo", "bar", "baz", "beer", "wine", "cheese"};
private int counter;
public int increment() {
return ++counter;
}
public String word() {
int ran = new Random().nextInt(words.length);
return words[ran];
}
@Override
public void configure() throws Exception {
// lets build a special custom error message for timeout
onException(ExchangeTimedOutException.class)
// here we tell Camel to continue routing
.continued(true)
// after it has built this special timeout error message body
.setBody(simple("#${header.corId}:${header.word}-Time out error!!!"));
from("timer:trigger")
// set correlation id as unique incrementing number
.setHeader("corId", method(this, "increment"))
// set random word to use in request
.setHeader("word", method(this, "word"))
// build request message as a string body
.setBody(simple("#${header.corId}:${header.word}"))
// log request before
.log("Request: ${id}:${body}")
// call netty server using a single shared connection and using custom correlation manager
// to ensure we can correltly map the request and response pairs
.to("netty4:tcp://localhost:4444?sync=true&encoders=#myEncoder&decoders=#myDecoder"
+ "&producerPoolEnabled=false&correlationManager=#myManager")
// log response after
.log("Response: ${id}:${body}");
}
}
}