码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 使用Postman并发测试接口&关于RedisTemplate线程安全的一些理解


    目录

    1、前言

    2、 使用Postman并发执行接口

     2.1、Postman版本为:7.36.6

    2.1.1、请求参数为json

    2.1.2、请求参数为form表单

    2.2、Postman版本为:8.12.4

    2.2.1、请求参数为json

    2.2.2、请求参数为form表单

    3、总结

    4、参考资料


    1、前言

            之前在学习redis的时候,做了一个“商品秒杀”的Demo公开到了网上,然后就有人评论:“redis本身就是线程安全的,没必要在秒杀方法上在加synchronized锁了”。

    为了验证他的说法。

    一开始我是打算用Junit,在test类中开多个线程同时去调用“doSecKill”方法。

     但这种测试的方法行不通!在程序运行的过程中,涉及到redis的操作都直接跳过了。我查了一下网上的说法,发现Junit并不适合用来测试多线程程序。

    可参考:Junit测试多线程_xiaoyangxavier的博客-CSDN博客

    因为懒得装Jmeter,我就用电脑上现有的Postman测试了一下。

    2、 使用Postman并发执行接口

    要测试的接口

     2.1、Postman版本为:7.36.6

    2.1.1、请求参数为json

     

     Step1、

    Step2、

    Step3、上传参数文件(json)

     

     Step4、点击“Run 并发测试”按钮

    并发测试执行情况 

     

    2.1.2、请求参数为form表单

    Step1、Step2同2.1.1

    Step3、上传参数文件(txt)

    Step4、点击“Run 并发测试”按钮

    并发测试执行情况 

     

    2.2、Postman版本为:8.12.4

     进入并发配置页面

    2.2.1、请求参数为json

    Step1、准备参数文件 data.json

     Step2、上传参数文件

     

     Step3、点击“Run 并发测试”按钮

    执行结果

    2.2.2、请求参数为form表单

    Step1、准备参数文件 data.txt

    Step2、上传参数文件

    Step3、点击“Run 并发测试”按钮

    执行结果

    3、总结

    RedisTemplate类,在我们配置好redis之后,本身就是一个线程安全的类。再使用 RedisTemplate类里面的相关方法,比如:opsForValue、opsForValue().decrement等这些,就无需再在方法上加锁,或者给某个代码块加锁了。因为这些方法对redis的操作都是原子化的。

    不过对于RedisTemplate类是如何做到线程安全的,我在网上没有查到相关的说明解释,自己看源码,只看到了RedisTemplate类引入了一个类:TransactionSynchronizationManager

    RedisTemplate类中有一个excute()方法,负责与redis建立连接。采用工厂模式,由RedisConnectionFactory类统一创建线程安全的redis的连接对象。在使用过程中由org.springframework.transaction.support.TransactionSynchronizationManager类对每个分配出去的redis连接对象进行监听。TransactionSynchronizationManager使用ThreadLocal来为不同的事务线程提供独立的资源副本,并且同时维护这些事务的配置属性和运行状态。当TransactionSynchronizationManager监听到RedisTemplate在执行redis操作相关的方法时,比如:redisTemplate.opsForValue().get(kcKey)、redisTemplate.opsForSet().isMember(userKey, uid)、redisTemplate.opsForValue().decrement(kcKey)等等。对于每一次redis操作都会被TransactionSynchronizationManager监听并为其操作线程提供独立的资源副本,“独立的资源副本”使得每一次redis操作互不干涉,避免了“脏数据”的情况。

    总言而之:

    1、RedisTemplate类通过RedisConnectionFactory实现操作线程原子化,确保在并发的情况下每一个操作线程不会被其他线程干扰。

    2、RedisTemplate类通过TransactionSynchronizationManager对每个操作线程在操作过程的redis里面的数据提供“独立的资源副本”,避免碰到“脏数据”。

    注:以上关于redis的叙述仅供参考

    4、参考资料

    Redis Setnx 命令_只有在 key 不存在时设置 key 的值。

    https://www.jianshu.com/p/1e30e7a4b0c8

    解决csv文件自动去掉首位0的方法__easyIT的博客-CSDN博客_csv保留首位是0

    RedisTemplate中的execute方法如何使用 - 掘金 (juejin.cn)

    Postman自动化测试时如何导入外部文件作为变量输入_欧世乐测试开发技术的博客-CSDN博客

    Junit测试多线程_xiaoyangxavier的博客-CSDN博客

  • 相关阅读:
    Java反射调用jar包
    设计模式(二)——策略模式(Strategy)
    【C++】enum class 域化枚举
    【科学文献计量】科学文献知识网络分析基础
    Vscode配置C/C++编程环境@配置C和CPP的运行和调试环境@配置过程的相关问题@中文文件名乱码@build和debug方案组合配置
    蔚蓝资源包和数据分析
    pmp考试是什么?
    二叉树 | 删除二叉树中的节点、修剪二叉树 | leecode刷题笔记
    实验二.常用网络命令
    【MySQL】索引的增删查
  • 原文地址:https://blog.csdn.net/weixin_42032770/article/details/126587964
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号