控制服务器处理请求的数量(高并发)-防止用户重复点击导致多次请求

本文介绍了一种基于AtomicInteger的简单限流方法,并通过Redis实现防重复点击功能。但指出这种方法存在并发问题,建议使用Hystrix或Guava RateLimiter等更稳定的技术进行限流。

private final AtomicInteger tick = new AtomicInteger();

 

    @ResponseBody
    @RequestMapping(value = "/url", method = { RequestMethod.POST })
    public String geturl(参数) {
   

        try {
            if (waitInLine()) {
       
                return 告诉用户现在系统处理能力不足,稍候再试;
            }
                 
                // 判断是否重复点击
                if (isFrequently(memberId)) {

              
                    return 告诉用户不要重复点击按钮,系统正在处理上一次的请求;
                }
             

              //业务代码

 

                return  业务代码后的返回结果;
            }
        } catch (Exception e) {
      
            return CommonConstant.gson.toJson(packetResult);
        } finally {

             //一定要写finally

            tick.decrementAndGet();
        }
    }

    /**
     * 判断是否超出处理范围
     *
     * @return
     */
    private boolean waitInLine() {
        return tick.incrementAndGet() > 1000;//表示系统最多同时处理1000个请求
    }

 

    /**
     * 判断是否提交过频繁
     *
     * @param memberId
     *            会员id
     * @return
     */
    public boolean isFrequently(String memberId) {
        ShardedJedis jedis = null;
        try {
            jedis = RedisFactory.getJedis();
            if (CommonUtils.isNull(jedis.get(memberId))) {
                jedis.set(memberId, "");
                jedis.expire(memberId, 1);//1秒后标记就消失
            } else {
                return true;
            }
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            RedisFactory.returnResource(jedis);//回收连接
        }
        return false;
    }

 

 

 

 

2021-6-22 补充:上边代码是萌新时期抄的,但是代码是有并发问题的。

限制流量推荐hystrix 以及guava的RateLimit

防止重复点击的代码,isFrequently不是原子性的,因为当时是使用的旧版本的jedis,新版本的jedis代码是有原子性的set方法的。

  @Override
  public String set(String key, String value, String nxxx, String expx, long time) {
    Jedis j = getShard(key);
    return j.set(key, value, nxxx, expx, time);
  }

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值