(二)高并发压力测试调优篇——caffeine本地缓存调优

前言

在上一节内容中我们主要介绍了高并发请求下,mysql数据库的调优,其调优的主要原理是尽量减少数据库的IO操作,从而提高服务器的访问性能。在此基础上,本节内容是关于如何利用缓存,提高系统的并发访问能力。我们会首先在项目中集成caffeine本地缓存组件,通过jemeter压测工具验证本地缓存对高并发的影响。

正文

  • 添加caffeine和spring cache的pom依赖
<!-- Spring Boot Cache Starter -->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-cache</artifactId>
</dependency><!-- Caffeine Cache -->
<dependency><groupId>com.github.ben-manes.caffeine</groupId><artifactId>caffeine</artifactId><version>3.1.5</version>
</dependency>
  • 在application.yml中配置caffeine缓存
spring:cache:type: caffeinecaffeine:spec: initialCapacity=100,maximumSize=500,expireAfterWrite=5m

  • 使用@EnableCaching注解启用缓存

  • 添加一个本地缓存测试用例
@Cacheable(cacheNames = "user", key = "#p0")
@Override
public TpsUserEntity getUserByUsername(String username) {LambdaQueryWrapper<TpsUserEntity> lambdaQueryWrapper = new LambdaQueryWrapper<TpsUserEntity>().eq(TpsUserEntity::getUsername, username);return this.getOne(lambdaQueryWrapper);
}
  • 500用户,并发500的压测结果:吞吐量达到18000/sec

  •  500用户,并发1000的压测结果:吞吐量达到19000/sec

  • 500用户,并发2000的压测结果:吞吐量达到22000/sec

结语

由此可见,通过增加内存级的缓存能够大幅度提高接口的并发访问能力,对于高并发访问的接口,我们可以通过使用本地内存或者redis等内存级的数据库,提升接口的并发访问能力。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/46870.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux部署禅道(无脑复制版)

目录 环境部署1、下载&#xff0c;解压2、启动3、设置开机自启 登录禅道登录数据库1、设置账号2、网页登录数据库 环境 Linux系统 Centos7 《Linux一键安装包安装禅道》视频链接&#xff1a; https://www.zentao.net/zentao-install/zentao-linux-install-80523.html 部署 …

谢启昆:乾隆年间的清廉典范与学术巨擘

谢启昆&#xff0c;一位生活在清朝乾隆年间的杰出人物&#xff0c;以其清廉的政绩和卓越的学术成就&#xff0c;成为后世效仿的典范。他的画像中&#xff0c;目光如炬&#xff0c;透露出坚毅与智慧的光芒&#xff0c;仿佛在诉说着他不平凡的一生。 谢启昆出生在一个书香门第&am…

蒙特卡洛采样

目录 蒙特卡洛采样的计算逻辑计算步骤&#xff1a;1. 定义问题2. 确定采样范围3. 生成随机样本点4. 计算函数值5. 估计期望值或积分值6. 计算误差 具体示例&#xff1a;1. 定义问题2. 确定采样范围3. 生成随机样本点4. 计算函数值5. 估计积分值6. 计算误差 总结 蒙特卡洛采样是…

《C++ Templetes》《1、函数模板》

文章目录 1、函数模板1.1 函数模板的简单示例&#xff1a;1.2 模板参数1.3 实参演绎实参演绎的概念实参演绎的过程注意事项示例 1.4 函数模板的重载 2、总结3、参考 在《 Effective C》中第一个建议就是&#xff0c;把C看作是一个语言的联邦&#xff0c;其中Templates在联邦中留…

多元统计分析概述

目录 1. 多元回归分析 2. 主成分分析&#xff08;PCA&#xff09; 3. 因子分析 4. 判别分析 5. 聚类分析 6. 多维尺度分析&#xff08;MDS&#xff09; 结论 多元统计分析是一组用于分析多个变量之间关系的统计方法。它广泛应用于各个领域&#xff0c;如市场研究、生物医…

华为OD机试D卷 --可以处理的最大任务数--24年OD统一考试(Java JS Python C C++)

文章目录 题目描述输入描述输出描述用例1题目解析java源码js源码c++源码题目描述 在某个项目中有多个任务(用task数组表示)需要你进行处理,其中: task[i] = [si, ei] 你可以在 si ≤ day ≤ ei 中的任意一天处理该任务,请返回你可以处理的最大任务数。 输入描述 第一行…

PHP webshell 免杀方法

本文介绍php类webshell简单的免杀方法&#xff0c;总结不一定全面&#xff0c;仅供读者参考。 webshell通常可分为一句话木马&#xff0c;小马&#xff0c;大马&#xff0c;内存马。 一句话木马是最简单也是最常见的webshell形式&#xff0c;这种木马体积小&#xff0c;隐蔽较…

a newer or same version is present nvidia解决方案

安装时候出现a newer or same version is present nvidia 或者Night Visual Editor 失败&#xff0c;把显卡驱动卸载掉&#xff0c;打开service.mtc 服务控制面板&#xff0c;把nvidia开头的服务全停掉&#xff0c;重新启动cuda安装程序选择自定义安装 vse visual studio相关的…

