• 统计当前在线人数


    当一个项目启动时,要统计当前在线人数,那么我们可以统计一个当前有几个session登录,增加一个session,表明已经有新浏览器访问该网站。实现

    HttpSessionListener, HttpSessionAttributeListener,覆盖其方法。
    public class UsersListener implements HttpSessionListener, HttpSessionAttributeListener {
        
        private ServletContext sc;
        //使用一个变量,进行统计
        private int count = 0;
        
        @Override
        public void sessionCreated(HttpSessionEvent event) {
            
            if( sc == null)
                sc = event.getSession().getServletContext();
            
            sc.setAttribute(Constants.SESSION_COUNT, count);
        }
    
        @Override
        public void sessionDestroyed(HttpSessionEvent event) {
            Enumeration<String> names = event.getSession().getAttributeNames();
            int line = 0;
            while(names.hasMoreElements()) {
                String name = names.nextElement();
                //统计剩余几个用户
    if(name.equalsIgnoreCase(Constants.FRONT_USER_SESSION)) {
                    line ++;
                }
            }
            if(line > 0) {
                count = line;
            }
            if(sc != null)
                sc.setAttribute(Constants.SESSION_COUNT, count);
        }
            //新增session
        @Override
        public void attributeAdded(HttpSessionBindingEvent event) {
            String name = event.getName();
            if(name.equalsIgnoreCase(Constants.FRONT_USER_SESSION))
                count ++;
            sc.setAttribute(Constants.SESSION_COUNT, count);
        }
    
        @Override
        public void attributeRemoved(HttpSessionBindingEvent event) {
            String name = event.getName();
            if(count > 0 && name.equalsIgnoreCase(Constants.FRONT_USER_SESSION))
                count --;
            sc.setAttribute(Constants.SESSION_COUNT, count);
        }
    
        @Override
        public void attributeReplaced(HttpSessionBindingEvent event) {
            
        }
        
    }
    工作小总结,有错请指出,谢谢。
  • 相关阅读:
    ThreadPoolExecutor的重要参数
    分布式系统中一致性哈希算法
    监测工具dstat
    luamysql 安装
    修改linux下系统资源限制
    linux系统资源监视工具TOP
    /etc/security/limits.conf
    lua连接mysql数据库
    query cache 的内存使用和调优
    redhat5 和redhat6 root用户不同的ulimits
  • 原文地址:https://www.cnblogs.com/zilanghuo/p/5201344.html
Copyright © 2020-2023  润新知