redis如何实现多个项目间同一条数据的并发读写控制?
目前最代码的多个项目(www,admin,edu)的同一个数据的读写缓存是通过ehcache实现,jgroups实现同步,但是发现,如果服务器负载较高的情况下,jgroups同步会出现问题。
最近在思考换成redis替代ehcache
但是同一条数据之间的读写并发控制是个问题,首先想到的是redis的加锁机制,如果Redis中有这条数据的锁则读写MySQL,如果没有则读写Redis,这样是否会对MySQL的压力加大?
另外百度搜索到的Redis共享数据全部是对Session的操作,请教牛牛们是否有类似的解决方案。

@Scheduled(initialDelay = 1000, fixedDelay = 60000)
public void redisTest(){
Jedis jedis = jedisPool.getResource();
try{
jedis.set("red_packet_num","5000");
}catch (Exception e)
{
e.printStackTrace();
if (jedis != null) {
jedis.close();
}
}
finally {
if (jedis != null) {
jedis.close();
}
}
Lock lock=new ReentrantLock();
for(int i=0;i<2000;i++){
fixedThreadPool.execute(new Runnable() {
@Override
public void run() {
Jedis jedis = jedisPool.getResource();
try {
lock.lock();
String red_packet_num = jedis.get("red_packet_num");
int a = Integer.parseInt(red_packet_num) - 1;
jedis.set("red_packet_num", String.valueOf(a));
lock.unlock();
System.out.println("数据是:" + a+"当前线程是:"+Thread.currentThread().getName()+"当前时间"+ CommonUtil.getCurrentTimeFormatForHMS());
}
catch (Exception e){
e.printStackTrace();
if (jedis != null) {
jedis.close();
}
}
finally {
if (jedis != null) {
jedis.close();
}
}
}
});
}
}
代码推荐调试看看,看处其中的处理操作逻辑,如何其中的推荐实践做实际实践看看吧,谢谢!
- 等最代码怎么获取牛币啊?
- 完谁来告诉我最代码上线的时间,答对者给5牛币,先来先得
- 等牛友们,大家好,你们做程序员多久了?现在?#36141;?#21527;?
- 完在微信打开的页面里进行app下载
- 等最代码2014年欢乐聚声会
- 完mysql如何查询表数据并且对3个字段降序的SQL?
- 完最代码牛?#19968;?#21046;改革
- 完成功的在bae上使用了自定义运?#35874;?#22659; jetty+nginx的组合,大家对jetty+nginx优化有哪些心得?
- 完进来分享一下各位牛牛是如何加入最代码大家庭的?
- 等为什么java BufferedImage类处理大图直接抛出内存溢出的异常?
- 等最代码是否开发手机app客户端?
- 完java程序员学习哪些java的?#38469;酰縥ava有哪些框架?都能做哪方面的开发?
- 等web扫码登录怎么实现,提供一下思路
- 等刚毕业的大学生主攻python?#27809;?#26159;Java好?
- 等Python好学吗
- 等VUE+pdf.js+Spring cloud在线预览pdf
- 等redis如何实现多个项目间同一条数据的并发读写控制?
- 等怎么将远程linux机器上的目录上在页面上以树形结构显示?
- 完springcloud进行远程调用的时候,微服务返回的json数据报错
- 等本人java新手入行,不知从什么地方入手,请各位大神指导。
- 等使用阿里easyexcel读取日期格式的数据得到的是数字
- 等如何orm框架中设置,让不同数据库字段类型互转
- 等sql语句 group by 后面的字段 要必须 与 select 后面的字段(除聚合函数) 保持一致吗??
- 完一个关于评级的疑问

- 等redis sentinel模式为什么master?#19994;簦瑂lave没有切换?
- 等java如何操作redis数据库的sortedset类型数据实现读取队列?
- 等redis主从同步启动从库出现的错误如何解决?
- 等java通过jedis为什?#27425;?#27861;连接redis服务?
- 等完redis单点?#29616;?#31995;统缓存怎么控制用户登录超时和关闭浏览器?
- 等redis数据读取不一致的问题
- 等redis-cli pipe方?#38477;?#20837;mysql sql查询导出的Protocol格式数据为什么出现redis-cli.exe已停?#26500;?#20316;的异常?
- 完RedisDesktopManager对电脑系统的版本有要求吗?
- 等spring boot集成redis为什么报数据源装载失败?