学懂C#编程:常用框架学习(三)——.NET Framework框架下的Entity Framework (EF)开发应用详解

目录 一、Entity Framework概述 二、Entity Framework的核心组成部分 Entity Data Model (EDM)&#xff1a; Entity Client&#xff1a; Object Services&#xff1a; ADO.NET Provider&#xff1a; 三、分层结构 应用程序层&#xff1a; Entity Framework层&#xff…

鸿蒙语言基础类库:【@system.device (设备信息)】

设备信息 说明&#xff1a; 从API Version 6开始&#xff0c;该接口不再维护&#xff0c;推荐使用新接口[ohos.deviceInfo]进行设备信息查询。本模块首批接口从API version 3开始支持。后续版本的新增接口&#xff0c;采用上角标单独标记接口的起始版本。 导入模块 import dev…

linux操作fb文件节点刷纯色

代码 #include <unistd.h> #include <stdio.h> #include <fcntl.h> #include <linux/fb.h> #include <sys/mman.h> #include <stdlib.h> #include <string.h>#define RED 0xF800 #define YELLOW 0xFFE0 #define BLUE 0x0…

手把手教你,如何利用积木易搭3D扫描仪完成文物三维建模?

当前&#xff0c;文物三维建模主要技术手段主要有摄影测量技术、三维激光扫描技术、结构光扫描技术。其中&#xff0c;积木易搭的MagicScan作为一款先进的3D扫描仪&#xff0c;是正是运用了结构光扫描技术的精髓&#xff0c;它巧妙地融合了点云相机的高精度空间数据采集能力、纹…

如何用python写接口

如何用python写接口&#xff1f;具体步骤如下&#xff1a;  1、实例化server 2、装饰器下面的函数变为一个接口 3、启动服务 开发工具和流程&#xff1a; python库&#xff1a;flask 》实例化server&#xff1a;server flask.Flask(__name__) 》server.route(/index,met…

【STM32嵌入式系统设计与开发---拓展】——1_9 GPIO的输入和输出

这里写目录标题 0、输入 输出1、输出&#xff08;1&#xff09;GPIO_SetBits:用于设置 GPIO 引脚的状态&#xff08;即将指定的引脚设置为高电平&#xff09; 2、输入&#xff08;1&#xff09;GPIO_ReadInputDataBit&#xff08;&#xff09; 0、输入 输出 咋们定义了一个结构…

新手程序员如何判断自己的代码是高质量还是烂代码?

“五年工作经验&#xff0c;代码质量却不如三年程序员&#xff1f;” 这句话或许有些夸张&#xff0c;却也反映出代码质量参差不齐的现状。 那么&#xff0c;究竟什么是高质量的代码&#xff1f;如何才能写出让同行称赞、让机器流畅运行的代码呢&#xff1f; 今天我们就来聊…

服务器网络配置

后来呀&#xff0c;天亮之前毕业后踏入服务器领域了。。。。。。 服务器网络配置大体流程&#xff1a;硬件选择——系统安装——驱动调用——网卡配置 1、硬件选择 驱动程序是操作系统与硬件之间通信的桥梁 服务器硬件硬件选择首先看是否还有预留槽位&#xff0c;或者riser…

资产报废 BAPI_ASSET_RETIREMENT_POST

入参BUKRS公司代码ANLN1主资产号ANLN2资产子编号 BUDAT转资日期ANBTR已过账的金额BLDAT凭证中的凭证日期BZDAT资产价值日出参BUKRS公司代码ANLN1主资产号ANLN2资产子编号 BELNR会计凭证号码GJAHR会计年度ZBFJZ按本位币计的金额MSGTS消息类型TEXT消息文本 METHOD assets_retirem…

解决ESLint和Prettier冲突的问题

在配置了ESLint的项目中使用Prettier进行格式化可能会出现冲突&#xff0c;不如Prettier配置了使用双引号&#xff0c;ESLint配置了单引号&#xff0c;当然可以一个一个改成一样的配置&#xff0c;但是比较麻烦。我发现可以直接使用ESLint的规则进行格式化。在VSCode配置过程如…

xss复习总结及ctfshow做题总结xss

xss复习总结 知识点 1.XSS 漏洞简介 ​ XSS又叫CSS&#xff08;Cross Site Script&#xff09;跨站脚本攻击是指恶意攻击者往Web页面里插入恶意Script代码&#xff0c;当用户浏览该页之时&#xff0c;嵌入其中Web里面的Script代码会被执行&#xff0c;从而达到恶意攻击用户的…

软考从报考到拿到证书的过程

一、报考阶段及参加考试阶段 这个阶段可以留意软考官网的的信息&#xff0c;一般上半年是3月份报名、5月份考试&#xff1b;下半年是8月份报名、11月份考试。以下是这个阶段会用到的链接&#xff0c;保持关注就好。 软考官网&#xff1a;中国计算机技术职业资格网 (ruankao.o…