Mina 长连接实践

- Mina介绍

最近项目需要使用长连接,而Mina应该是个不错的选择。个人在Mina的长连接的集成过程中碰到一些问题解决,现在和大家探讨下。言归正传,要使用Mina首先需要看看Mina的官网,特别是他的开发文档需要阅读下(http://mina.apache.org/mina-project/documentation.html)。个人觉得以下二张图是比重要的(来自于http://mina.apache.org/mina-project/resources/ACAsia2006.pdf)。

官网流程图

从上张图可以看出Mina的客户端有三个比较重要的类,一个是IoSession, 客户端和服务器端建立连接后会返回ConnectFuture,里面就包含这个类,IoHandler是建立连接后的回调接口。第二个是IoFilterChain,在与服务器建立连接前,可以将IoFilterChain的实现注入到IoFilterChainBuilder。因为所有I/O请求和Event都会经过filter,可以通过IoFilterChain进行操作,比如LoggingFilter用来打印所有请求,KeepAliveFilter 用来对服务器发送心跳请求,当然你也可以自定义IoFilterChain进行特需的操作,这个实现个人觉得可以参考OkHttp的源码。最后一个就是IOService,客户端与服务端的通讯都是通过它进行的,对客户端而言,可以通过实现new NioSocketConnector()新建一个IoService:

这里写图片描述

第二个比较重要的图就是:
官网IoService实现
从上图可以看出,服务器端也是通过IoService与客户端进行通讯的(有点像Java的里面的RMI Stub/Skeleton)。针对该IoService,服务器端有相应的TCP, UDP, SOCKET实现(关于VmPipe我不是很了解,知道的同学可以留言),客户端亦然。服务器端代码如下:

服务器端示例代码

从示例代码可以看出,实现和Server socket很相似,只是对其做了二次封装而已。基本介绍完毕,下面我来看看具体的实现。

Mina服务器端实现

首先服务器端,你可以上Mina的官网,下载二个jar包(mina-core-2.0.16+slf4j-api-1.7.21), 示例代码如下:

        ioAcceptor = new NioSocketAcceptor();
        ioAcceptor.getFilterChain().addLast("logger", new LoggingFilter());
        ioAcceptor.getFilterChain().addLast("codec", new ProtocolCodecFilter(new      ObjectSerializationCodecFactory()));
        ioAcceptor.setHandler(new ConnectionHandler());
        ioAcceptor.getSessionConfig().setReadBufferSize(connectionConfig.getBufferSize());
        ioAcceptor.getSessionConfig().setIdleTime(IdleStatus.BOTH_IDLE, connectionConfig.getIdleTime());
        try {
            ioAcceptor.bind(new InetSocketAddress(connectionConfig.getPort()));
        } catch (IOException e) {
            e.printStackTrace()
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值