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

网站建设undefined海外推广代理商

网站建设undefined,海外推广代理商,凤翔做网站,毕业设计代做的网站靠谱吗集群环境下的秒杀问题 前序 【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.mmbaike.com/news/28480.html

相关文章:

  • 南阳做网站seo的国际重大新闻事件10条
  • 网站建设需要学习哪些公司网站建设流程
  • 做网站用webpack可以吗百度识图网页版入口
  • 机械设备东莞网站建设郑州百度推广开户
  • 开发公司发生的物业费用所得税申报深圳seo优化排名推广
  • 做旅游网站教程武汉seo招聘信息
  • 用表格做网站教程搜客
  • 怎样在领英上做公司网站互联网营销案例分析
  • 网站文化建设阿里云域名查询和注册
  • 贺州做网站哪家公司快速排名seo软件
  • 国内网站开发公司seo关键词优化哪个平台好
  • 网站建设最好的杭州seo博客有哪些
  • 顺德网站建设找顺的河北seo基础知识
  • 电子商务营销策略株洲seo优化推荐
  • 成都APP,微网站开发软文推广新闻发布
  • 公司建立网站的好处软文广告素材
  • 网站建设的基本准则是什么百度seo优化怎么做
  • 零下一度网站建设糕点烘焙专业培训学校
  • 湖南企业网站建设淘宝直通车推广怎么收费
  • 江门市建设银行网站国外网页模板
  • 乐清网站设计公司哪家好巨量引擎广告投放
  • 有哪些学做衣服的网站昆明自动seo
  • 天津做网站的公司百度手机助手app下载官网
  • 登陆不了建设银行网站地推网app推广平台
  • 小程序用什么开发锦州seo推广
  • wordpress 函数教程视频网络seo营销推广
  • 做美女网站会天津做网站的公司
  • 微网站建设找哪家好深圳网络推广工资
  • asp.net建立手机网站免费测试seo
  • 网站开发前景知乎优秀企业网站欣赏