Mina2.0框架源码剖析(五)

简介:
前面介绍过IoSessionRecycler是负责回收不再使用的会话的接口,ExpiringSessionRecycler是其一个实现类,用于回收超时失效的会话。

private ExpiringMap<Object, IoSession> sessionMap;//待处理的会话集
private ExpiringMap<Object, IoSession>.Expirer mapExpirer;//负责具体的回收工作
sessionMap的键是由本地地址和远端地址共同组成的,值是这两个地址对应的会话。

Expirer类实现了Runnable接口,这个线程负责监控ExpiringMap,并把ExpiringMap中超过阀值的元素从ExpiringMap中移除。这个线程调用了setDaemon(true),因此是作为守护线程在后台运行。具体的处理过程如下:

复制代码
   private void processExpires() 
        {
            long timeNow = System.currentTimeMillis();//当前时间
            for (ExpiringObject o : delegate.values()) 
            {
                if (timeToLiveMillis <= 0) 
                {
                    continue;
                }
                long timeIdle = timeNow - o.getLastAccessTime();//时间差
                if (timeIdle >= timeToLiveMillis) 
                {//超时
                    delegate.remove(o.getKey());
                    for (ExpirationListener<V> listener : expirationListeners) 
                    {//呼叫监听者
                        listener.expired(o.getValue());
                    }
                }
            }
        }
复制代码
     启动/关闭超时检查线程都需要进行封锁机制,这里使用的是读写锁:

复制代码
      private final ReadWriteLock stateLock = new ReentrantReadWriteLock();

        public void startExpiring() 
        {
            stateLock.writeLock().lock();
            try 
            {
                if (!running) 
                {
                    running = true;
                    expirerThread.start();
                }
            } 
            finally 
            {
                stateLock.writeLock().unlock();
            }
        }
        public void stopExpiring() 
        {
            stateLock.writeLock().lock();
            try 
            {
                if (running) 
                {
                    running = false;
                    expirerThread.interrupt();
                }
            } 
            finally 
            {
                stateLock.writeLock().unlock();
            }
        }
复制代码
     会话超时监听者:

    private class DefaultExpirationListener implements
            ExpirationListener<IoSession> {
        public void expired(IoSession expiredSession) {
            expiredSession.close();//关闭超时的会话
        }
    }

本文转自Phinecos(洞庭散人)博客园博客,原文链接:http://www.cnblogs.com/phinecos/archive/2008/12/04/1347752.html,如需转载请自行联系原作者
目录
相关文章
|
前端开发 算法 Java
由浅入深Netty组件实战2
由浅入深Netty组件实战2
230 0
|
Java
由浅入深Netty组件实战3
由浅入深Netty组件实战3
73 0
|
缓存 安全 Java
由浅入深Netty基础知识NIO三大组件原理实战 2
由浅入深Netty基础知识NIO三大组件原理实战
86 0
|
前端开发 安全 Java
由浅入深Netty组件实战1
由浅入深Netty组件实战1
94 0
|
设计模式 监控 前端开发
第 10 章 Netty 核心源码剖析
第 10 章 Netty 核心源码剖析
142 0
|
存储 缓存 编解码
Netty源码剖析之核心组件
NioEventLoop有以下核心功能。 - 开启Selector并初始化。 - 把ServerSocketChannel注册到Selector上。 - 处理各种I/O事件,如OP_ACCEPT、OP_CONNECT、OP_READ、 OP_WRITE事件。 - 执行定时调度任务。 - 解决JDK空轮询bug。
127 0
探秘Netty5:基于Netty自己动手实现RPC框架
大厨小鲜——基于Netty自己动手实现RPC框架 钱文品 Good news everyone! ​关注他 71 人赞了该文章 今天我们要来做一道小菜,这道菜就是RPC通讯框架。
|
Java 安全 API
Netty 源码阅读入门实战(一)-介绍
1 简介 以 Netty 为底层的框架 Netty 是什么 Netty 技术和方法的特点 设计 针对多种传输类型的统一接口 - 阻塞和非阻塞 简单但更强大的线程模型 真正的无连接的数据报套接字支持 链接逻辑支持复用 易用性 大量的 Javadoc 和 代码实例 除了在 JDK 1.6 + 额外的限制。
1756 0
|
Java
Netty 源码阅读入门实战(四)-NioEventLoop
1 NioEventLoop概述 总述 2 NioEventLoop创建概述 ...
1188 0
|
Web App开发 Java
探秘Netty6:基于Netty自己动手实现Web框架
大厨小鲜——基于Netty自己动手实现Web框架 钱文品 Good news everyone! ​关注他 17 人赞了该文章 上节课我们自己动手制作了一个RPC框架,本节课我们挑战一个稍有难度的一点的任务,手动制作一个Web框架。