- 浏览: 979853 次
文章分类
- 全部博客 (428)
- Hadoop (2)
- HBase (1)
- ELK (1)
- ActiveMQ (13)
- Kafka (5)
- Redis (14)
- Dubbo (1)
- Memcached (5)
- Netty (56)
- Mina (34)
- NIO (51)
- JUC (53)
- Spring (13)
- Mybatis (17)
- MySQL (21)
- JDBC (12)
- C3P0 (5)
- Tomcat (13)
- SLF4J-log4j (9)
- P6Spy (4)
- Quartz (12)
- Zabbix (7)
- JAVA (9)
- Linux (15)
- HTML (9)
- Lucene (0)
- JS (2)
- WebService (1)
- Maven (4)
- Oracle&MSSQL (14)
- iText (11)
- Development Tools (8)
- UTILS (4)
- LIFE (8)
最新评论
-
Donald_Draper:
Donald_Draper 写道刘落落cici 写道能给我发一 ...
DatagramChannelImpl 解析三(多播) -
Donald_Draper:
刘落落cici 写道能给我发一份这个类的源码吗Datagram ...
DatagramChannelImpl 解析三(多播) -
lyfyouyun:
请问楼主,执行消息发送的时候,报错:Transport sch ...
ActiveMQ连接工厂、连接详解 -
ezlhq:
关于 PollArrayWrapper 状态含义猜测:参考 S ...
WindowsSelectorImpl解析一(FdMap,PollArrayWrapper) -
flyfeifei66:
打算使用xmemcache作为memcache的客户端,由于x ...
Memcached分布式客户端(Xmemcached)
MINA TCP简单通信实例:http://donald-draper.iteye.com/blog/2375297
Mina 过滤链默认构建器:http://donald-draper.iteye.com/blog/2375985
在TCP简单通信实例这篇文章中我们测试了一下LoggerFilter,同时我们也实现了一个Filter,今天我们来看一下过滤器IoFilter的定义。
总结:
IoFilter添加到过滤链时,一般以ReferenceCountingIoFilter包装,添加到过滤链,init方法在添加到过滤链时,由ReferenceCountingIoFilter调用,所以可以在init方法初始化一些共享资源。如果过滤器没有包装成ReferenceCountingIoFilter,init方法将不会调用。然后调用onPreAdd通知过滤器将会添加到过滤连上,当过滤器添加到过滤链上时,所有IoHandler事件和IO请求,将会被过滤器拦截当过滤器添加到过滤链上后,将会调用onPostAdd,如果方法有异常,过滤器在过滤链的链尾,ReferenceCountingIoFilter将调用#destroy方法释放共享资源。过滤器IoFilter,主要是监听会话IoSession相关事件(创建,打开,空闲,异常,关闭,接受数据,发送数据) 及IoSesssion的Write与close事件;过滤器后继NextFilter关注的事件与过滤器IoFilter相同,主要是转发相关事件。WriteRequest是会话IoSession写操作write的包装,内部有一个消息对象用于存放write的内容,一个socket地址,即会话写请求的目的socket地址,一个写请求结果返回值WriteFuture,用于获取会话write消息的操作结果。当一个过滤器从过滤链上移除时,#onPreRemove被调用,用于通知过滤器将从过滤链上移除;如果过滤器从过滤链上移除,所有IoHandler事件和IO请求,过滤器不再拦截;#onPostRemove调用通知过滤器已经从过滤链上移除;移除后,如果过滤器在过滤链的链尾,ReferenceCountingIoFilter将调用#destroy方法释放共享资源。
IoFilter生命周期如下:
inti->onPreAdd->onPostAdd->(拦截IoHandler相关事件:sessionCreated,Opened,Idle,
exceptionCaught,Closed,messageSent,messageReceived;会话相关事件:filterWrite,filterClose)->onPreRemove
->onPostRemove->destroy。
附:
//IoFilterAdapter,过滤器适配器
IoFuture:异步IO操作结果
WriteFuture:异步写操作结果
Mina 过滤链默认构建器:http://donald-draper.iteye.com/blog/2375985
在TCP简单通信实例这篇文章中我们测试了一下LoggerFilter,同时我们也实现了一个Filter,今天我们来看一下过滤器IoFilter的定义。
package org.apache.mina.common; import java.net.SocketAddress; import org.apache.mina.filter.ReferenceCountingIoFilter; /** * A filter which intercepts {@link IoHandler} events like Servlet * filters. Filters can be used for these purposes: 过滤器可以拦截IoHandler的相关事件,与Servlet过滤器相似。过滤器可以用于以下目的: * [list] * [*]Event logging, 事件日志 * [*]Performance measurement, 性能测试 * [*]Authorization, 认证 * [*]Overload control, 负载控制 * [*]Message transformation (e.g. encryption and decryption, ...), 消息传输(加密解密) * [*]and many more. * [/list] * <p> * [b]Please NEVER implement your filters to wrap * {@link IoSession}s.[/b] Users can cache the reference to the * session, which might malfunction if any filters are added or removed later. * 坚决不要在实现过滤器时,wrap会话。用户可以缓存会话的引用,如果过滤器添加或移除过后, 可能会导致故障。 * <h3>The Life Cycle</h3>声明周期 * {@link IoFilter}s are activated only when they are inside {@link IoFilterChain}. * <p>当过滤器添加到过滤链上,过滤器被激活 * When you add an {@link IoFilter} to an {@link IoFilterChain}: * [list=1]当添加一个过滤器到过滤链上时: * <li>{@link #init()} is invoked by {@link ReferenceCountingIoFilter} if * the filter is added at the first time.</li> 首先通过ReferenceCountingIoFilter调用init方法 * <li>{@link #onPreAdd(IoFilterChain, String, NextFilter)} is invoked to notify * that the filter will be added to the chain.</li> 然后#onPreAdd方法将会被调用,用于通知过滤器将要被添加到过滤链上 * <li>The filter is added to the chain, and all events and I/O requests * pass through the filter from now.</li> 过滤器添加到过滤链上,所有IoHandler事件和IO请求,将会被过滤器拦截 * <li>{@link #onPostAdd(IoFilterChain, String, NextFilter)} is invoked to notify * that the filter is added to the chain.</li> 在调用#onPostAdd,用于通知过滤器已经添加到过滤连上 * <li>The filter is removed from the chain if {@link #onPostAdd(IoFilterChain, String, org.apache.mina.common.IoFilter.NextFilter)} * threw an exception. {@link #destroy()} is also invoked by * {@link ReferenceCountingIoFilter} if the filter is the last filter which * was added to {@link IoFilterChain}s.</li> 如果#onPostAdd方法抛出异常,过滤器将会从过滤链上移除。如果过滤器在过滤链的链尾, ReferenceCountingIoFilter将调用#destroy方法释放共享资源 * [/list] * <p> * When you remove an {@link IoFilter} from an {@link IoFilterChain}: 当从过滤链上移除一个过滤器时: * [list=1] * <li>{@link #onPreRemove(IoFilterChain, String, NextFilter)} is invoked to * notify that the filter will be removed from the chain.</li> #onPreRemove被调用,用于通知过滤器将从过滤链上移除 * <li>The filter is removed from the chain, and any events and I/O requests * don't pass through the filter from now.</li> 如果过滤器从过滤链上移除,所有IoHandler事件和IO请求,过滤器不再拦截 * <li>{@link #onPostRemove(IoFilterChain, String, NextFilter)} is invoked to * notify that the filter is removed from the chain.</li> #onPostRemove调用通知过滤器已经从过滤链上移除 * <li>{@link #destroy()} is invoked by {@link ReferenceCountingIoFilter} if * the removed filter was the last one.</li> #如果过滤器在过滤链的链尾,ReferenceCountingIoFilter将调用#destroy方法释放共享资源 * [/list] * * @author The Apache Directory Project (mina-dev@directory.apache.org) * @version $Rev$, $Date$ * * @see IoFilterAdapter */ public interface IoFilter { /** * Invoked by {@link ReferenceCountingIoFilter} when this filter * is added to a {@link IoFilterChain} at the first time, so you can * initialize shared resources. Please note that this method is never * called if you don't wrap a filter with {@link ReferenceCountingIoFilter}. IoFilter添加到过滤链时,最好以ReferenceCountingIoFilter包装,添加到过滤链,init方法 在添加到过滤链时,由ReferenceCountingIoFilter第一次调用,所以可以在init方法初始化一些共享资源。 如果过滤器没有包装成ReferenceCountingIoFilter,init方法将不会调用。 */ void init() throws Exception; /** * Invoked by {@link ReferenceCountingIoFilter} when this filter * is not used by any {@link IoFilterChain} anymore, so you can destroy * shared resources. Please note that this method is never called if * you don't wrap a filter with {@link ReferenceCountingIoFilter}. 当过滤器不再被过滤链使用时,ReferenceCountingIoFilter调用destroy方法使用共享资源。 如果过滤器没有包装成ReferenceCountingIoFilter,destroy方法将不会调用。 */ void destroy() throws Exception; /** * Invoked before this filter is added to the specified <tt>parent</tt>. * Please note that this method can be invoked more than once if * this filter is added to more than one parents. This method is not * invoked before {@link #init()} is invoked. *当过滤器添加到过滤链时,调用此方法,如果过滤器添加到多个过滤链,此方法可以多次调用。 此方法不会在init方法前调用。 * @param parent the parent who called this method * @param name the name assigned to this filter * @param nextFilter the {@link NextFilter} for this filter. You can reuse * this object until this filter is removed from the chain. */ void onPreAdd(IoFilterChain parent, String name, NextFilter nextFilter) throws Exception; /** * Invoked after this filter is added to the specified <tt>parent</tt>. * Please note that this method can be invoked more than once if * this filter is added to more than one parents. This method is not * invoked before {@link #init()} is invoked. *当过滤器添加到过滤链后,调用此方法,如果过滤器添加到多个过滤链,此方法可以多次调用。 此方法不会在init方法前调用。 * @param parent the parent who called this method * @param name the name assigned to this filter * @param nextFilter the {@link NextFilter} for this filter. You can reuse * this object until this filter is removed from the chain. */ void onPostAdd(IoFilterChain parent, String name, NextFilter nextFilter) throws Exception; /** * Invoked before this filter is removed from the specified <tt>parent</tt>. * Please note that this method can be invoked more than once if * this filter is removed from more than one parents. * This method is always invoked before {@link #destroy()} is invoked. * 当过滤器从过滤链移除前,调用此方法,如果从多个过滤链移除,此方法可以多次调用。 此方法在#destroy方法前调用 * @param parent the parent who called this method * @param name the name assigned to this filter * @param nextFilter the {@link NextFilter} for this filter. You can reuse * this object until this filter is removed from the chain. */ void onPreRemove(IoFilterChain parent, String name, NextFilter nextFilter) throws Exception; /** * Invoked after this filter is removed from the specified <tt>parent</tt>. * Please note that this method can be invoked more than once if * this filter is removed from more than one parents. * This method is always invoked before {@link #destroy()} is invoked. * 当过滤器从过滤链移除后,调用此方法,如果从多个过滤链移除,此方法可以多次调用。 此方法在#destroy方法前调用。 * @param parent the parent who called this method * @param name the name assigned to this filter * @param nextFilter the {@link NextFilter} for this filter. You can reuse * this object until this filter is removed from the chain. */ void onPostRemove(IoFilterChain parent, String name, NextFilter nextFilter) throws Exception; /** * Filters {@link IoHandler#sessionCreated(IoSession)} event. 过滤IoHandler#sessionCreated事件 */ void sessionCreated(NextFilter nextFilter, IoSession session) throws Exception; /** * Filters {@link IoHandler#sessionOpened(IoSession)} event. 过滤IoHandler#sessionOpened事件 */ void sessionOpened(NextFilter nextFilter, IoSession session) throws Exception; /** * Filters {@link IoHandler#sessionClosed(IoSession)} event. 过滤IoHandler#sessionClosed事件 */ void sessionClosed(NextFilter nextFilter, IoSession session) throws Exception; /** * Filters {@link IoHandler#sessionIdle(IoSession,IdleStatus)} * event. 过滤IoHandler#sessionIdle事件 */ void sessionIdle(NextFilter nextFilter, IoSession session, IdleStatus status) throws Exception; /** * Filters {@link IoHandler#exceptionCaught(IoSession,Throwable)} * event. 过滤IoHandler#exceptionCaught事件 */ void exceptionCaught(NextFilter nextFilter, IoSession session, Throwable cause) throws Exception; /** * Filters {@link IoHandler#messageReceived(IoSession,Object)} * event. 过滤IoHandler#messageReceived事件 */ void messageReceived(NextFilter nextFilter, IoSession session, Object message) throws Exception; /** * Filters {@link IoHandler#messageSent(IoSession,Object)} * event. 过滤IoHandler#messageSent事件 */ void messageSent(NextFilter nextFilter, IoSession session, Object message) throws Exception; /** * Filters {@link IoSession#close()} method invocation. 过滤IoSession#close事件 */ void filterClose(NextFilter nextFilter, IoSession session) throws Exception; /** * Filters {@link IoSession#write(Object)} method invocation. 过滤IoSession#write事件 */ void filterWrite(NextFilter nextFilter, IoSession session, WriteRequest writeRequest) throws Exception; /** * Represents the next {@link IoFilter} in {@link IoFilterChain}. 过滤器在过滤链中的后继,转发IoHandler的会话相关事件(创建,打开,空闲,异常,关闭,接受数据,发送数据) 及IoSesssion的Write与close事件。 */ public interface NextFilter { /** * Forwards <tt>sessionCreated</tt> event to next filter. */ void sessionCreated(IoSession session); /** * Forwards <tt>sessionOpened</tt> event to next filter. */ void sessionOpened(IoSession session); /** * Forwards <tt>sessionClosed</tt> event to next filter. */ void sessionClosed(IoSession session); /** * Forwards <tt>sessionIdle</tt> event to next filter. */ void sessionIdle(IoSession session, IdleStatus status); /** * Forwards <tt>exceptionCaught</tt> event to next filter. */ void exceptionCaught(IoSession session, Throwable cause); /** * Forwards <tt>messageReceived</tt> event to next filter. */ void messageReceived(IoSession session, Object message); /** * Forwards <tt>messageSent</tt> event to next filter. */ void messageSent(IoSession session, Object message); /** * Forwards <tt>filterWrite</tt> event to next filter. */ void filterWrite(IoSession session, WriteRequest writeRequest); /** * Forwards <tt>filterClose</tt> event to next filter. */ void filterClose(IoSession session); } /** * Represents write request fired by {@link IoSession#write(Object)}. 表示一个会话写请求IoSession#write */ public static class WriteRequest { //写请求返回值WriteFuture private static final WriteFuture UNUSED_FUTURE = new WriteFuture() { public boolean isWritten() { return false; } public void setWritten(boolean written) { } //获取关联会话 public IoSession getSession() { return null; } public Object getLock() { return this; } public void join() { } public boolean join(long timeoutInMillis) { return true; } public boolean isReady() { return true; } public void addListener(IoFutureListener listener) { throw new IllegalStateException( "You can't add a listener to a dummy future."); } public void removeListener(IoFutureListener listener) { throw new IllegalStateException( "You can't add a listener to a dummy future."); } }; private final Object message;//发送消息 private final WriteFuture future;//写操作返回Future private final SocketAddress destination;//socket目的地址 /** * Creates a new instance without {@link WriteFuture}. You'll get * an instance of {@link WriteFuture} even if you called this constructor * because {@link #getFuture()} will return a bogus future. */ public WriteRequest(Object message) { this(message, null, null); } /** * Creates a new instance with {@link WriteFuture}. */ public WriteRequest(Object message, WriteFuture future) { this(message, future, null); } /** * Creates a new instance. * 根据消息,WriteFuture,消息socket目的地址构建WriteRequest * @param message a message to write * @param future a future that needs to be notified when an operation is finished * @param destination the destination of the message. This property will be * ignored unless the transport supports it. */ public WriteRequest(Object message, WriteFuture future, SocketAddress destination) { if (message == null) { throw new NullPointerException("message"); } if (future == null) { future = UNUSED_FUTURE; } this.message = message; this.future = future; this.destination = destination; } /** * Returns {@link WriteFuture} that is associated with this write request. */ public WriteFuture getFuture() { return future; } /** * Returns a message object to be written. */ public Object getMessage() { return message; } /** * Returne the destination of this write request. * * @return <tt>null</tt> for the default destination */ public SocketAddress getDestination() { return destination; } public String toString() { return message.toString(); } } }
总结:
IoFilter添加到过滤链时,一般以ReferenceCountingIoFilter包装,添加到过滤链,init方法在添加到过滤链时,由ReferenceCountingIoFilter调用,所以可以在init方法初始化一些共享资源。如果过滤器没有包装成ReferenceCountingIoFilter,init方法将不会调用。然后调用onPreAdd通知过滤器将会添加到过滤连上,当过滤器添加到过滤链上时,所有IoHandler事件和IO请求,将会被过滤器拦截当过滤器添加到过滤链上后,将会调用onPostAdd,如果方法有异常,过滤器在过滤链的链尾,ReferenceCountingIoFilter将调用#destroy方法释放共享资源。过滤器IoFilter,主要是监听会话IoSession相关事件(创建,打开,空闲,异常,关闭,接受数据,发送数据) 及IoSesssion的Write与close事件;过滤器后继NextFilter关注的事件与过滤器IoFilter相同,主要是转发相关事件。WriteRequest是会话IoSession写操作write的包装,内部有一个消息对象用于存放write的内容,一个socket地址,即会话写请求的目的socket地址,一个写请求结果返回值WriteFuture,用于获取会话write消息的操作结果。当一个过滤器从过滤链上移除时,#onPreRemove被调用,用于通知过滤器将从过滤链上移除;如果过滤器从过滤链上移除,所有IoHandler事件和IO请求,过滤器不再拦截;#onPostRemove调用通知过滤器已经从过滤链上移除;移除后,如果过滤器在过滤链的链尾,ReferenceCountingIoFilter将调用#destroy方法释放共享资源。
IoFilter生命周期如下:
inti->onPreAdd->onPostAdd->(拦截IoHandler相关事件:sessionCreated,Opened,Idle,
exceptionCaught,Closed,messageSent,messageReceived;会话相关事件:filterWrite,filterClose)->onPreRemove
->onPostRemove->destroy。
附:
//IoFilterAdapter,过滤器适配器
/** * An abstract adapter class for {@link IoFilter}. You can extend * this class and selectively override required event filter methods only. All * methods forwards events to the next filter by default. * IoFilterAdapter为过滤器的抽象实现。在实现自己的过滤器时,可以扩展IoFilterAdapter, 选择需要关注的时间,默认所有事件方法将会转发事件到后继过滤器。 * @author The Apache Directory Project (mina-dev@directory.apache.org) * @version $Rev$, $Date$ */ public class IoFilterAdapter implements IoFilter { public void init() throws Exception { } public void destroy() throws Exception { } public void onPreAdd(IoFilterChain parent, String name, NextFilter nextFilter) throws Exception { } public void onPostAdd(IoFilterChain parent, String name, NextFilter nextFilter) throws Exception { } public void onPreRemove(IoFilterChain parent, String name, NextFilter nextFilter) throws Exception { } public void onPostRemove(IoFilterChain parent, String name, NextFilter nextFilter) throws Exception { } //默认实现为,将事件转发到后继过滤器 public void sessionCreated(NextFilter nextFilter, IoSession session) throws Exception { nextFilter.sessionCreated(session); } public void sessionOpened(NextFilter nextFilter, IoSession session) throws Exception { nextFilter.sessionOpened(session); } public void sessionClosed(NextFilter nextFilter, IoSession session) throws Exception { nextFilter.sessionClosed(session); } public void sessionIdle(NextFilter nextFilter, IoSession session, IdleStatus status) throws Exception { nextFilter.sessionIdle(session, status); } public void exceptionCaught(NextFilter nextFilter, IoSession session, Throwable cause) throws Exception { nextFilter.exceptionCaught(session, cause); } public void messageReceived(NextFilter nextFilter, IoSession session, Object message) throws Exception { nextFilter.messageReceived(session, message); } public void messageSent(NextFilter nextFilter, IoSession session, Object message) throws Exception { nextFilter.messageSent(session, message); } public void filterWrite(NextFilter nextFilter, IoSession session, WriteRequest writeRequest) throws Exception { nextFilter.filterWrite(session, writeRequest); } public void filterClose(NextFilter nextFilter, IoSession session) throws Exception { nextFilter.filterClose(session); } }
IoFuture:异步IO操作结果
package org.apache.mina.common; /** * Represents the result of an ashynchronous I/O operation. * IoFuture表示一个异步操作的结果 * @author The Apache Directory Project (mina-dev@directory.apache.org) * @version $Rev$, $Date$ */ public interface IoFuture { /** * Returns the {@link IoSession} which is associated with this future. 获取结果关联的会话 */ IoSession getSession(); /** * Returns the lock object this future acquires. */ Object getLock(); /** * Wait for the asynchronous operation to end. 等待异步IO操作结束 */ void join(); /** * Wait for the asynchronous operation to end with the specified timeout. * 超时等待异步IO操作完成 * @return <tt>true</tt> if the operation is finished. */ boolean join(long timeoutInMillis); /** * Returns if the asynchronous operation is finished. 判断一个异步操作是否完成 */ boolean isReady(); /** * Adds an event <tt>listener</tt> which is notified when * the state of this future changes. 添加结果监听器,用于监听结果状态的变化 */ void addListener(IoFutureListener listener); /** * Removes an existing event <tt>listener</tt> which is notified when * the state of this future changes. 移除结果监听器 */ void removeListener(IoFutureListener listener); }
WriteFuture:异步写操作结果
package org.apache.mina.common; /** * An {@link IoFuture} for asynchronous write requests. *WriteFuture表示一个异步写请求 * <h3>Example</h3>,示例: * <pre> * IoSession session = ...; * WriteFuture future = session.write(...); * // Wait until the message is completely written out to the O/S buffer. * future.join();//等待写操作完成 * if( future.isWritten() ) * { * // The message has been written successfully.写操作完成 * } * else * { * // The messsage couldn't be written out completely for some reason. * // (e.g. Connection is closed) 写操作没有完成 * } * </pre> * * @author The Apache Directory Project (mina-dev@directory.apache.org) * @version $Rev$, $Date$ */ public interface WriteFuture extends IoFuture { /** * Returns <tt>true</tt> if the write operation is finished successfully. 判断写操作是否完成 */ boolean isWritten(); /** * Sets whether the message is written or not, and notifies all threads * waiting for this future. This method is invoked by MINA internally. * Please do not call this method directly. 设置消息是否被写,并通知所有等待此结果的线程。这个方法为MINA内部调用。 不要直接调用这个方法。 */ void setWritten(boolean written); }
发表评论
-
Mina 报文连接器(NioDatagramConnector)
2017-06-14 08:46 1416Mina 抽象Polling连接器(A ... -
Mina 报文监听器NioDatagramAcceptor二(发送会话消息等)
2017-06-13 16:01 1541Mina 报文监听器NioDatagramAcceptor一( ... -
Mina 报文监听器NioDatagramAcceptor一(初始化,Io处理器)
2017-06-13 09:51 2574Mina Io监听器接口定义及抽象实现:http://dona ... -
Mina 报文通信简单示例
2017-06-12 09:01 2584MINA TCP简单通信实例:http://donald-dr ... -
Mina socket连接器(NioSocketConnector)
2017-06-12 08:37 4772Mina 抽象Polling连接器(AbstractPolli ... -
Mina 抽象Polling连接器(AbstractPollingIoConnector)
2017-06-11 21:29 1008Mina 连接器接口定义及抽象实现(IoConnector ) ... -
Mina 连接器接口定义及抽象实现(IoConnector )
2017-06-11 13:46 1831Mina IoService接口定义及抽象实现:http:// ... -
Mina socket监听器(NioSocketAcceptor)
2017-06-09 08:44 3418Mina IoService接口定义及抽象实现:http:// ... -
Mina 抽象polling监听器
2017-06-08 22:32 783Mina Io监听器接口定义及抽象实现:http://dona ... -
Mina Io监听器接口定义及抽象实现
2017-06-07 13:02 1349Mina IoService接口定义及抽象实现:http:// ... -
Mina IoService接口定义及抽象实现
2017-06-06 23:44 1195Mina IoHandler接口定义:http://donal ... -
Mina Nio会话(Socket,DataGram)
2017-06-06 12:53 1209Mina Socket会话配置:http://donald-d ... -
Mina 抽象Io会话
2017-06-05 22:45 1014Mina Io会话接口定义:http://donald-dra ... -
Mina Io会话接口定义
2017-06-04 23:15 1166Mina Nio处理器:http://donald-drape ... -
Mina Nio处理器
2017-06-04 22:19 742Mina Io处理器抽象实现:http://donald-dr ... -
Mina Io处理器抽象实现
2017-06-03 23:52 1148Mina 过滤链抽象实现:http://donald-drap ... -
Mina IoHandler接口定义
2017-06-01 21:30 1733Mina 过滤链抽象实现:http://donald-drap ... -
MINA 多路复用协议编解码器工厂二(多路复用协议解码器)
2017-06-01 12:52 2273MINA 多路复用协议编解码器工厂一(多路复用协议编码器): ... -
MINA 多路复用协议编解码器工厂一(多路复用协议编码器)
2017-05-31 22:22 1867MINA 多路分离解码器实例:http://donald-dr ... -
Mina 累计协议解码器
2017-05-31 00:09 1229MINA 编解码器实例:http://donald-drape ...
相关推荐
1. **Filter Chain**:Mina的核心设计模式之一是过滤器链。每个连接都有一系列过滤器,它们按照顺序处理入站和出站事件。过滤器可以实现特定功能,如数据编码解码、安全验证、性能监控等。 2. **Session**:Session...
MINA的编码器和解编码器遵循了Filter设计模式,每个解编码器都是一个过滤器,可以在数据传递过程中进行拦截和处理。 3. **自定义解编码器的实现** 自定义解编码器需要继承MINA提供的AbstractDecoder类或其子类,并...
首先,我们需要将图片文件读取到内存中的IoBuffer,然后通过过滤器链传递给远程客户端。在这个过程中,可以实现数据压缩、加密等额外功能。同时,Mina提供了进度反馈机制,可以实时监控文件传输进度,确保传输的可靠...
在Spring中整合Mina,首先需要在Spring配置文件中声明Mina的相关bean,如Acceptor、ProtocolCodecFactory(编码解码工厂)和FilterChainBuilder(过滤器链构建器)。通过Spring的依赖注入,我们可以轻松地管理这些...
4. **过滤器链**:MINA引入了过滤器的概念,数据在传输过程中会经过一系列过滤器,每个过滤器可以执行特定的操作,如编码、解码、日志记录等。这种设计使得模块化和复用变得简单。 5. **多线程支持**:MINA支持多...
3. 理解Mina的过滤器机制,以及如何编写自定义过滤器。 4. 实践数据编码和解码的过程,理解ProtocolCodec的使用。 5. 掌握事件驱动编程模型,理解IoHandler中的各个事件回调方法。 这个Demo是学习Mina网络通信开发...
Mina的强大之处在于你可以轻松地定义自己的协议格式,只需要创建相应的过滤器来解析和生成数据。 **5. 扩展性与灵活性** - **适应多协议**:由于Mina的过滤器链设计,你可以很容易地添加新的过滤器以支持其他协议...
开发者可以定义多个过滤器,每个过滤器可以执行特定的操作,如数据编码、解码或安全检查。过滤器链的概念使得我们可以按顺序处理数据,增强了代码的可扩展性。 3. **ProtocolHandler**:协议处理器是处理特定协议的...
- **创建过滤器链**:Mina的过滤器机制允许我们在数据传输过程中进行预处理或后处理,比如编码解码、安全检查等。 - **定义业务处理器**:实现具体的业务逻辑,处理客户端发来的消息。 **4. 配置Spring Boot** 在...
Mina框架主要由两个核心模块组成:mina-core负责基本的网络I/O操作,而mina-filter则包含了一系列预定义的过滤器,如日志记录、压缩、加密等。开发者可以根据需要选择或组合使用这些过滤器,以增强应用的功能。 ...
这使得配置和管理MINA服务变得更加灵活和方便,通过XML配置文件就可以定义和连接MINA的服务器、过滤器、处理器等组件。 在提供的压缩文件中,有两个名为"MinaClient.rar"和"mina.rar"的子文件。MinaClient.rar可能...
过滤器是 Mina 的核心概念,它们定义了数据在网络层传输前后的处理逻辑。在源代码中,你可能会看到自定义的 Filter 类,它们用于数据编码、解码、认证、加密等任务。过滤器链的执行遵循“责任链模式”,数据在每个...
通过编写一个简单的示例,你可以更好地了解如何设置项目、创建服务端和客户端、定义过滤器以及处理网络事件。同时,不要忘记考虑异常处理和性能优化,这些在实际项目中都是至关重要的。在实践中不断探索和调试,将有...
6. **过滤器链**:Mina的过滤器机制允许我们在数据传输过程中插入自定义逻辑,例如认证、日志记录、性能监控等。在服务器和客户端的管道中添加适当的过滤器。 7. **调用服务**:客户端通过发送包含方法名和参数的...
Apache MINA的核心概念包括事件驱动、非阻塞I/O和过滤器链。非阻塞I/O允许在单个线程中处理多个连接,提高了服务器的并发处理能力。事件驱动模式使得MINA可以高效地响应网络事件,如连接建立、数据读取和写入等。...
- **构建FilterChain**:这是MINA的一个重要特性,它允许我们定义一系列过滤器,对输入/输出数据进行处理。例如,我们可以创建一个LoggingFilter记录网络交互,或者自定义过滤器实现特定业务逻辑。 - **创建...
5. **处理事件**:在过滤器中定义对各种事件(如连接建立、数据到达、连接关闭)的响应。 6. **编码与解码**:使用MINA提供的工具或自定义编码器和解码器处理网络数据。 7. **部署与测试**:完成代码编写后,部署...
2. **Filter**:过滤器是Mina框架中的核心概念,它们按照特定顺序链接在一起,形成一个过滤器链。每个过滤器都可以对数据进行处理,如编码解码、压缩解压缩、安全加密等,也可以实现业务逻辑。 3. **...
- 过滤器:定义附加功能的过滤器类。 - 对象类:需要传输的自定义Java对象,可能包含序列化和反序列化相关的注解。 - 测试代码:用于验证传输和接收数据的正确性。 总的来说,Apache Mina提供了强大的工具,帮助...
2. **Filter Chain**: 过滤器链是Mina的一大特色,它允许开发者插入自定义的过滤器,对数据进行处理或拦截。过滤器可以实现如协议解析、数据加密解密、日志记录等功能。 3. **Protocol Codec**: 编解码器负责将应用...