性能测试面试题汇总
稳定性测试的怎么挑选的接口?
1、频繁使用的接口:选择那些被频繁使用的接口,因为这些接口可能会面临更大的负载和并发访问,从而可能导致性能问题。
2、核心功能接口:选择那些实现系统核心功能的接口,因为这些接口的故障可能会导致整.个系統的故障。
3、外部依赖接口:选择那些与外部系统通信的接口,例如第三方 APl数据库、消息队列等等,因为这些接口的稳定性可能对系统整体性能和可用性产生影响。
4、流量高的接口:选择那些通常会有高流量负载的接口进行测试,这些接口可能会在高峰期经历高负载,而测试它们可以验证系统是否能够在高负载情况下正常运行。
5、关键路径接口:选择那些在系统关键路径上的接口,因为这些接口可能会导致系统性能下降或系统故障。
6、据库交互的接口:选择那些与数据库交互的接口进行测试,这些接口会产生数据库负载。测试这些接口可以确保系统能够稳定地处理数据库交互,而不会出现性能问题。
7、消息队列接口:这些接口允许不同的应用程序或模块之问异步地发送消息。在稳定性测试中,需要验证消息队列接口是否能够处理高并发的消息传递请求。
8、长时问运行的接口:这些接口通常需要较长的处理时间,如长时问查询、批量处理等。这些接口可能会在运行期间出现性能问题或故障。
性能测试中常见的指标有哪些?
1、响应时问 (Response Time):从用户发起请求到收到响应的时间,通常以毫秒为单位。这是衡量系统性能的关键指标之一。
2、吞吐量 (Throughput):单位时间内能够处理的请求数量。通常以每秒钟处理的请求数量(TPS) 来衡量。
3、并发用户数(Concurrency):同时处理的用户数,可以用于确定系统在负载压力下的承载能力。
4、CPU使用率 (CPU Utilization):系统中CPU的占用率。
5、内存使用率 (Memory Utilization) :系统中内存的占用率。如果内存使用率过高,可能会导致系统变慢或崩溃。
6、网络延迟 (Network Latency):发送请求和接收响应之问的时间差。这通常是网络速度和响应时间的重要组成部分。
7、错误率(Error Rate) :处理请求时发生错误的百分比。这对于确定系统是否可靠和稳定非常重要。
8、磁盘使用率 (Disk Utilization) :系统磁盘的占用率。
性能测试如何发现并定位到数据库的问题?
以项目是多个微服务+MysQL数据库为例:可以基于promethues+gratana+mysql_exporter监控mysal数据库性能指标,同时使用skywalking 做mysal的链路监控,如果检测到在数据库层面消耗时间过长,可以结合 profiling 工具分析如下性能指标:
1、连接数:同时连接到MySQL服务器的客户端数量。
2、查询数和查询响应时问:MySQL服务器接收到的查询数量和查询响应时间。
3、缓存命中率:查询在查询缓存中找到的百分比。
4、锁定等待时间:等待锁定的时问长度,包括共享锁和排它锁等待的时问。
5、磁盘使用率:MysQL服务器对磁盘进行读取和写入操作的使用率。
6、内存使用率:MySQL服务器使用的系统内存占总内存的百分比。
7、CPU使用率:MySQL服务器使用的CPU占总CPU 使用率的百分比。
8、慢查询数量和响应时间:查询执行时 间超过指定时间阈值的查询数量和响应时间。
9、错误日志:记录 MySQL服务器发生错误的日志,可以通过分析错误日志来了解MySQL服务器的问题。
10、慢查询日志:记录执行时间超过指定时间阈值的查询的日志,可以通过分析慢查询日志来了解MySQL服务器的查询问题。
以上性能指标出现问题都可能导致系统整体性能下降,借助工具进一步定位是SQL问题、锁定阻塞问题还是索引、表设计问题。
如何开展性能测试?
1、进行性能测试需求调研和准备
在进行性能测试之前,需要先了解测试的目标、需求和限制,以确保测试可以精准地反映实际场景。通常需要了解系统的架构、用户数量、交互类型、使用频率等信息。同时,需要组建性能测试团队并选择适合的测试工具和环境。
2、确定性能测试范国、方法和目标确定测试范围可以帮助测试人员集中精力测试关键场景,而不是无脑地测试每个功能。性能测试方法通常包括负载测试、压力测试、容量测试、稳定性测试等。针对每个测试方法,需要设定相应的性能测试目标,例如响应时间、,吞吐量、并发用户数、资源利用率等。
3、构建业务模型
基于实际的业务场景和用户行为,需要构建业务模型,模拟实际用户在系统中的操作。通过分析系统的访问日志,可以了解用户的行为模式、操作频率、访问路径等信息,从而构建出合适的业务模型。
4、编写性能测试方案
性能测试方案是性能测试的核心,它包括了测试的范围、方法、目标、测试场景、测试数据、测试工具、测试计划和执行流程等内容。根据项目的架构和业务特点,编写出详细的性能测试方案。
5、进行前端页面性能监控及分析
使用 Dynatrace Ajax Edition 等工具,可以对系统的前端页面进行性能监控和分析。通过监控页面的加载时问、资源请求、JavaScript执行等关键指标,可以深入了解前端页面的性能表现,并及时发现潜在的性能问题。
6、实施性能测试
基于 Jmeter、Locust、 Loadrunner等性能测试工具,开发性能测试脚本并设计测试场景,设置测试参数和指标监控,执行性能测试,收集测试数据并进行分析。在测试过程中,需要及时记录测试日志,包括测试结果、性能指标、错误信息等。
7、搭建性能监控平台
使用 Docker、Promethues、Grafana、InfluxDB、 Exporter、Skywalking 等开源工具,可以搭建一个完整的性能监控平台。通过对系统各个组件的监控和分析,可以深入了解系统的性能
8、代码瓶颈定位
如果监控到可能是代码级的瓶颈,可以基于JisualVM、Arthas等监控工具进行代码级监控及瓶颈定位。
9、根据要求生成相应的 《性能测试报告及优化方案》。
性能测试压力上不去的原因有哪些?
性能测试压力无法达到预期值的原因可能有多种,以下是一些常见的原因:
1、脚本设计不合理:脚本使用的语言或者逻辑过于复杂导致压力机出现瓶颈,比如数据加密等操作。
2、资源限制:测试环境的资源限制可能导致无法模拟预期的负载。例如,压力机的CPU、内存或网络带宽可能不足以支持生成所需的负载。
3、被测系统本身性能问题:被测系统本身可能存在性能问题,导致性能测试无法达到预期的负载水平。例如,应用程序中存在性能瓶颈,数据库操作不够高效,代码实现存在死循环、内存泄漏等问题等。
4、数据问题:测试数据的大小、分布和内容可能会影响负载测试的结果。测试数据可能过于简单或过于复杂,导致无法模拟真实的负载。
5、测试工具问题:测试工具可能存在问题,…例如无法正确处理多线程、网络延迟等情况,导致无法生成预期的负载。LoadRunner、Jmeter、Locust相同的用户数压力可能就不一样。
6、网络问题:测试环境与实际生产环境之问的网络差异可能会影响性能测试结果。例如,生产环境可能存在更多的网络延迟、丢包和带宽限制。
7、未考虑实际使用场景:性能测试可能未考虑实际使用场景。例如,测试可能过于 专注于单个功能或单个用户,而实际上需要考虑多个用户和复杂的工作流程。
8、测试过程错误:测试过程可能存在错误,例如测试用例不准确、测试数据不充分、测试环境设置不正确等等,导致无法生成预期的负载。
9、数据库或其他第三方服务的性能问题:如果被测系统依赖于其他服务,比如数据库或第三方服务,那么这些服务的性能问题也可能会影响到被测系统的性能测试结果。
性能面试的主要几个考核问题
可以通过下面的问题考核一下:
1、如何判断系统性能是否存在瓶颈?
2、针对容量场景,如何设计业务模型?
3、压力上不去的原因可能有哪些?
4、性能脚本是否加思考时间?
5、一台压力机可以运行多少线程?
6、性能监控方案是什么设计的?
7、怎么定位内存泄露的问题?
8、针对多个微服务项目如何全链路监控?
9、写过性能测试方案?包含哪些内容?
10、如何判断Linux内存不足?
相关文章:

