聊聊从web session的共享到可扩展缓存设计
先从web session的共享说起
cookies
session池化
做一个可扩展的缓存策略设计
public class RoleMenuCache implements IClearCache {
private static Map<String, RoleMenu> roleMenuCache = new HashMap<String, RoleMenu>();
...业务代码省略
}
这里主要是替换这个HashMap所以改动就比较小。


Cachemanager
public class CacheManager {
private final static Logger logger = LoggerFactory.getLogger(CacheManager.class);
private static Map<String, ICache> caches = new ConcurrentHashMap<>();
private static ICacheStrategy cacheStrategy = new DefaultCacheStategy();
private static String cacheStrategyClass;
@SuppressWarnings("unchecked")
public static synchronized <T extends ICache> T getOrCreateCache(String cacheName, Class<?> keyClass, Class<?> valueCalss) {
T cache = (T) caches.get(cacheName);
if (cache != null) {
return cache;
}
cache = (T) cacheStrategy.createCache(cacheName, keyClass, valueCalss);
caches.put(cacheName, cache);
return cache;
}
@SuppressWarnings("rawtypes")
public static synchronized void destroyCache(String cacheName) {
ICache cache = caches.remove(cacheName);
if (cache != null) {
cache.clear();
}
}
}
ICache<K,V>
ICacheStrategy
public interface ICacheStrategy {
ICache createCache(String name, Class<?> keyClass, Class<?> valueCalss);
void destroyCache(ICache cache);
}
public class DefaultCache<K, V> implements ICache<K, V> {
protected Map<K, V> map;
private String name;
private long maxCacheSize;
private long maxLifetime;
private int cacheSize = 0;
public DefaultCache(String name, long maxSize, long maxLifetime) {
this.name = name;
this.maxCacheSize = maxSize;
this.maxLifetime = maxLifetime;
map = new ConcurrentHashMap<K, V>(103);
}
@Override
public V get(Object key) {
return map.get(key);
}
@Override
public V put(K key, V value) {
return map.put(key, value);
}
@Override
public V remove(Object key) {
return map.remove(key);
}
@Override
public void putAll(Map<? extends K, ? extends V> m) {
map.putAll(m);
}
@Override
public void clear() {
if (map != null) {
map.clear();
}
}
}
对于调用方来说其实就很简单,只需要调用CacheManager即可,还是前面举的RoleMenuCache
public class RoleMenuCache implements IClearCache {
private static Map<String, RoleMenu> roleMenuCache;
static {
roleMenuCache = CacheManager.getOrCreateCache("permissionCache", String.class, RoleMenu.class);
}
...业务代码省略
}
对于老代码的改造还是比较小的,而且这样的好处是以后想换成redis的也很简单,对于业务代码就不需要再修改了。
/**
* 根据key设置map的值
*/
@Override
public V put(K key, V value) {
jedisTemp.hset(name, JSON.toJSONString(key), JSON.toJSONString(value));
return value;
}
这并没啥问题,因为对象转换成json串是正常的。问题是get的时候,我们使用的
CacheManager.getOrCreateCache("permissionCache", String.class, RoleMenu.class);
最终get方法的实现就是这样:
@Override
public V get(Object key) {
String json = jedisTemp.hget(name, JSON.toJSONString(key));
return (V) JSON.parseObject(json, valueClass);
}
问题虽然是解决了,只不过总觉得怪怪的。
聊聊从web session的共享到可扩展缓存设计的更多相关文章
- session和cookie区别,多台WEB服务器如何共享session,禁用COOKIE后SESSION是否可用,为什么?
答:session的运行机制: 用户A访问站点Y,如果站点Y指定了session_start();(以下假设session_start()总是存在)那么会产生一个session_id,这个sessio ...
- nginx+iis+redis+Task.MainForm构建分布式架构 之 (redis存储分布式共享的session及共享session运作流程)
本次要分享的是利用windows+nginx+iis+redis+Task.MainForm组建分布式架构,上一篇分享文章制作是在windows上使用的nginx,一般正式发布的时候是在linux来配 ...
- ASP.NET Session的共享
注: 在ashx文件中使用Session 首先添加引用 using System.Web.SessionState; 实现接口 public class XXXX: IHttpHandler ==&g ...
- 通过memcached来实现对tomcat集群中Session的共享策略
近期在做一套集群的实现,实现的方案是在Linux下完成对Apache + Tomcat 负载均衡的功能. 上述功能已经实现,有需要了解的朋友可以看我另外一篇博文. Linux下Apache与Tomca ...
- Session分布式共享 = Session + Redis + Nginx
一.Session 1.Session 介绍 我相信,搞Web开发的对Session一定再熟悉不过了,所以我就简单的介绍一下. Session:在计算机中,尤其是在网络应用中,称为"会话控制 ...
- 详解Session分布式共享(.NET CORE版)
一.前言&回顾 在上篇文章Session分布式共享 = Session + Redis + Nginx中,好多同学留言问了我好多问题,其中印象深刻的有:nginx挂了怎么办?采用Redis的S ...
- spring-session实现分布式集群session的共享
前言 HttpSession是通过Servlet容器创建和管理的,像Tomcat/Jetty都是保存在内存中的.但是我们把应用搭建成分布式的集群,然后利用LVS或Nginx做负载均衡,那么来自同一用户 ...
- Tomcat通过自带的Cluster方式实现Session会话共享环境操作记录
一般来说,在多个tomcat集群业务中,session会话共享是必须的需求,不然前端nginx转发过来的请求不知道之前请求在哪台tomcat节点上,从而就找不到session以至于最终导致请求失败.要 ...
- redis缓存web session
redis缓存web session 首先说下架构图.使用Redis作为会话服务器,统一管理Session.如图,集群里的WEB服务器共享存放在REDIS里面全部的客户端SESSION. 当然,反向代 ...
随机推荐
- 使用ServiceStack构建Web服务
提到构建WebService服务,大家肯定第一个想到的是使用WCF,因为简单快捷嘛.首先要说明的是,本人对WCF不太了解,但是想快速建立一个WebService,于是看到了MSDN上的这一篇文章 Bu ...
- Laravel Composer and ServiceProvider
Composer and: 创建自定义类库时,按命名空间把文件夹结构组织好 composer.json>autoload>classmap>psr-4 composer dump-a ...
- 使用Oracle官方巡检工具ORAchk巡检数据库
ORAchk概述 ORAchk是Oracle官方出品的Oracle产品健康检查工具,可以从MOS(My Oracle Support)网站上下载,免费使用.这个工具可以检查Oracle数据库,Gold ...
- 再部署一个 instance 和 Local Network - 每天5分钟玩转 OpenStack(131)
上一节部署了 cirros-vm1 到 first_local_net,今天我们将再部署 cirros-vm2 到同一网络,并创建 second_local_net. 连接第二个 instance 到 ...
- Phoenix综述(史上最全Phoenix中文文档)
个人主页:http://www.linbingdong.com 简书地址:http://www.jianshu.com/users/6cb45a00b49c/latest_articles 网上关于P ...
- 前端HTML5几种存储方式的总结
接下来要好好总结一些知识,秋招来啦...虽然有好多知识都不大会,但是还是要努力一下,运气这种东西,谁知道呢~ 总体情况 h5之前,存储主要是用cookies.cookies缺点有在请求头上带着数据,大 ...
- WebGIS中等值面展示的相关方案简析
文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1.背景 等值面是气象.环保等相关项目上常用到的效果展示.在传统的CS项 ...
- [原]Cachedb 网络模块文档
Cachedb 网络模块文档 整体结构 多路复用 (epoll 模块) 事件驱动 (事件封装) 缓冲管理 (上层buffer管理) 设计思想 层次化的设计,每一个模块只调用上一个模块的接口,并将耦合聚 ...
- JQuery中的siblings()是什么意思
jQuery siblings() 方法返回被选元素的所有同胞元素,并且可以使用可选参数来过滤对同胞元素的搜索. 实例演示:点击某个li标签后将其设置为红色,而其所有同胞元素去除红色样式. 1.创建H ...
- Spring获取ApplicationContext
在Spring+Struts+Hibernate中,有时需要使用到Spring上下文.项目启动时,会自动根据applicationContext配置文件初始化上下文,可以使用ApplicationCo ...