2022最新性能测试面试题(带答案)

news2025/1/11 12:37:01

一、性能测试开展过程:

答:第一步:找产品沟通哪些接口需要压测,需要达到什么样的预期值(TPS和响应时间)

第二步:编写测试计划,人员、时间周期、工具

第三步:环境搭建

第四步:造数据

第五步:场景测试(单接口基准测试、单接口压力测试、混合接口测试、稳定性测试)

第六步:结果分析,提交测试报告

第七步:等待开发性能调优,复测

二、交付一个性能测试项目,请阐述你的性能测试流程 (偏高级的回答)

答:1:明确测试需求

2:基于需求设计测试用例,测试方案,测试计划

3:准备测试数据,测试账号(预估并发量),设计测试脚本(参数化,表达式,断言,控制器)

4:运行测试脚本,数据监听(响应时间,tps,活动线程),结果分析(判断性能瓶颈)

5:基本性能瓶颈做调优(tomcat线程池,jvm内存,swap内存,带宽)

6:调优之后做性能回归,和前期结果做对比,是否有明显的优化。

7:代码问题优化(自己定位或者交给开发定位)

8:性能测试报告。整理性能测试数据(包括调优之前和调优之后)

9:构建持久化的性能监听平台,监听线上的服务性能

性能测试贯穿项目始终,从需求分析到上线之后,都需要持续跟踪分析发现问题,响应解决问题

三、什么是性能测试?

答:测试系统有没有性能问题

考虑时间,空间

服务端资源是否足够?

响应时间是否超时?

系统是否足够稳定?

四、性能测试的核心原则是什么?

答:基于协议,多线程,场景设计

协议:所有的请求都是基于协议发出去 http,https,udp,tcp,mqtt

多线程:压力测试是基于java多线程原理,通过线程去模拟用户的行为

基于场景:控制器+定时器设计各种场景满足压测要求

并发场景、负载场景、稳定性、压力测试

… …

五、什么是负载?有哪些负载模式?

答:负载就是对服务器迭代式加压,从而寻求性能测试拐点

1:用户模式。不断增加的用户数带来的压力

1个用户1s内发起20个请求,rps=20/s

2:请求模式,不断增加的请求数带来的压力

10个用户,1s用户1s内发起1个请求,rps=10/s

不能单纯的通用用户去衡量压力,直接通过每秒请求数去衡量压力。直接从服务端考虑

六、性能测试的应用领域有哪些?

答:1、能力验证:乙方向甲方交付项目时,声明项目的性能数据。

2、瓶颈分析:在能力验证的过程中可能会发现一些瓶颈,通过技术手段分析瓶颈,得到分析数据,为后续调优做理论依据。

3、响应超时:什么负载量的时候出现超时现象?

4、tps达到瓶颈,波动剧烈:tps瓶颈点在哪里?,在什么地方出现性能衰减?

5、性能调优:在得到瓶颈分析数据之后,做性能调优。

6、降低超时,提高tps,减少抖动。。

7、容量规划:基于未来。为将来的用户激增提前做准备

8、数据库扩容

9、服务端硬件优化(增加cpu,扩充磁盘,提升带宽,分布式,负载均衡。。。)

七、压力工具的工作原理是什么?

答:jmeter工作原理:基于协议,通过多线程的方式模拟用户行为,设计各种场景压测服务端,得到性能数据,分析性能瓶颈

八、性能测试基本思路是什么?

答:1、测什么:明确测试目标(明确需求)

2、怎么测:怎么设计场景?

测试计划,测试用例,测试方案、数据准备、参数化,表达式,断言、场景设计(并发,负载,压测)

得到性能测试结果、测试结果验证

验证结果数据是否符合预期

如果预期响应时间是3s,但是实际结果响应时间达到了5s 不合格

预期最大tps需要达到500,但是实际最大的tps只有300 不合格

八、测试哪些关键场景?

答:1、浏览器层面:

web端和app端(H5页面)

关注首屏时间(页面打开到完全呈现)

脚本加载时间,cpu占用,fps频率(帧频率越高,流畅度越高)

2、接口层面

权限划分

普通用户权限(非常多的的用户)

大并发场景:包括查询,表单提交

数据量也需要考虑(电商平台,门户网站)

负载场景:用户长期在线访问,对资源的要求会很高

3、管理员权限(几个用户)

大数据量的场景(管理几十万用户数据)

列表查询时间,分页时间

数据下载(excel,数据导出)是否会内存溢出

mysql数据库是否会死锁,sql查询是否异常

4、超管(1个)

大数据量的场景(管理几十万用户数据)

九、前端性能测试关注哪些点?了解哪些前端性能优化方法?