性能测试面试题汇总
稳定性测试的怎么挑选的接口? 1、频繁使用的接口:选择那些被频繁使用的接口,因为这些接口可能会面临更大的负载和并发访问,从而可能导致性能问题。 2、核心功能接口:选择那些实现系统核心功能的接口,因为这…...

vue权限控制和动态路由
思路 登录:当用户填写完账号和密码后向服务端验证是否正确,验证通过之后,服务端会返回一个token,拿到token之后(我会将这个token存贮到localStore中,保证刷新页面后能记住用户登录状态)…...

利用正则表达式删掉代码中的所有注释-pycharm为例
首先删除注释 打开您想要删除注释的Python文件。 使用快捷键 Ctrl Shift R 打开 "Replace in Files"(在文件中替换)对话框。 在 "Find"(查找)框中输入以下正则表达式,以查找所有行中的注释内容…...

【java基础】内部类、局部内部类、匿名内部类、静态内部类
内部类 内部类就是定义在另一个类中的类。我们使用内部类的原因主要有以下两点 内部类可以对同一个包中的其他类隐藏内部类方法可以访问定义这个类的作用域中的数据,包括原本私有的数据 public class A {class B {} }我们使用内部类可以访问外部类的所有属性&…...

react renderProps学习记录
react renderProps学习记录1.引入2.改一下呢3.再改一下呢4.总结一下如何向组件内部动态传入带内容的结构(标签)?children propsrender props1.引入 上代码: import React, { Component } from react import ./index.css export default class Parent extends Com…...

