Java利用Redis实现高并发计数器的示例代码
业务需求中经常有需要用到计数器的场景:譬如一个手机号一天限制发送5条短信、一个接口一分钟限制多少请求、一个接口一天限制调用多少次等等。使用Redis的Incr自增命令可以轻松实现以上需求。以一个接口一天限制调用次数为例:
/** * 是否拒绝服务 * @return */ private boolean denialOfService(String userId){ long count=JedisUtil.setIncr(DateUtil.getDate()+'&'+userId+'&'+'queryCarViolation', 86400); if(count<=10){ return false; } return true; }
/** * 查询违章 * @param plateNumber车牌 * @param vin 车架号 * @param engineNo发动机 * @param request * @param response * @throws Exception */ @RequestMapping('/queryCarViolationList.json') @AuthorizationApi public void queryCarViolationList(@CurrentToken Token token,String plateNumber,String vin, String engineNo,HttpServletRequest request,HttpServletResponse response) throws Exception { String userId=token.getUserId(); //超过限制,拦截请求 if(denialOfService(userId)){ apiData(request, response, ReqJson.error(CarError.ONLY_5_TIMES_A_DAY_CAN_BE_FOUND)); return; } //没超过限制,业务逻辑…… }
每次调用接口之前,先获得下计数器自增后的值,如果小于限制,放行,执行后面的代码。如果大于限制,则拦截掉。
JedisUtil工具类:
public class JedisUtil { protected final static Logger logger = Logger.getLogger(JedisUtil.class); private static JedisPool jedisPool; @Autowired(required = true) public void setJedisPool(JedisPool jedisPool) { JedisUtil.jedisPool = jedisPool; } /** * 对某个键的值自增 * @author liboyi * @param key 键 * @param cacheSeconds 超时时间,0为不超时 * @return */ public static long setIncr(String key, int cacheSeconds) { long result = 0; Jedis jedis = null; try { jedis = jedisPool.getResource(); result =jedis.incr(key); if (result<=1 && cacheSeconds != 0) { jedis.expire(key, cacheSeconds); } logger.debug('set '+ key + ' = ' + result); } catch (Exception e) { logger.warn('set '+ key + ' = ' + result); } finally { jedisPool.returnResource(jedis); } return result; }}
到此这篇关于Java利用Redis实现高并发计数器的示例代码的文章就介绍到这了,更多相关Java Redis 高并发计数器内容请搜索好吧啦网以前的文章或继续浏览下面的相关文章希望大家以后多多支持好吧啦网!
相关文章:
1. Java中关键字synchronized的使用方法详解2. 详解为什么Vue中不要用index作为key(diff算法)3. python tkinter GUI绘制,以及点击更新显示图片代码4. set rs=conn.execute,set rs=server.createobject(“ADODB.recordset”)的性能对比5. 如何修改PHP的memory_limit限制6. SpringBoot使用Atomikos技术整合多数据源的实现7. 解决Vue的项目使用Element ui 走马灯无法实现的问题8. Android开发之AppWidget详解9. Python requests模块安装及使用教程图解10. Python将CSV文件转化为HTML文件的操作方法