答:首屏时间:页面完全展现需要的时间

白屏时间:页面第一帧画面出现之前的时间

脚本加载时间,fps,cpu,network

前端性能优化:使用缓存,压缩图片,压缩js,css,gc回收优化,js前置

十、解释常用的性能指标的名称与具体含义

答:1、用户角度

响应时间(rt)从发起请求,到接口响应,到页面渲染

错误率(error)

2、 服务端角度

rps(request persecond)每秒请求数,用户发起的

tps(transaction persecond)每秒完成事物数,服务端决定的

通过rps指标,来测试tps,从而衡量服务端性能。

3、浏览器层面

qps(query perecond)每秒查询接口数(uv pv)

刷新一次页面,调用了三个接口

hps(hit persecond)每秒点击率

十一、性能测试类型有哪些?按顺序描述

答:并发数先确定

基准测试(得到性能数据,为后续的回归测试做理论依据)

单接口基准测试

容量基准测试

负载测试

不断增加负载量(压力),一直到瓶颈点出现,可以停止

压力测试

1:稳定性压测

假设瓶颈点在300tps,用对应的负载量的80%-90%做持续性(几小时或者几天)的压测。目的是发现稳定性问题(内存溢出等等)

2:破坏性压测

用对应负载量的100%或者150%做压测,直接让服务器出现异常。目的是及早的暴露问题

失效恢复测试

服务端出现异常之后能不能及时恢复

十二、什么是集合点?设置集合点有什么意义?jmeter中如何设置集合点?

答:集合点更多的运用在并发测试

为了让压力尽可能的落在同一个时间点

十三、什么是固定等待和隐式等待?

答:固定等待:超时时间=0

线程数一定要>=集合数。一定要集合完毕才发起请求

隐式等待:超时时间>0

达到超时时间范围,无论集合多少线程都会发起请求

十四、你在测试中遇到过哪些性能问题?

答:h5页面响应时间过长

h5的分页经常卡死,sql查询过多,数据量过大

导出excel时间过长,页面503,后台报内存溢出

功能涉及到算法的时候,一定要在测试环境用大量数据去模拟

只要点击,后台cpu立刻就是300%

十五、你在性能场景设计中用到哪些方法?

答:参数化,关联,断言,jdbc连接

十六、什么是关联,如何动态关联?有哪几种关联的方法?

答:正则关联,json关联,xpath关联

保证接口上下游是衔接的

十七、jmeter负载测试中怎么保持session会话?

答:KaTeX parse error: Expected group after '_' at position 2: {_̲_setProperty(co…{counter},${COOKIE_beegosessionID},)} 存储session

${__P(cookie,)} 从属性表提取session

十八、什么是Ramp up?你如何设置?

答:线程启动的时间

ramp越大,单位时间内的压力越小。ramp=0表示单位时间压力无穷大,线程启动时间无穷小。ramp=0不代表时间为0

十九、如何识别性能瓶颈?

答:随着负载不断升高,tps也是不断升高的,正常逻辑

随着负载不断增加,tps不再增加,甚至下降。表示单位线程的tps实际在衰减。tps的瓶颈点

二十、简述堆区的空间分配和gc原理

答:年轻代

1个eden

2个存活区(S1和S2)

老年代

GC(垃圾回收)

内存溢出:OOM(OUT OF memory)

1:运行内存>当前空间剩余内存

2:垃圾不能及时回收

年轻代GC:

1:最初的对象是存活在eden;伊甸园空间满了之后,会进行第一次GC;

2:第一次GC之后,依然存活的对象,会被丢到S1(第一个存活区);

3:S1初次满了之后,会进行第二次GC(年轻代GC)

4:第二次GC之后,依然存活的对象,会被丢到S2(第二个存活区),同时清空伊甸园和S1;

5:S2满了之后,会进行第三次GC,依然存活的对象,会再次被丢到S1,同时清空伊甸园和S2;

年轻代里面的垃圾碎片都是比较小;老年代的碎片比较大;

让垃圾尽可能的在年轻代里面进行回收;否则会影响老年代空间的整理;

老年代GC:

1:年轻代的GC年龄超出阈值(默认16次),会把年轻代依然存活的对象扔到老年代;

2:对象的尺寸超出了阈值;对象尺寸超出了阈值,会直接进入老年代;

3:对象的大小超出了年轻代剩余的空间大小,直接进入老年代;

老年代GC=fullGC(一般默认)

1:老年代剩余空间不足以对象进入;老年代会直接进行一次fullGC;

2:老年代的对象无法进行GC;老年代会进行一次fullGC;

老年代的对象尺寸都比较大,所以gc时间会很长,同时所有线程会出现暂停;