关于tf.gather函数batch_dims参数用法的理解
关于tf.gather函数batch_dims参数用法的理解0 前言1. 不考虑batch_dims2. 批处理(考虑batch_dims)2.1 batch_dims12.2 batch_dims02.3 batch_dims>22.4 batch_dims再降为12.5 再将axis降为12.6 batch_dims<02.7 batch_dims总结3. 补充4. 参数和返回值5. 其他相关论述6. 附…...

日常操作linux常用命令
cd /mnt/opt/cqstt/logs/stt-erp docker logs -f --tail1000 stt-erp # 查看物理CPU个数 cat /proc/cpuinfo| grep "physical id"| sort| uniq| wc -l # 查看每个物理CPU中core的个数(即核数) cat /proc/cpuinfo| grep "cpu cores"| uniq # 查看逻辑CPU的…...

【Java集合框架】篇二:Collection接口方法
JDK不提供此接口的任何直接实现类,而是提供更具体的子接口(如:Set和List)去实现。 Collection 接口是 List和Set接口的父接口,该接口里定义的方法既可用于操作 Set 集合,也可用于操作 List 集合。方法如下…...

PHP入门指南:简单易学的语法和丰富的调试工具与安全性最佳实践
PHP是一种非常流行的服务器端编程语言,它被广泛地应用于Web开发中。如果您想学习Web开发,那么PHP是一个非常好的选择。在本文中,我将介绍PHP的一些基础知识,包括语法、变量、函数、数组、数据库连接、调试和安全性等。PHP的语法PH…...

前端面试题--HTML篇
一、src和href的区别src指向外部资源的位置,指向的内容会嵌入到文档中当前标签所在的位置;href指向网络资源的位置,建立和当前元素或当前文档之间的链接。二、对HTML语义化的理解根据内容的结构化,选择合适的标签。优点࿱…...

SpringBoot集成ElasticSearch,实现模糊查询,批量CRUD,排序,分页,高亮
导入elasticsearch依赖在pom.xml里加入如下依赖:<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-elasticsearch</artifactId> </dependency>非常重要:检查依赖版本…...

常用Swagger注解汇总
常用Swagger注解汇总 前言 在实际编写后端代码的过程中,我们可能经常使用到 swagger 注解,但是会用不代表了解,你知道每个注解都有什么属性吗?你都用过这些属性吗?了解它们的作用吗?本文在此带大家总结一下…...

