设为首页 收藏本站
查看: 677|回复: 0

[经验分享] Apache Mina简单实例

[复制链接]

尚未签到

发表于 2017-1-3 12:20:28 | 显示全部楼层 |阅读模式
一.简介
MINA是一个网络应用框架,也可被称之为NIO框架库、客户端/服务器框架库、网络套接字 (socket)库,可以帮助用户开发高性能和高可扩展性的网络应用程序,支持(TCP/IP、UDP/IP协议)等。
二.工作流程
MINA处于中间层,它不关心数据是如何在底层网络进行传输,只负责接受底层数据,将数据通过过滤器过滤并装换成JAVA对象,供应用程序使用,然后在应用程序对数据做过业务处理之后,将响应值过滤且转换成底层能识别的二进制数据,提供给底层传输。总之,MINA是底层数据和应用程序交互的接口。
第一步,创建服务对象(服务端、客户端)  ----IoService接口实现
第二步,数据过滤(编解码器)           ----IoFilter接口实现
第三步,业务处理                       ----IoHandler接口实现

IoFilter是MINA的精髓,可以进行日志记录,信息过滤,编解码等操作,把数据接收发送从业务层独立出来。
IoService对NIO进行了封装,提供简介接口,来创建服务对象。
IoHandler是我们最关心的部分,负责对接收/发送数据做了业务逻辑处理
三.服务端实例
private static Logger logger = Logger.getLogger(Demo1Server.class);
private static final int PORT = 3005;
public static void main(String[] args) {
IoAcceptor acceptor = new NioSocketAcceptor();
acceptor.addListener(new ServerListener());
acceptor.getFilterChain().addLast(
"codec",
new ProtocolCodecFilter(new MyTextLineCodecFactory()));
// 设置读取数据的缓冲区大小
acceptor.getSessionConfig().setReadBufferSize(2048);
// 读写通道10秒内无操作进入空闲状态
acceptor.getSessionConfig().setIdleTime(IdleStatus.BOTH_IDLE, 10);
// 绑定逻辑处理起器
acceptor.setHandler(new Demo1ServerHandler());
// 绑定端口
try {
acceptor.bind(new InetSocketAddress(PORT));
logger.info("服务器启动成功。。。。端口为:" + PORT);
} catch (IOException e) {
logger.error("服务器启动异常。。。。", e);
e.printStackTrace();
}
}

四.客户端实例
private Logger logger = Logger.getLogger(Demo2Client.class);
private static final String HOST = "127.0.0.1";
private static final int PORT = 3005;
public static void main(String[] args) {
// 创建一个非阻塞的客户端程序
IoConnector connector = new NioSocketConnector();
// 设置连接超时时间 单位毫秒
connector.setConnectTimeout(30000);
// 添加过滤器
connector.getFilterChain().addLast(
"codec",
new ProtocolCodecFilter(new MyTextLineCodecFactory()));
// 添加业务逻辑处理类
connector.setHandler(new Demo2ClientHandler());
// 创建连接
IoSession session = null;
try {
ConnectFuture connect = connector.connect(new InetSocketAddress(
HOST, PORT));
// 等待连接创建完成
connect.awaitUninterruptibly();
// 获取session
session = connect.getSession();
session.write("我爱你,mina!!!!");
} catch (Exception e) {
System.out.println("客户端连接异常");
}
session.getCloseFuture().awaitUninterruptibly();
connector.dispose();
}

五.编解码器实例
5.1 编码器
private Logger logger = Logger.getLogger(MyTextLineCodecEncoder.class);
//字符编码类型
private Charset charset = Charset.forName("UTF-8");
@Override
public void dispose(IoSession arg0) throws Exception {
}
@Override
public void encode(IoSession arg0, Object obj, ProtocolEncoderOutput out)
throws Exception {
logger.info("开始编码...........");
IoBuffer io = IoBuffer.allocate(100).setAutoExpand(true);
CharsetEncoder ce = charset.newEncoder();
io.putString(obj.toString(), ce);
io.put((byte)'\r');
io.put((byte)'\n');
io.flip();
out.write(io);
}
5.2 解码器
private Logger logger = Logger.getLogger(MyTextLineCodecDecoder.class);
//字符编码类型
private Charset charset = Charset.forName("UTF-8");
//设置数据存放的IoBuffer大小
private IoBuffer ioBuffer = IoBuffer.allocate(1024).setAutoExpand(true);
@Override
public void decode(IoSession session, IoBuffer in, ProtocolDecoderOutput out)
throws Exception {
logger.info("开始解码...........");
while(in.hasRemaining()){
byte by = in.get();
//将数据存放到IoBuffer中
ioBuffer.put(by);
//数据解码结束标记
if(by == '\n'){
ioBuffer.flip();
byte[] b = new byte[ioBuffer.limit()];
ioBuffer.get(b);
String msg = new String(b,charset);
//重置ioBuffer
ioBuffer = IoBuffer.allocate(100).setAutoExpand(true);
out.write(msg);
}
}
}

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-323290-1-1.html 上篇帖子: apache FTPS文件上传 下篇帖子: 答复: Apache+Tomcat集群配置
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表