码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 外卖系统关于redis使用解决高并发情况


    1、如何配置redis

    在java中操作redis

    操作步骤:

    1、导入Spring Data Redis的maven坐标

    2、配置Redis数据源

    3、编写配置类,创建RedisTemplate对象

    4、通过RedisTemplate对象操作Redis

    2、Redis结合Lua脚本

    • 减少网络开销:使用Lua脚本,无需向Redis 发送多次请求,执行一次即可,减少网络传输
    • 原子操作:Redis 将整个Lua脚本作为一个命令执行,原子,无需担心并发
    • 复用:Lua脚本一旦执行,会永久保存 Redis 中,其他客户端可复用

    lua执行过程

    重试、限流、熔断被称为分布式系统高可用性的四板斧;

    分布式限流

           分布式区别于单机限流,它把整个分布式集群环境中所有服务器当作一个整体来考量。比如针对IP,我们限制一个IP每秒最多访问10个访问,不管来自这个IP的地址的请求落在了哪台机器上,只要是访问了集群中的服务节点,那么都会收到限制规则的制约。

    目前两种主要的限流方案:

    • 网关层限流。将限流规则应用再所有流量的入口处
    • 中间件限流。将限流信息存储在分布式环境中某个中间件里(例如redis),每个组件都能从这里获取到当前时间的流量统计,从而决定是否放行还是拒绝。

    1. -- 获取调用脚本时传入的第一个key值(用作限流的 key)
    2. local key = KEYS[1]
    3. -- 获取调用脚本时传入的第一个参数值(限流大小)
    4. local limit = tonumber(ARGV[1])
    5. -- 获取当前流量大小
    6. local curentLimit = tonumber(redis.call('get', key) or "0")
    7. -- 是否超出限流
    8. if curentLimit + 1 > limit then
    9. -- 返回(拒绝)
    10. return 0
    11. else
    12. -- 没有超出 value + 1
    13. redis.call("INCRBY", key, 1)
    14. -- 设置过期时间
    15. redis.call("EXPIRE", key, 2)
    16. -- 返回(放行)
    17. return 1
    18. end

  • 相关阅读:
    Kotlin 数据类生成多个构造函数
    Android 对于状态栏和导航栏的操作
    DSPE-PEG-NH2,CAS:474922-26-4 磷脂-聚乙二醇-氨基饱和18C磷脂
    Leetcode 39.组合总和
    一些k8s集群操作命令
    智能化安全巡更巡查系统—提升安全管理效率
    安全-js的bind方法
    Java8 新特性之Stream(四)-- Stream的summaryStatistics()
    ⽬标⾏动及稠密环境未知情况下,⽆⼈机跟踪的系统解决⽅案
    76、SpringBoot 整合 MyBatis------使用 sqlSession 作为 Dao 组件(就是ssm那一套,在 xml 写sql)
  • 原文地址:https://blog.csdn.net/weixin_53908842/article/details/138975018
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号