jvm调优是为了规避fullgc的频繁出现;会影响到tps;

jstat -gcutil pid 1000 监听gc情况

jmap -heap pid 查看内存空间分配情况

jvm参数调优

调堆内存空间,调年轻代的gc年轻,调空间分配比例(老年代:年轻代 / eden:存活区);调gc回收器,并行回收机制

二十一、什么是内存溢出?

答:1:运行需要的内存大于空间剩余内存;会出现内存溢出

2:垃圾无法进行GC;会出现内存溢出

二十二、简述cpu的工作原理

答:分析cpu参数:lscpu

CPU(s): 2 cpu个数

Thread(s) per core: 1 每核的线程

Core(s) per socket: 1 每个卡槽的核

Socket(s): 2 每个cpu的卡槽

双cpu,4核多线程;每个cpu是双核;

cpu负载和利用率

可运行的进程(双r)+不可中断的进程(block)

running(运行中的)+runnable(等待运行的)+block(等待io)=cpu的负载

利用率:cpu双线程如果都在调度java进程,表示当前cpu利用率是100%;

cpu双线程如果只有一个java进程在调度,表示当前cpu利用率是50%;

最理想的情况:每个cpu线程都调度一个java进程,此时的负载=4;

不理想的情况:java进程数远大于cpu线程数,此时负载会远远超出cpu线程数;不能及时调度的进程就会排队;

cpu会给运行中的和等待运行的进程数均匀分配时间片;

cpu调度是以时间片为基准的;假设调度时间为1ns,调度超出1ns之后,进程会被挂起;切换到下一个进程

队列越长,cpu时间片就越小,调度时间就会越短,切换的越快;切换的过于频繁,cpu利用率就会很低,线程也会暂停

进程是最小资源分配单元;

线程最小调度单元;

二十三、什么是上下文切换?哪些场景会存在上下文切换?

答:1:线程的切换

切换的时间加载寄存器和计数器

保存数据和位置信息,然后切换到下一个线程并读取它的数据和位置信息

2:进程切换

3:特权切换

系统调用(切换两次上下文)

用户空间向内核空间发起申请,内核空间返回api给用户空间调用;

二十四、什么是swap空间?oomkiller了解吗?怎么开启swap空间

答:swap:从磁盘空间开辟的虚拟用户空间。

cat /proc/sys/vm/swappiness 查看swap比例

当内存空间使用超出了比例,会启用swap空间(内存交换)

so 换出

si 换入

swapon -a 启用swap

sudo sysctl vm.swappiness=10 临时修改swappiness比例

vim /etc/sysctl.conf 永久修改swappiness比例

学习安排上

如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

在这里插入图片描述

视频文档获取方式:

这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片进群即可自行领取

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

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

相关文章

计算机操作系统

并行和并发的区别与联系? 【并发】 多个任务交替执行 计算机在运行过程中,有很多指令会涉及 I/O 操作,而 I/O 操作又是相当耗时的,速度远远低于 CPU,这导致 CPU 经常处于空闲状态,只能等待 I/O 操作完成后…

springboot项目如何启用arthas

Arthas 是Alibaba开源的Java诊断工具,深受开发者喜爱。当你遇到以下类似问题而束手无策时,Arthas可以帮助你解决: 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?我改的代码为什么没有执行到&#xff…

HTML网页设计:爱护动物题材——保护动物大象(6页) HTML网页设计结课作业 web课程设计网页规划与设计 网页设计成品DW静态网页

