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

公司网站自己可以学习优化吗网页设计需要学什么知乎

公司网站自己可以学习优化吗,网页设计需要学什么知乎,mugeda做网站,吴中seo网站优化软件基于redis的stream结构作为消息队列,实现异步秒杀下单 需求: 创建一个Stream类型的消息队列,名为stream.oreders 修改之前的秒杀下单Lua脚本,在认定有抢够资格后,直接向stream.orders中添加消息,内容包括…
基于redis的stream结构作为消息队列,实现异步秒杀下单

需求:

  • 创建一个Stream类型的消息队列,名为stream.oreders

  • 修改之前的秒杀下单Lua脚本,在认定有抢够资格后,直接向stream.orders中添加消息,内容包括voucherId、userId、orderId

  • 项目启动后,开启一个线程任务,尝试获取stream.orders中的消息,完成下单

首先,使用命令行来创建消息队列:

image-20250702162909923

其次,需要修改Lua脚本:

------ Generated by EmmyLua(https://github.com/EmmyLua)--- Created by 20893.--- DateTime: 2025/6/27 15:48----- 1.参数列表--1.1优惠券IDlocal voucherId = ARGV[1]--1.2用户IDlocal userId = ARGV[2]-- 1.3 订单IDlocal orderId = ARGV[3]--2.数据key--2.1库存keylocal stockKey = 'seckill:stock:' .. voucherId--2.2订单keylocal orderKey = 'seckill:order:' .. voucherId--3.业务逻辑--3.1判断库存是否充足-- redis.call('get',stockKey)中取出的值是String类型,需要将其转化成int类型,调用tonumber()方法if  (tonumber(redis.call('get', stockKey))<= 0) then--3.2. 库存不足 返回1return 1end--3.3判断用户是否重复下单if (redis.call('sismember', orderKey, userId) == 1) then--3.4. 重复下单 返回2return 2end--3.5扣减库存redis.call('incrby', stockKey, -1)--3.6记录订单redis.call('sadd', orderKey, userId)--3.7发送消息到队列中,xadd stream.orders * k1 v1 ...redis.call('xadd', 'stream.orders', '*', 'userId', userId, 'voucherId', voucherId, 'id', orderId)return 0

还需要修改Java业务代码:

 public Result seckillVoucher(Long voucherId) {//获取用户Long userId = UserHolder.getUser().getId();long orderId = redisIdWorker.nextId("order");//1.执行Lua脚本Long result = stringRedisTemplate.execute(SECKILL_SCRIPT, Collections.emptyList(),voucherId.toString(),userId.toString(),String.valueOf(orderId));//2.判断结果是否为0int r = result.intValue();if (result != 0){//2.1.不为0,代表没有购买资格return Result.fail(r == 1 ? "库存不足" : "不能重复下单");}//获取代理对象proxy = (IVoucherOrderService) AopContext.currentProxy();//3.返回订单IDreturn Result.ok(orderId);

最终,根据我们的伪代码进行对异步线程中业务流程的修改

while(true){//尝试今天队列,使用阻塞模式,最长等待2000毫秒Object msg = redis.call("xreadgroup group g1 c1 count 1 block 200 streams s1 >");if(msg == null){//null说明没有消息,继续下一次continue;}try{//处理消息,完成后需要确认消息(ACK)handleMessage(msg);}catch(Exception e){while(true){Object msg = redis.call("xreadgroup group g1 c1 count 1 block 200 streams s1 0");if(msg == null){//null说明没有异常消息,所有消息已确认,结束循环break;}try{//说明有异常消息,再次处理handleMessage(msg);}catch(Exception e){//再次出现异常,记录日志,继续循环continue;}}}}

代码展示:

 private static final ExecutorService SECKILL_ORDER_EXECUTOR = Executors.newSingleThreadExecutor();//该注解表示在类初始化之后执行@PostConstructprivate void init(){SECKILL_ORDER_EXECUTOR.submit(new VoucherOrderHandler());}private  class VoucherOrderHandler implements Runnable{String queueName = "stream.orders";@Overridepublic void run() {while ( true){try {//获取消息队列中的订单信息 xreadgroup group g1 c1 count 1 block 2000 streams stream.orders >List<MapRecord<String, Object, Object>> list = stringRedisTemplate.opsForStream().read(Consumer.from("g1", "c1"),StreamReadOptions.empty().count(1).block(Duration.ofSeconds(2)),StreamOffset.create(queueName, ReadOffset.lastConsumed()));//判断消息获取是否成功if(list == null || list.isEmpty()){//2.1如果获取失败,说明没有消息,继续下一次循环continue;}//2.2.解析消息中的数据MapRecord<String, Object, Object> entries = list.get(0);Map<Object, Object> value = entries.getValue();//将map对象转换成订单对象VoucherOrder order = BeanUtil.fillBeanWithMap(value, new VoucherOrder(), true);//2.2.如果获取成功,可以下单handleVoucherOrder(order);//3.ACK确认 sack stream.order g1 idstringRedisTemplate.opsForStream().acknowledge(queueName,"g1",entries.getId());​} catch (Exception e) {log.error("获取订单信息异常",e);handlePendingList();}}​}​private void handlePendingList() {while( true){try {//获取pending-list中的订单信息 xreadgroup group g1 c1 count 1 streams stream.orders 0List<MapRecord<String, Object, Object>> list = stringRedisTemplate.opsForStream().read(Consumer.from("g1", "c1"),StreamReadOptions.empty().count(1).block(Duration.ofSeconds(2)),StreamOffset.create(queueName, ReadOffset.from("0")));//判断消息获取是否成功if(list == null || list.isEmpty()){//2.1如果获取失败,说明pending-list没有消息,继续下一次循环break;}//2.2.解析消息中的数据MapRecord<String, Object, Object> entries = list.get(0);Map<Object, Object> value = entries.getValue();//将map对象转换成订单对象VoucherOrder order = BeanUtil.fillBeanWithMap(value, new VoucherOrder(), true);//2.2.如果获取成功,可以下单handleVoucherOrder(order);//3.ACK确认 sack stream.order g1 idstringRedisTemplate.opsForStream().acknowledge(queueName,"g1",entries.getId());​} catch (Exception e) {log.error("获取pending-list订单信息异常",e);//如果害怕因为报错导致陷入循环,可以设置休眠时间try {Thread.sleep(20);} catch (InterruptedException ex) {throw new RuntimeException(ex);}}}}}

整体业务流程描述:

首先尝试从消息队列中读取数据,如果数据获取失败,直接进行下一次循环,再来读一次消息队列,如果获取成功,说明有订单信息需要处理,就去解析订单信息,完成下单,在进行ack确认。在进行下一次读取,继续循环,如果在处理消息的过程抛出异常,导致该消息没有确认,那么该消息就会进入pending-list,就被catch到,在catch中执行handlePendinglist()函数,在该函数中,首先去pending-list获取未确认消息,如果读到,则解析消息,处理,下单,ack确认,如果没有异常消息,就会直接跳出循环,异常处理结束,如果再抛异常,就再度循环。直到pending-list中所有异常全部处理完成为止。

进行测试:

image-20250702173402911

image-20250702173423837

image-20250702173452042

image-20250702173524978

再次测试:

image-20250702173728568

至此优化秒杀下单的业务需求完成。

希望对大家有所帮助。


文章转载自:

http://2IF3ineB.pzrnf.cn
http://GXEJhHF7.pzrnf.cn
http://3H2TjUBQ.pzrnf.cn
http://V1iLVJok.pzrnf.cn
http://HS3zeCUF.pzrnf.cn
http://jL2i1u63.pzrnf.cn
http://rqO8wLXx.pzrnf.cn
http://n1z5HoLG.pzrnf.cn
http://poTOeIYI.pzrnf.cn
http://mY4GRqEe.pzrnf.cn
http://SlldYaLV.pzrnf.cn
http://fdEAANLv.pzrnf.cn
http://Y9cgyOQ7.pzrnf.cn
http://4WkutyxY.pzrnf.cn
http://0WQtVeQU.pzrnf.cn
http://s7N0AlCu.pzrnf.cn
http://ZdsDkSjT.pzrnf.cn
http://dBv1yB8g.pzrnf.cn
http://XDfsEiWH.pzrnf.cn
http://DF50loSW.pzrnf.cn
http://THhM9syz.pzrnf.cn
http://B603CygQ.pzrnf.cn
http://CAE7SdyT.pzrnf.cn
http://HmRndJUr.pzrnf.cn
http://JLqmQTQK.pzrnf.cn
http://kjc3mKN3.pzrnf.cn
http://RKQYEC2y.pzrnf.cn
http://qZMgdz68.pzrnf.cn
http://i2oZs4wi.pzrnf.cn
http://Ozmwzrmb.pzrnf.cn
http://www.dtcms.com/wzjs/701495.html

相关文章:

  • 站长工具seo综合查询收费吗福建龙岩天宫山
  • 单位网站建设情况说明书广州网站建设的公司
  • 哪些网站可以做顺风车旅游网站有哪些
  • 那个网站做网编好医院网站建设存在问题
  • 在线制作钓鱼网站源码网站建设找汉狮
  • 9元包邮网站怎么做wordpress 插件 扫描
  • 温州网站制作网站网站建设388
  • 网站建设 服务范围wordpress链接数据库出错
  • 建设个人网站流程网站建设职位名称
  • 企业搭建自己的网站沈阳网站建设服务平台
  • 网站代运营合同模板四川建筑安全员c证报名官网
  • 如何添加网站图标易点科技有限公司
  • 百度网站验证是贺州 网站建设公司有哪些
  • 海口网站开发师招聘石家庄网络公司代理
  • 黄埔区做网站做计算机网站有哪些功能
  • 海棠网站是什么意思企业做网站的方案
  • 国内著名平面设计师的个人网站运动健身型网站开发
  • c语言开发网站教程wordpress怎么加菜单
  • seo的外链平台有哪些如何做网站的优化
  • 厦门网站建设和人才库建设网站建设维护服务协议
  • 怎么做搜索网站银川做网站哪家好
  • 如何选择网站公司成都住建局官网app
  • 惠州网站小程序建设点网站备案查询接口
  • 网站生成wap海外网络推广专员招聘
  • 广州那家做网站最好wordpress 与现有sso
  • 做1元夺宝网站挣钱吗网站彩票做号
  • 微 网站阿里网站建设费用
  • 做站群的网站怎么来景观设计学
  • 河南整合网络营销咨询太原seo推广优化
  • 2016织梦小说网站源码淘宝代运营公司十大排名