返回顶部
首页 > 资讯 > 数据库 >Redis原子计数器incr如何防止并发请求
  • 229
分享到

Redis原子计数器incr如何防止并发请求

2024-04-02 19:04:59 229人浏览 独家记忆
摘要

这篇文章将为大家详细讲解有关Redis原子计数器incr如何防止并发请求,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、前言在一些对高并发请求有限制的系统或者功能里,比

这篇文章将为大家详细讲解有关Redis原子计数器incr如何防止并发请求,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

一、前言

在一些对高并发请求有限制的系统或者功能里,比如说秒杀活动,或者一些网站返回的当前用户过多,请稍后尝试。这些都是通过对同一时刻请求数量进行了限制,一般用作对后台系统的保护,防止系统因为过大的流量冲击而崩溃。对于系统崩溃带来的后果,显然还是拒绝一部分请求更能被维护者所接受。
而在各种限流中,除了系统自身设计的带机制的计数器外,利用Redis实现显然是一种既高效安全又便捷方便的方式。

二、incr命令

Redis Incr 命令将 key 中储存的数字值增一。
如果 key 不存在,那么 key 的值会先被初始化为 0 ,然后再执行 INCR 操作。
如果值包含错误的类型,或字符串类型的值不能表示为数字,那么返回一个错误。
本操作的值限制在 64 位(bit)有符号数字表示之内。
示例:

127.0.0.1:6379> set num 10
OK
127.0.0.1:6379> incr num
(integer) 11
127.0.0.1:6379> get num    # 数字值在 Redis 中以字符串的形式保存
"11"

注意: 由于redis并没有一个明确的类型来表示整型数据,所以这个操作是一个字符串操作。

执行这个操作的时候,key对应存储的字符串被解析为10进制的64位有符号整型数据。
事实上,Redis 内部采用整数形式(Integer representation)来存储对应的整数值,所以对该类字符串值实际上是用整数保存,也就不存在存储整数的字符串表示(String representation)所带来的额外消耗。

三、使用场景

1.计数器

使用思路是:每次有相关操作的时候,就向Redis服务器发送一个incr命令。
例如这样一个场景:我们有一个WEB应用,我们想记录每个用户每天访问这个网站的次数。
web应用只需要通过拼接用户id和代表当前时间的字符串作为key,每次用户访问这个页面的时候对这个key执行一下incr命令。

这个场景可以有很多种扩展方法:
通过结合使用INCR和EXPIRE命令,可以实现一个只记录用户在指定间隔时间内的访问次数的计数器
客户端可以通过GETSET命令获取当前计数器的值并且重置为0
通过类似于DECR或者INCRBY等原子递增/递减的命令,可以根据用户的操作来增加或者减少某些值 比如在线游戏,需要对用户的游戏分数进行实时控制,分数可能增加也可能减少。

2.限速器

限速器是一种可以限制某些操作执行速率的特殊场景。
传统的例子就是限制某个公共api的请求数目。
假设我们要解决如下问题:限制某个api每秒每个ip的请求次数不超过10次。
我们可以通过incr命令来实现两种方法解决这个问题。

四、流量控制之java实现

这里我们将在java中使用redis-incr的特性来构建一个1分钟内只允许 请求100次的控制代码,key代表在redis内存放的被控制的键值。

public static boolean flowControl(String key){
        //最大允许100
        int max = 100;
        long total = 1L;
        try {
            if (jedisInstance.get(key) == null) {
                //jedisInstance是Jedis连接实例,可以使单链接也可以使用链接池获取,实现方式请参考之前的blog内容
                //如果redis目前没有这个key,创建并赋予0,有效时间为60s
                jedisInstance.setex(key, 60, "0");
            } else {
                //获取加1后的值
                total = jedisInstance.incr(redisKey).longValue();
                //Redis TTL命令以秒为单位返回key的剩余过期时间。当key不存在时,返回-2。当key存在但没有设置剩余生存时间时,返回-1。否则,以秒为单位,返回key的剩余生存时间。
                if (jedisInstance.ttl(redisKey).longValue() == -1L)
                {
                    //为给定key设置生存时间,当key过期时(生存时间为0),它会被自动删除。
                    jedisInstance.expire(redisKey, 60);
                }
            }
        } catch (Exception e) {
            logger.error("流量控制组件:执行计数操作失败,无法执行计数");
        }
        long keytotaltransations = max;
        //判断是否已超过最大值,超过则返回false
        if (total > keytotaltransations) {
            return false;
        }
        return true;
    }

