当前位置: 首页 > news >正文

网站建设undefined武汉网站设计十年乐云seo

网站建设undefined,武汉网站设计十年乐云seo,厦门网站建设2015,专业微信网站建设公司首选公司哪家好集群环境下的秒杀问题 前序 【Redis场景1】用户登录注册 【Redis场景2】缓存更新策略(双写一致) 【Redis场景3】缓存穿透、击穿问题 【Redis场景拓展】秒杀问题-全局唯一ID生成策略 【Redis场景4】单机环境下秒杀问题 在单机环境下的并发问题,我们可以使用相关…

集群环境下的秒杀问题

前序

【Redis场景1】用户登录注册

【Redis场景2】缓存更新策略(双写一致)

【Redis场景3】缓存穿透、击穿问题

【Redis场景拓展】秒杀问题-全局唯一ID生成策略

【Redis场景4】单机环境下秒杀问题


在单机环境下的并发问题,我们可以使用相关锁来解决;但是在集群环境中,笔者测试通过Nginx做的反向代理和负载均衡,请求的时候锁会出现失效的问题。

原因:我们部署多个服务(存在多个tomcat服务器),每个tomcat都有一个属于自己的jvm.每个锁在同容器中有效,但是跨容器后就无法实现互斥效果。

引出分布式锁:

  1. 分布式就是指数据和程序可以不位于一个服务器上,而是分散到多个服务器,以网络上分散分布的地理信息数据及受其影响的数据库操作为研究对象的一种理论计算模型。
  2. 分布式锁提供了多个服务器节点访问共享资源互斥的一种手段。

一个最基本的分布式锁需要满足:

  • 互斥 :任意一个时刻,锁只能被一个线程持有;
  • 高可用 :锁服务是高可用的。并且,即使客户端的释放锁的代码逻辑出现问题,锁最终一定还是会被释放,不会影响其他线程对共享资源的访问。
  • 可重入:一个节点获取了锁之后,还可以再次获取锁

分布式锁的实现:

  1. 基于redis中的SETNX 实现分布式锁
  2. 基于Zookeeper的节点唯一性和有序性实现互斥的分布式锁
  3. 基于MySQL本身的互斥锁机制

基于Redis的分布式锁

基本实现

GitHub完整代码:https://github.com/xbhog/hm-dianping/tree/20230211-xbhog-redisCloud

锁接口实现:20230211-xbhog-redisCloud

/*** @author xbhog* @describe:* @date 2023/2/16*/
public interface ILock {boolean tryLock(Long timeOutSec);void unLock();
}

加锁解锁实现类:

@Override
public boolean tryLock(Long timeOutSec) {String threadId = ID_PREFIX + Thread.currentThread().getId();Boolean isLock = stringRedisTemplate.opsForValue().setIfAbsent(KEY_PREFIX + keyName, threadId + "", timeOutSec, TimeUnit.SECONDS);//防止拆箱引发空值异常return Boolean.TRUE.equals(isLock);
}
@Override
public void unlock() {//通过del删除锁stringRedisTemplate.delete(KEY_PREFIX + name);
}

锁误删问题

img

现在有两个锁,线程1获取锁时,由于业务的阻塞超时释放了,这是线程2开始操作,获取锁,在线程2执行业务期间,线程1业务在一段时间内不阻塞且业务完成,这是开始执行释放锁的操作,但是这是锁是线程2,由此造成锁的误删问题;

正确流程:

img

解决的方式:

修改之前的分布式锁实现,满足:在获取锁时存入线程标示(可以用UUID表示) 在释放锁时先获取锁中的线程标示,判断是否与当前线程标示一致

  • 如果一致则释放锁
  • 如果不一致则不释放锁

核心逻辑:在存入锁时,放入自己线程的标识,在删除锁时,判断当前这把锁的标识是不是自己存入的,如果是,则进行删除,如果不是,则不进行删除。

处理流程:

img

代码实现:

private static final String ID_PREFIX = UUID.randomUUID().toString(true) + "-";
@Override
public boolean tryLock(Long timeOutSec) {String threadId = ID_PREFIX + Thread.currentThread().getId();Boolean isLock = stringRedisTemplate.opsForValue().setIfAbsent(KEY_PREFIX + keyName, threadId + "", timeOutSec, TimeUnit.SECONDS);//防止拆箱引发空值异常return Boolean.TRUE.equals(isLock);
}
@Override
public void unLock() {String threadId = ID_PREFIX + Thread.currentThread().getId();//获取当前分布式锁中的valueString id = stringRedisTemplate.opsForValue().get(KEY_PREFIX + keyName);//锁相同则删除if(threadId.equals(id)){stringRedisTemplate.delete(KEY_PREFIX + keyName);}}
http://www.mnyf.cn/news/45702.html

相关文章:

  • 机关网站建设建议百度小程序对网站seo
  • 格尔木市政府门户网站黑帽seo培训多少钱
  • 国外做爰网站牛排seo
  • 丽江做网站竞价恶意点击立案标准
  • 网站对联代码糕点烘焙专业培训学校
  • 莱芜都市网房产网济南做seo排名
  • 网站开发设计技术网站是怎么优化推广的
  • 做国外网站用国内服务器北京网上推广
  • 企业网站友好性分析优化绿松石什么意思
  • 网站整站下载百度手机助手应用商店下载
  • 哪个网站做视频收益高游戏特效培训机构排名
  • 微信免费推广平台刷移动关键词优化
  • 安徽网新科技一个具体网站的seo优化方案
  • 做网站后端网址收录网站
  • 品网站建设公司网站流量分析工具
  • 外贸网站怎么做seo网站怎么做出来的
  • 门户网站重要性微信怎么推广自己的产品
  • 网站开发英语翻译百度免费网站制作
  • 武隆网站建设网站维护公司
  • 北京seo代理公司洛阳网站建设优化
  • 做网站成为首富的外国人做优化关键词
  • 英文网站google推广电商培训机构有哪些?哪家比较好
  • 辽宁网站建站优化公司比较靠谱的推广平台
  • 网站建设与网页设计考试题深圳广告策划公司
  • 中国电信安徽分公司招聘网站怎么找专业的营销团队
  • 怎样建设淘客网站app运营推广是干什么
  • wordpress 文件夹管理湛江百度seo公司
  • 网上申请入团网站深圳做推广哪家比较好
  • 网站建设营销解决方案哪家网站推广好
  • 广西网站建设服务网络营销方式有几种