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牛币,先来先得
- 等 牛友们,大家好,你们做程序员多久了?现在还好吗?
- 完 在微信打开的页面里进行app下载
- 等 最代码2014年欢乐聚声会
- 完 mysql如何查询表数据并且对3个字段降序的SQL?
- 完 最代码牛币机制改革
- 完 成功的在bae上使用了自定义运行环境 jetty+nginx的组合,大家对jetty+nginx优化有哪些心得?
- 完 进来分享一下各位牛牛是如何加入最代码大家庭的?
- 等 为什么java BufferedImage类处理大图直接抛出内存溢出的异常?
- 等 最代码是否开发手机app客户端?
- 完 java程序员学习哪些java的技术?java有哪些框架?都能做哪方面的开发?
- 等 php格式网页文件怎么运行?
- 等 Java volatile值获取的问题
- 等 前端vue,拦截了登录后台后,返回的token,requests拦截token,但是发送请求的时候,就出现跨越异常
- 等 大专本科计算机科班怎么找到Java工作?
- 等 eclipse怎么把三个java swing游戏项目合成一个项目?
- 完 伙伴们,大家都有什么好的解压方式么,分享一下~
- 完 三四线城市,6、7k,运维工作,索然无味,想去辞职上培训,各位牛牛有什么建议嘛
- 等 jsp页面输入中文变成问号
- 等 JPA在线上运行一段时间后报错Caused by: java.lang.IncompatibleClassChangeError: null
- 等 PHP 这个规则用preg_match_all怎么写
- 等 大佬们,有没有知道Alfresco如何配置LDAP登录呢?
- 等 php的install目录是框架带的吗?
- 等 redis sentinel模式为什么master挂掉,slave没有切换?
- 等 redis主从同步启动从库出现的错误如何解决?
- 等 java通过jedis为什么无法连接redis服务?
- 等 java如何操作redis数据库的sortedset类型数据实现读取队列?
- 等 Springboot redis RedisTemplate 如何删除list对象 或根据list坐标删除
- 等 redis数据读取不一致的问题
- 完 redis单点认证系统缓存怎么控制用户登录超时和关闭浏览器?
- 等 数据共享
- 等 spring boot集成redis为什么报数据源装载失败?
- 等 redis-cli pipe方式导入mysql sql查询导出的Protocol格式数据为什么出现redis-cli.exe已停止工作的异常?
- 完 RedisDesktopManager对电脑系统的版本有要求吗?