关于Redis原子计数器incr如何防止并发请求就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

您可能感兴趣的文档:

--结束END--

本文标题: Redis原子计数器incr如何防止并发请求

本文链接: https://lsjlt.com/news/51913.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Redis原子计数器incr如何防止并发请求
    这篇文章将为大家详细讲解有关Redis原子计数器incr如何防止并发请求,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、前言在一些对高并发请求有限制的系统或者功能里,比...
    99+
    2024-04-02
  • Redis原子计数器incr防止并发请求指的是什么
    小编给大家分享一下Redis原子计数器incr防止并发请求指的是什么,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!一、前言在一些对高并发请求有限制的系统或者功能里,比如说秒杀活动,或者一些网站...
    99+
    2024-04-02
  • 如何防止重复发送Ajax请求
    本篇内容主要讲解“如何防止重复发送Ajax请求”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何防止重复发送Ajax请求”吧!在页面中有多个按钮,点击该按钮可以...
    99+
    2024-04-02
  • 如何使用同步原语来防止 Goroutine 并发?
    防止并发问题可以使用同步原语,包括:mutex:允许一次只有一个 goroutine 访问共享数据。semaphore:限制可同时访问共享数据的 goroutine 数量。waitgro...
    99+
    2024-05-15
    同步原语
  • web服务器如何处理并发请求
    web服务器如何处理并发请求?Web服务器是用于处理和响应来自客户端的请求的软件或硬件系统。处理并发请求是Web服务器的一个核心功能,因为在现代Web应用程序中,同时会有大量的请求发送到服务器。以下是关于Web服务器如何处理并发请求的概述...
    99+
    2024-01-24
    web服务器如何处理并发请求 云服务器 云服务器知识
  • 如何解决Redis高并发防止秒杀超卖的问题
    这篇文章主要介绍了如何解决Redis高并发防止秒杀超卖的问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1:解决思路将活动写入 redis 中,通过 redis 自减指令扣...
    99+
    2023-06-25
  • 原生JS如何发送异步数据请求
    这篇文章主要介绍原生JS如何发送异步数据请求,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在做项目的时候,有时候需要用到异步数据请求,但是如果这个时候没有框架的依赖,就需要用到原生J...
    99+
    2024-04-02
  • Apache 服务器如何优化 PHP 并发请求?
    Apache 服务器如何优化 PHP 并发请求? Apache 是一个广泛使用的 Web 服务器,它能够处理大量的并发请求。然而,当我们在使用 PHP 开发 Web 应用程序时,我们往往会遇到一些性能问题,特别是在高并发的情况下。 在本文中...
    99+
    2023-09-22
    并发 unix apache
  • Apache服务器如何应对Python并发请求?
    Apache是一款流行的Web服务器软件,它可以运行在Windows、Linux等多种操作系统上。作为一款优秀的服务器软件,Apache在处理并发请求方面表现出了卓越的性能。但是,当我们使用Python编写Web应用时,如何让Apache...
    99+
    2023-11-13
    并发 apache 关键字
  • JavaScript如何利用Promise控制并发请求个数
    一、场景 假设现在有这么一种场景:现有 30 个异步请求需要发送,但由于某些原因,我们必须将同一时刻并发请求数量控制在 5 个以内,同时还要尽可能快速的拿到响应结果。 如图所示: ...
    99+
    2024-04-02
  • PHP数组分页中如何处理并发请求?
    并发请求在数组分页中至关重要,双重锁定提供了一种处理方法:使用全局变量存储当前页和每页大小。获取互斥锁以防止同时访问共享资源。计算总记录数、总页数并检查当前页是否超出范围。计算偏移量并使...
    99+
    2024-05-03
    php 并发处理 并发请求
  • 大数据时代,PHP 容器如何应对高并发请求?
    在大数据时代,随着互联网的快速发展,网站的访问量也在不断增加,高并发请求成为了互联网应用开发中需要解决的重要问题。PHP 容器作为一种常见的互联网应用开发框架,如何应对高并发请求,也是开发者们需要深入研究的问题。 一、PHP 容器的基本原理...
    99+
    2023-06-15
    容器 响应 大数据
  • Python 函数如何实现实时响应并发请求?
    Python 是一门强大的编程语言,它支持并发编程。在现代 Web 应用程序中,实现并发请求处理是至关重要的。在本文中,我们将探讨如何使用 Python 函数来实现实时响应并发请求。 Python 函数是一种可重复使用的代码块,可以接收参...
    99+
    2023-08-29
    函数 实时 并发
  • Go语言在云计算中如何处理大量的并发用户请求?
    随着云计算的普及和应用,云计算技术已经成为了现代IT行业中最前沿和关键的技术之一。在云计算中,作为应用程序的基础语言之一的Go语言,因其高效的并发处理和轻量级特性,成为许多企业和开发者选择的语言之一。而在云计算场景中,处理大量的并发请求是必...
    99+
    2023-05-18
    Go语言 云计算 并发用户请求
  • ASP在Unix大数据环境下,如何应对高并发请求?
    随着大数据技术的发展,数据量的快速增长已经成为了数据处理的一个重要问题。同时,随着互联网的普及,高并发请求也成为了许多网站所面临的一个挑战。ASP作为一种常用的Web开发技术,也需要面对这些问题。本文将介绍ASP在Unix大数据环境下,如...
    99+
    2023-09-23
    响应 unix 大数据
  • 如何在PHP项目中处理大数据量和高并发请求?
    如何在PHP项目中处理大数据量和高并发请求?随着互联网的快速发展,越来越多的网站和应用需要处理大数据量和高并发请求。尤其是在PHP项目中,由于其易于学习和部署的特性,承载着许多大型在线平台的重任。但是,PHP作为一种脚本语言,在处理大数据量...
    99+
    2023-11-03
    PHP 高并发请求 大数据量处理
  • 在Go语言中如何解决并发网络请求的请求参数校验和合法性问题?
    在Go语言中进行并发网络请求时,我们经常需要对请求参数进行校验和合法性检查。本文将介绍如何使用Go语言的并发特性来解决这些问题,并提供具体的代码示例。首先,我们需要使用Go语言的协程来同时发送多个网络请求。Go语言提供了goroutine来...
    99+
    2023-10-22
    并发(Concurrency) 请求参数校验(parameter validation) 合法性问题(validity
  • 如何使用golang中的http.Post函数发送POST请求并获取响应
    如何使用golang中的http.Post函数发送POST请求并获取响应在使用golang进行网络编程时,http包是我们经常使用的一个重要模块。其中,http.Post函数是一个非常实用的函数,可以方便地发送POST请求并获取响应结果。下...
    99+
    2023-11-18
    Golang POST请求 httpPost
  • 如何利用 Apache 服务器实现 PHP 并发请求的分布式处理?
    如何利用 Apache 服务器实现 PHP 并发请求的分布式处理? 随着互联网的发展,越来越多的网站需要处理大量的并发请求。为了提高网站的响应速度和稳定性,我们需要使用分布式处理来处理大量的并发请求。在本文中,我们将介绍如何使用 Apach...
    99+
    2023-09-22
    并发 unix apache
  • 如何使用Redis+Lua脚本实现计数器接口防刷功能
    这篇文章主要介绍如何使用Redis+Lua脚本实现计数器接口防刷功能,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!【实现过程】一、问题分析 如果set命令设置上,但是在设置失效时间时由于网络抖动等原因导致没...
    99+
    2023-06-29
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作