🎉精彩专栏推荐 💭文末获取联系 ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 💂 作者主页: 【主页——🚀获取更多优质源码】 🎓 web前端期末大作业: 【📚毕设项目精品实战案例 (10…

scConverter 文档转换 DLL / SDK

scConverter 转换 DLL / SDK scConverter 是一个DLL,可以将PDF、DWF、Gerber、CGM、TIFF、CALS、PLT、PNG和JPEG文件转换为大量输出格式。可用的输出格式列表包括Adob​​e PDF、PDF/A、DXF、DWF、CALS、TIFF、PLT和PNG。您将在下面找到所有可用输入和输出格式的完整…

R语言用向量自回归(VAR)进行经济数据脉冲响应研究分析

自从Sims(1980)发表开创性的论文以来,向量自回归模型已经成为宏观经济研究中的关键工具。最近我们被客户要求撰写关于向量自回归(VAR)的研究报告,包括一些图形和统计输出。这篇文章介绍了VAR分析的基本概念…

Java高级——后端编译与优化

后端编译与优化解释器和编译器编译器即时编译器分层编译热点代码热点探测计数器编译过程查看及分析即时编译结果提前编译器jaotc的提前编译后端编译优化总览优化演示方法内联(最重要的优化技术之一)逃逸分析(最前沿的优化技术之一&#xff09…

15. 过拟合和欠拟合

1. 过拟合和欠拟合 当数据比较简单时,使用模型容量低的模型更好,否则使用高的会出现过拟合。如果是复杂的数据用到简单模型上会出现欠拟合,用到复杂模型上是正常的。 2. 模型容量 模型容量:拟合各种函数的能力 低容量的模型难以…

Springboot+Easyexcel:导出excel表格

常规导出 常规导出excel有两种,个人比较推荐第一种: 1、新建一个导出数据的实体类,用ExcelProperty()注解标明excel中列的中文名称;如果实体的类某些列不想导出,可以使用ExcelIgnore进行忽略就可以了。 2、使用easyexc…

彻底理解Python中浅拷贝和深拷贝的区别

目录 前言 1. 浅拷贝和深拷贝的概念 2. is和的区别 3. 赋值操作 4. copy模块里面的copy()方法 5. copy模块里面的deepcopy()方法 6.字典自带的copy方法 7.切片表达式拷贝 前言 Python 的所有变量其实都是指向内存中的对象的一个指针,这确实和之前学过的强类…

JDBC基本使用(第一个jdbc程序)

在web开发中,不可避免的地要使用数据库来存储和管理数据。为了在java语言中提供数据库访问的支持,Sun公司于1996年提供了一套访问数据的标准Java类库,即JDBC。 JDBC的全称是Java数据库连接(Java Database connect),它是一套用于执…

Web3中文|AI机器人ChatGPT如何看待DeFi?

如果还没有玩过OpenAI最新的聊天机器人ChatGPT,那您真的应该体验一下。 从电影推介到编程查询,ChatGPT几乎可以对您向它提出的任何提示做出类似人类的逻辑响应。这种新奇的感觉就像乔布斯第一次滑动解锁iPhone屏幕时那样。 与加密货币一样,…

nacos配置在代码中如何引用

1、在代码的模块服务中安装nacos 配置依赖 <dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId></dependency>2、在nacos配置中心中进行服务配置 注意不是模块名&#…

LeetCode刷题复盘笔记—一文搞懂动态规划之213. 打家劫舍 II问题(动态规划系列第十八)

今日主要总结一下动态规划完全背包的一道题目&#xff0c;213. 打家劫舍 II 题目&#xff1a;213. 打家劫舍 II Leetcode题目地址 题目描述&#xff1a; 你是一个专业的小偷&#xff0c;计划偷窃沿街的房屋&#xff0c;每间房内都藏有一定的现金。这个地方所有的房屋都 围成一…

电力系统短期负荷预测(Python代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

莲花-第10届蓝桥杯Scratch选拔赛真题精选

[导读]&#xff1a;超平老师计划推出Scratch蓝桥杯真题解析100讲&#xff0c;这是超平老师解读Scratch蓝桥真题系列的第99讲。 蓝桥杯选拔赛每一届都要举行4~5次&#xff0c;和省赛、国赛相比&#xff0c;题目要简单不少&#xff0c;再加上篇幅有限&#xff0c;因此我精挑细选…

16. 模型选择,欠拟合和过拟合 代码实现

我们现在可以通过多项式拟合来探索这些概念。 import math import numpy as np import torch from torch import nn from d2l import torch as d2l1. 生成数据集 max_degree 20 # 多项式的最大阶数&#xff0c;20个特征 n_train, n_test 100, 100 # 训练和测试数据集大小…

Kafka概念以及参数

概念&#xff1a; Concept: 主题&#xff1a;Topic。主题是承载消息的逻辑容器&#xff0c;在实际使用中多用来区分具体的业务。 Subject: Topic. A topic is a logical container that carries messages. In practice, it is often used to distinguish specific services.…

[附源码]计算机毕业设计的高校车辆租赁管理系统Springboot程序

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

在软件定义网络中使用机器学习的方法进行 DDOS 攻击检测与缓解--实验

在软件定义网络中使用机器学习的方法进行 DDOS 攻击检测与缓解--实验〇、拉取代码一、 配置环境二、 正常流量收集三、攻击流量数据四、DDoS攻击检测与缓解4.1 正常流量的检测4.2 攻击流量的检测与缓解五&#xff0c;精准度和检测率申明&#xff1a; 未经许可&#xff0c;禁止以…

Existence theorem

In mathematics, an existence theorem is a theorem which asserts the existence of a certain object.[1] It might be a statement which begins with the phrase “there exist(s)”, or it might be a universal statement whose last quantifier is existential (e.g., …