Redis进行高并发的处理

背景:在集群多台服务器的系统会产生同一秒钟请求多次的情况;

解决方案:为了解决这种高并发的情况可以使用Redis进行处理,常见的方式先进行Redis.GetValue(key),如果值不存在的情况下,进行Redis.SetValue(key,10);这种情况如果是同一秒钟进行请求的时候是无法进行拦截的,具体的可以使用Jmeter进行性能应用进行请求处理;

改善的方法:使用Redis.SetNX进行改写

在 Redis 里,所谓 SETNX,是「SET if Not eXists」的缩写,也就是只有不存在的时候才设置,可以利用它来实现锁的效果。

通过测试进行的效果可以看到这个是可以进行同一秒钟多个请求的拦截处理;

2.如果不是同一秒甚至与是10秒之后的二次回写的问题这个可以使用数据库的原子性操作进行业务的更新、插入操作;

如果更新的结果是0,说明该操作已经处理,就不能进行二次的处理,该情况适用于一个方法的执行时间较长,并且在请求的时候数据状态是1,当真正进行处理业务的时候该数据的状态0已经无效了,这个时候就不能进行功能的处理,否则会把0值更新为1;导致的业务异常;

 

你可能感兴趣的:(Redis,数据原子性解决高并发)