【发布时间】:2015-09-17 09:07:19
【问题描述】:
我在 grails 中使用 apache camel netty4,并且我已经声明 mycustom ServerInitializerFactory 如下
public class MyServerInitializerFactory extends ServerInitializerFactory {
private int maxLineSize = 1048576;
NettyConsumer nettyConsumer
public MimacsServerInitializerFactory() {}
@Override
protected void initChannel(Channel channel) throws Exception {
ChannelPipeline pipeline = channel.pipeline()
pipeline.addLast("logger", new LoggingHandler(LogLevel.INFO))
pipeline.addLast("framer", new LengthFieldBasedFrameDecoder(ByteOrder.LITTLE_ENDIAN, maxLineSize, 2, 2, 6, 0, false))
pipeline.addLast("decoder", new MfuDecoder())
pipeline.addLast("encoder", new MfuEncoder())
pipeline.addLast("handler", new MyServerHandler())
}
}
我有一条路线,我在路线构建器中设置如下。
from('netty4:tcp://192.168.254.3:553?serverInitializerFactory=#sif&keepAlive=true&sync=true&allowDefaultCodec=false').to('activemq:queue:Tracking.Queue')
我的 Camel Context 在 BootStrap.groovy 中设置如下
def serverInitializerFactory = new MyServerInitializerFactory()
SimpleRegistry registry = new SimpleRegistry()
registry.put("sif", serverInitializerFactory)
CamelContext camelContext = new DefaultCamelContext(registry)
camelContext.addComponent("activemq", activeMQComponent.activeMQComponent("failover:tcp://localhost:61616"))
camelContext.addRoutes new TrackingMessageRoute()
camelContext.start()
当我运行我的应用程序时,我的路由已启动,并且我的成帧器、解码器、处理程序和编码器都被调用,但消息没有到达跟踪。队列和响应不会返回给客户端。
如果我不在 netty url 和用户编码器和解码器中使用 serverInitializerFactory,我的消息将进入队列,但我无法控制我想要为收到的每种类型的消息发送的确认。似乎activemq 试图发送自己的响应,但被我的编码器拒绝。
我应该然后编写代码以再次发送还是我遗漏了什么?
【问题讨论】:
标签: grails apache-camel activemq netty