关于 TypeScript 声明文件
declare var 声明全局变量declare function 声明全局方法declare class 声明全局类declare enum 声明全局枚举类型declare namespace 声明(含有子属性的)全局对象interface 和 type 声明全局类型export 导出变量export namespace 导出(含有子…...

SpringBoot学习-原理篇
SpringBoot原理篇springboot技术本身就是为了加速spring程序的开发的,可以大胆的说,springboot技术没有自己的原理层面的设计,仅仅是实现方案进行了改进。将springboot定位成工具,你就不会去想方设法的学习其原理了。就像是将木头…...

目标检测YOLOv5数据集怎么找?
完整的配置-标注-训练-识别在我这篇博客小白YOLOv5全流程-训练实现数字识别_yolov5数字识别_牛大了2022的博客-CSDN博客 模型部分剖析可以看我每周深度学习笔记部分。关于训练的数据集怎么搞很多人问过我,我在这篇文章给大家一点我的经验和建议。 数据集是什么 简…...

安卓短信自动填充踩坑
安卓短信自动填充踩坑 前言 最近弄了个短信自动填充功能,一开始觉得很简单,不就是动态注册个广播接收器去监听短信消息不就可以了吗?结果没这么简单,问题就出在机型的适配上。小米的短信权限、荣耀的短信监听都是坑,…...

【抽象类和接口的区别】
抽象类和接口都是Java中实现多态的机制,它们都是用来约束子类必须要实现的方法。但是它们有以下区别: 实现方式 实现方式:抽象类是一个类,而接口是一个接口。一个类只能继承一个抽象类,但可以实现多个接口。 构造方…...

接口导出文件功能
1.写接口 export function getExport(params) { return fetch({ url: ******.export, method: post, data: params, responseType:blob, }) } 2.编写前端页面 <el-button :loading"exportDisable" :disabled&quo…...

深圳大学计软《面向对象的程序设计》实验9 期中复习
A. 机器人变身(类与对象)【期中模拟】 题目描述 编写一个机器人类,包含属性有机器名、血量、伤害值、防御值、类型和等级。其中血量、伤害和防御和等级、类型相关: 普通型机器人,类型为N,血量、伤害、防…...

python之异步编程
一、异步编程概述 异步编程是一种并发编程的模式,其关注点是通过调度不同任务之间的执行和等待时间,通过减少处理器的闲置时间来达到减少整个程序的执行时间;异步编程跟同步编程模型最大的不同就是其任务的切换,当遇到一个需要等…...

为什么很多计算机专业大学生毕业后还会参加培训?
基于IT互联网行业越来越卷的现状,就算是科班出身,很多也是达不到用人单位的要求。面对这样的现实情况,有的同学会选择继续深造,比如考个研,去年考研人数457万人次,可见越来越的同学是倾向考研提升学历来达到…...

JUC并发编程之JMM_synchronized_volatile
目录 JUC并发编程之JMM_synchronized_volatile 什么是JMM模型? JMM和JVM的区别 JMM不同于JVM内存区域模型 主内存 工作内存 Java内存模型与硬件内存架构的关系 JMM存在的必要性 数据同步八大原子操作 同步规则分析 并发编程的可见性,原子性与有序…...

hashCode 和 equals 的处理
文章目录hashCode 和 equals 的处理1. 阿里巴巴编程规范要求2. equals和hashcode的分析2.1 Object方法2.2 只覆写(Override)equals带来的问题问题演示问题分析问题处理hashCode 和 equals 的处理 1. 阿里巴巴编程规范要求 2. equals和hashcode的分析 2…...

17. OPenGL实现旋转移动物体
1. 说明: 整体思路:如果想实现动态,可以使用一个矩阵和我们给定的坐标值进行相乘,实时的改变坐标值 类似于坐标的齐次变换,然后使用一个定时器,在规定时间内触发重新绘制的函数。 实际效果: OP…...

《SQL基础》14. 存储过程 · 存储函数
存储过程 存储函数存储过程基本语法变量系统变量用户定义变量局部变量if判断参数case判断while循环repeat循环loop循环游标条件处理程序存储函数存储过程 存储过程是事先经过编译并存储在数据库中的一段SQL语句的集合。调用存储过程可以简化应用开发人员的工作,减…...

NFT Insider #87:The Sandbox 收购游戏开发工作室 Sviper,GHST 大迁徙即将拉开帷幕
引言:NFT Insider由NFT收藏组织WHALE Members(https://twitter.com/WHALEMembers)、BeepCrypto(https://twitter.com/beep_crypto)联合出品,浓缩每周NFT新闻,为大家带来关于NFT最全面、最新鲜、最有价值的讯息。每期周…...

html部分codewhy网课学习笔记
day1 网页显示的过程和服务器 浏览器内核,也称为渲染引擎 head标签描述网页的原数据,如title shifttab是向前缩进 div>ul>li可以快速生成 <div> <ul> <li></li> </ul> </div> 在早期,单标签如<input>也可写为&l…...

电脑出问题了怎么重装系统修好
电脑在使用过程中经常会出现各种各样的问题,如系统崩溃、蓝屏、病毒感染等。这些问题如果不能及时得到解决,将会给用户带来很多麻烦和损失。小白一键重装系统是一个功能强大的工具,可以帮助用户快速解决电脑常见问题。下面我们就来详细介绍如…...

Nginx国密支持问题记录
文章目录添加国密支持可能出现的问题国密不生效,查看 Nginx 可执行文件路径是否正确证书无法解析Nginx无法启动添加国密支持 NGINX添加国密支持 添加国密支持可以直接按照官网的操作顺序操作即可 参考网址:https://www.gmssl.cn/gmssl/index.jsp 可能出…...

基于ensp的小型局域网网络搭建及需求分析
一 需求分析本实验的目的在于建立小型局域网。由于公司由财政部、人事部、科技部三个部门组成,分布在同一个交换机下。设计以下网络:三个个部门使用两台交换机连接,然后连接到汇聚交换机,再通过路由器与外网以及其他部门网络相连。…...