Mina中使用多个filter,解码的时候总是出现问题,解码顺序似乎一直有问题。看了源码终于找到问题所在。
ProtocolCodecFilter中有一些AttributeKey,会放在IoSession中的attribute里。
private final AttributeKey ENCODER = new AttributeKey(ProtocolCodecFilter.class, "encoder");
private final AttributeKey DECODER = new AttributeKey(ProtocolCodecFilter.class, "decoder");
private final AttributeKey DECODER_OUT = new AttributeKey(ProtocolCodecFilter.class, "decoderOut");
private final AttributeKey ENCODER_OUT = new AttributeKey(ProtocolCodecFilter.class, "encoderOut");
我原本以为 新new出来的AttributeKey,在Iosession的Map中会是不同的key,但是我错了。
public int hashCode() {
int h = 17 * 37 + ((name == null) ? 0 : name.hashCode());
return h;
}
AttributeKey 的hashCode方法被重写了,所以hash值都是根据name来的。
这样导致如果多个ProtocolCodecFilter 这些 key所在value被共享了。这样问题来了
看下DECODER_OUT这个key的value:
private static class ProtocolDecoderOutputImpl extends
AbstractProtocolDecoderOutput {
public ProtocolDecoderOutputImpl() {
// Do nothing
}
public void flush(NextFilter nextFilter, IoSession session) {
Queue<Object> messageQueue = getMessageQueue();
while (!messageQueue.isEmpty()) {
nextFilter.messageReceived(session, messageQueue.poll());
}
}
}
当第一个filter解码器 解码产生一个对象A,放入messageQueue 然后调用
while (!messageQueue.isEmpty()) {
nextFilter.messageReceived(session, messageQueue.poll());
}
第二个filter解码器根据传入的对象A( messageQueue.poll()出来的),解码产生对象B,放入messageQueue 。
这个时候问题来了,!messageQueue.isEmpty() 又变true了循环继续,
传入第二个filter解码器的是刚刚自己产生的对象B,这样显然不能再解码一次对象B。
总结:继承同一超类filter的不要使用多个。
分享到:
相关推荐
Filter链可以包含多个Filter,每个Filter都有自己的业务逻辑,比如身份验证、消息格式检查等。 在Filter中,我们可以实现消息的解码和编码。通常,我们会自定义一个Message类来表示聊天消息,然后创建对应的Decoder...
Mina 是一个高性能的网络通信框架,主要用于构建网络应用程序,如服务器端的TCP或UDP通信。在Mina程序执行过程中,...在实际项目中,你还可以根据需求添加更多的 Filter 来实现更复杂的逻辑,如身份验证、流量控制等。
NIO是Java提供的一个扩展,与传统的阻塞I/O模型不同,它允许单线程处理多个连接,提高了系统资源利用率。 首先,我们需要了解Mina的基本组件,如Session、Filter和ProtocolDecoder/Encoder。Session代表了服务器与...
在"mina demo全套"的源码中,`src`目录下可能包含了多个子目录,每个子目录代表一个特定的示例,这些示例通常会包含服务端和客户端的代码,通过阅读和运行这些代码,你可以了解Mina如何设置和管理会话、处理I/O事件...
为了提高性能,可以利用Mina2的多线程模型,实现并发处理多个连接。此外,还可以结合Spring框架,将Mina2集成到Spring Boot应用中,实现更灵活的服务注册和发现。 总结,Apache Mina2提供了一套强大的工具,使得...
总结起来,利用Apache Mina进行文件上传,开发者需要理解Mina的基本架构和组件,设计并实现相应的Filter、Decoder、Encoder和Handler,以及妥善处理网络通信中的各种事件。这样,就可以构建出高效、稳定的文件上传...
MINA的核心是其异步事件驱动模型,它基于Java NIO(Non-blocking I/O)库,通过选择器(Selector)来监控多个通道(Channel)的状态变化,当有数据可读或可写时,选择器会唤醒,从而减少了线程的阻塞时间,提升了...
在构建多人聊天室程序时,首先我们需要在Spring配置文件中定义Mina的相关bean,包括ServerSocketConnector、ProtocolDecoder和ProtocolEncoder等。这些bean负责监听客户端连接、解析接收到的数据以及编码发送给...
会话累积可能指的是将多个小消息合并成一个大消息进行传输,以减少网络传输的次数,提高效率。这在低带宽或者高延迟的网络环境中尤其重要。实现这个功能,我们需要创建一个新的编码器类,继承自Mina提供的基础编码器...
1. **异步事件驱动**:MINA 使用非阻塞I/O模型,这意味着它能够在单个线程上处理多个连接,提高了服务器的并发性能。当数据可用时,MINA会触发相应的事件,比如连接建立、数据读取或写入完成。 2. **协议无关性**:...
1. **事件驱动模型**:Mina基于I/O多路复用技术,如Java的NIO(Non-blocking I/O),实现了一个事件驱动的模型。这意味着当数据准备好读取或写入时,Mina会触发相应的事件,而不是一直阻塞等待。 2. **Session**:...
它基于Java NIO(Non-blocking Input/Output)库,能够高效地管理多个连接,而无需为每个连接创建新的线程,从而避免了线程资源的过度消耗。 在minaTcp实例中,我们通常会涉及到以下组件: 1. **Session**:这是...