Apache Mina开发手冊之四
Apache Mina开发手冊之四
作者:chszs,转载需注明。
博客主页:http://blog.csdn.net/chszs
一、Mina开发的主要步骤
1、创建一个实现了IoService接口的类
IoService接口有两个子接口:
1)IoAcceptor接口,用于server
2)IoConnection接口,用于client
IoService接口的目的是提供服务。有几个默认实现:
NioDatagramAcceptor、NioDatagramConnector
NioSocketAcceptor、NioSocketConnector
VmPipeAcceptor、VmPipeConnector
ProxyConnector
2、设置一个过滤器。假设须要自己定义过滤器,那么此过滤器须要实现了IoFilter接口
IoFilter作用是建立一层过滤网。作用与Servlet规范中的过滤器一样。
IoFilter接口的默认实现比較多,有些仅供内部使用。有些供用户使用,并且过滤器的顺序能够影响程序的执行。
经常使用的实现类包含:
1)ExecutorFilter:从此过滤器后的不论什么操作都工作于这个Executor
2)LoggingFilter:日志操作过滤器,记录日志用的
3)ProtocolCodecFilter:实现协议层和业务层的分离。
4)ProxyFilter:代理过滤器,拦截请求或响应,转发给代理。
5)SslFilter:用于SSL通信
3、创建一个实现了IoHandler接口的处理类,用于处理事件
处理业务逻辑,尤其要注意里面的IoSession接口。
4、对IoService绑定一个port開始工作
二、Mina自己定义协议
Mina中的样例:
org.apache.mina.example.chat:支持Spring、Jmx、自己定义协议
org.apache.mina.example.imagine:支持Jmx、自己定义协议
org.apache.mina.example.sumup:支持自己定义协议
org.apache.mina.example.tapedeck:状态机的示范、自己定义协议
三、协议解码器
协议解码器是依赖于ProtocolDecoder接口:
public interface ProtocolDecoder{
// 把二进制协议或特定协议的内容解码成高级消息
void decode(IoSession session, IoBuffer in, ProtocolDecoderOutput out);
// 当指定的会话关闭时调用此方法
void finishDecode(IoSession session, ProtocolDecoderOutput out);
// 释放此解码器相关的全部资源
void dispose(IoSession session) throws Exception;
}
由于异步的原因,传过来的IoBuffer所接受的内容是不全然确定的,也即IoBuffer中对于一次receive后。存放的不一定是一个完整的协议。有可能是多个不完整的协议。也可能刚好是一个完整的协议。这些都不确定。
基于以上情况,实际开发通常是实现CumulativeProtocolDecoder类,此抽象类的作用是为解析协议提供一些帮助,此抽象类实现了ProtocolDecoder接口中的decode接口。并抽象出一个doDecode方法。
doDecode方法要求假设能解析一个协议,则把此协议解析后放入ProtocolDecoderOutput类,并返回true。反之则直接返回false。并须要手动回滚POS。
协议解码器类有两种工作方式:
1)全然交由doDecode处理
2)逻辑部分交由doDecode方法处理。IoBuffer是半自己主动的
四、协议编码器
协议编码器依赖于ProtocolEncoder接口。
public interface ProtocolEncoder{
// 把高级消息对象编码成二进制或特定协议的数据
void encode(IoSession session, Object message, ProtocolEncoderOutput out);
// 释放此协议编码器相关的全部资源
void dispose(IoSession session) throws Exception;
}
协议编码器能够做到全自己主动,由于能够一次性把所需的内容写入IoBuffer,并交给ProtocolEncoderOutput,后台会依据缓冲区的大小。能写入多少就写入多少,直到把ProtocolEncoderOutput中须要发送的协议全部发送完。
Apache Mina开发手冊之四的更多相关文章
- Apache Shiro 使用手冊 链接文件夹整理
1.Apache Shiro 使用手冊(一)Shiro架构介绍 2.Apache Shiro 使用手冊(二)Shiro 认证 3.Apache Shiro 使用手冊(三)Shiro 授权 4.Apac ...
- HapiJS开发手冊
HapiJS开发手冊 作者:chszs.转载需注明.博客主页:http://blog.csdn.net/chszs 一.HapiJS介绍 HapiJS是一个开源的.基于Node.js的应用框架,它适用 ...
- 阿里Java开发手冊之编程规约
对于程序猿来说,编程规范能够养成良好的编程习惯,提高代码质量,减少沟通成本.就在2月9号,阿里出了一份Java开发手冊(正式版),分为编程规约.异常日志.MySQL规约,project规约.安全规约五 ...
- 谷歌Web中文开发手冊:3响应式
https://developers.google.com/web/fundamentals/getting-started/your-first-multi-screen-site/responsi ...
- CAS 4.0 配置开发手冊
1 下载 地址http://downloads.jasig.org/ cas-server-4.0.0-release.tar.gz cas-client-3.3.3-release.tar.g ...
- Java开发手冊 Java学习手冊教程(MtJava开发手冊)
本文档的版权归MtJava文档小组全部,本文档及其描写叙述的内容受有关法律的版权保护,对本文档内容的不论什么形式的非法复制.泄露或散布.将导致对应的法律责任. MtJava仅仅是一个学习Java的简化 ...
- OBIEE开发手冊
Creating a Repository Using the Oracle BI 11g Administration Tool cid=5690&ssid=0">http: ...
- Apache MiNa 实现多人聊天室
Apache MiNa 实现多人聊天室 开发环境: System:Windows JavaSDK:1.6 IDE:eclipse.MyEclipse 6.6 开发依赖库: Jdk1.4+.mina-c ...
- Nginx中文手冊
下载 : Nginx 中文手冊 Nginx 常见应用技术指南[Nginx Tips] 第二版 作者:NetSeek http://www.linuxtone.org (IT运维专家网|集群架构|性能调 ...
随机推荐
- mini-httpd源码分析-tdate_parse.h
///关联字符串和整数 struct strlong { char* s; long l; }; ///将字符串中的大写字母转换成小写字母 static void pound_case(char* s ...
- the C programming language 阅读笔记1
读了一遍著名的<the C programming language>,果然如听说的一样,讲解基础透彻,案例简单典型,确实自己C语言还有很多细节点不是很清楚. 总结一下阅读的收获(部分原书 ...
- Nginx和Nginx+的比较(上)
Nginx和Nginx+的比较(上) 作者:chszs,未经博主允许不得转载.经许可的转载需注明作者和博客主页:http://blog.csdn.net/chszs 一.Nginx+介绍 Nginx和 ...
- DbConnectionFactory 数据库连接
/** * */package com.sprucetec.dbatch.tmsfee;import java.io.Serializable;import java.sql.Connection;i ...
- golang仿AS3写的ByteArray
用golang写了个仿AS3写的ByteArray,稍微有点差别,demo能成功运行,还未进行其他测试 主要参考的是golang自带库里的Buffer,结合了binary 来看看demo: packa ...
- CodeForces Round #179 (295A) - Greg and Array 一个线段树做两次用
线段树的区间更新与区间求和...一颗这样的线段树用两次... 先扫描1~k...用线段树统计出每个操作执行的次数... 那么每个操作就变成了 op. l , op.r , op.c= times* ...
- 链表的实现 -- 数据结构与算法的javascript描述 第六章
链表 链表是由一组节点组成的集合.每个节点都使用一个对象的引用指向它的后继.指向另一个节点的引用叫做链 结构示意图 : 链表头需要我们标识 head { element:head,next:obj1 ...
- vlan trunk vtp端口聚合
第一步:端口聚合(两端都需要做相同的操作) 第二步:在服务器端配置为服务器模式 第四步:在服务器端添加vlan 第五步:在两端分别将不同的端口添加到不同的vlan
- English - allow to do 与 allow doing 的区别
英语中并没有allow to do sth这种结构,只有allow doing sth 及allow sb to do sth这两个结构. 你这样记忆可能方便一些: 1. 在主动语态中,如果allow ...
- hbase 单机安装问题
报zookeeper exception not found I fixed this by editing the file "/usr/local/hbase-0.94.1/conf/h ...