大家好,我是懂Java的测试。
本科毕业于武汉某二本普通院校,本人16年开始工作,曾任职上海哔哩哔哩科技有限公司(B站)高级测试开发,目前在一家云计算公司担任测试工程师,日常工作比较繁杂,主要负责功能测试,自动化测试,性能测试以及测试工具的开发。
工作六年左右,参与大大小小的面试将近100多场,拿到过货拉拉、众安保险、得物、网易和百度等公司的offer,所以在测试工程师日常学习、面试等方面具备丰富的经验,又加上最近“金三银四”,所以想把最近几年积攒的部分面试题和答案分享给大家,后期看文章热门程度,再陆续分享其他面试题和答案。
一.基础题
1.测试用例你一般是怎么设计的,怎么可以提高覆盖率?
有没有形成自己的 一套方法论?
答:这些都是基础的理论题。
2.电梯、朋友圈、红包、登录功能是怎么测试的?用例设计
答:这些都是基础的用例设计题目,网上一大堆,建议面试前多准备几个,总结其中的规律。
3.假如让你独立负责一个大项目,你是如何开展测试的?
答:可以理解为如何保障产品质量,从需求分析理解、用例设计和评审、测试bug提交和跟踪、上线验证、项目复盘等等方面回答。
4.接口测试你是怎么做的?都发现了哪些问题,详细说下定位分析过程。
5.测试过程中你遇到最难的一个技术问题是什么?如何解决的?
答:面试前重点准备一个类似的题目,比如开发了测试工具,提高效率,搭建自动化框架或平台,引入了测试覆盖率工具、代码检测工具等等
6.你们整个测试流程是怎样的?
答:大致分为以下几种测试需求分析阶段、测试计划阶段、测试设计阶段、测试执行阶段、测试评估阶段。
二.网络相关
http和https ,tcp 和udp协议区别,网络七层模型,
答:HTTPS和HTTP的区别主要如下:
tcp 和udp协议区别:
网络七层模型:
2.tcp 为啥三次握手,为啥四次挥手,
答:因为当Server端收到Client端的SYN连接请求报文后,可以直接发送SYN+ACK报文。其中ACK报文是用来应答的,SYN报文是用来同步的。但是关闭连接时,当Server端收到FIN报文时,很可能并不会立即关闭SOCKET,所以只能先回复一个ACK报文,告诉Client端,"你发的FIN报文我收到了"。只有等到我Server端所有的报文都发送完了,我才能发送FIN报文,因此不能一起发送。故需要四步握手。
3.tcp 拥塞算法、滑动窗口、重传机制、粘包和拆包
答:滑动窗口协议(Sliding Window Protocol)、重传机制详情见
TCP 滑动窗口/快速重传机制_Shawei_的博客-CSDN博客_tcp快速重传机制 。
拆包 :TCP直接将应用层数据包(可以认为就是一个数组)发给接收方,并且根据TCP协议,TCP会将每个发送的数据包编号(序列号),发送完一个序列号后,接收端收到会回复该序列号,代表已经被接受,but 接收端有自己的TCP缓存区,它会将多个包积累在一起再进行处理,这样的结果是导致包与包之间“无缝连接”,即所谓的”粘包“
粘包:针对此问题,就有了一些解决办法:哪每个包长度固定:这样接收端就可以每隔一定长度进行拆包,但缺点是浪费资源,加入头部信息:每个数据包前加入该数据包中数据的长度值,这样接收端从缓存中读取时,通过读该头部信息,知道了每个包的长度,这样就能拆包
4.一些抓包工具如fidder、tcpdump的使用,
答:网上都有现成的使用教程,可以选一两篇去操作下。
5.浏览器输入百度网址发生了什么?DNS解析过程
答:这个问题比较宽泛,整个流程也比较长,涉及到网络7层模型、dns解析、tcp/ip协议簇,三次握手、负载均衡、集群架构、数据库,linux 系统状态、进程切换等等方面,看你自己对哪块比较熟悉,重点去说
6.说下cookies,session鉴权机制?为什么要引入这套机制?
答:
引入原因:HTTP 是无状态的协议(对于事务处理没有记忆能力,每次客户端和服务端会话完成时,服务端不会保存任何会话信息):每个请求都是完全独立的,服务端无法确认当前访问者的身份信息,无法分辨上一次的请求发送者和这一次的发送者是不是同一个人。所以服务器与浏览器为了进行会话跟踪(知道是谁在访问我),就必须主动的去维护一个状态,这个状态用于告知服务端前后两个请求是否来自同一浏览器。而这个状态需要通过 cookie 或者 session 去实现。
三.数据库重中之重
简单
1、基本的增删改查语句;
答:insert、delete、update、select sql编写。
2、多表联合查询、左右连接区别、子查询等;
答:网上都有教程,可以自行查找,在这里不做赘述。
3、聚合、分组、排序sql语句编写、having和where 区别
答:表数据
sql 编写:
SELECT
class 班级名称,
COUNT(*) 每个班级人数,
MAX(grade) 最高分,
MIN(grade) 最低分,
SUM(grade) 班级总分,
AVG(grade) 平均分
FROM
student
where age <20
GROUP BY
class
HAVING SUM(grade) >=34
ORDER BY
最高分 DESC
执行结果:
4、char 和varchar区别等
答:varchar;表示变长字符串,char;定长字符串。
5、三范式是什么?
答:第一范式(确保每列保持原子性)、第二范式(确保表中的每列都和主键相关)、第三范式(确保每列都和主键列直接相关,而不是间接相关)
中级
1、说一下sql是怎么优化的?
答:show variables like '%quer%'; 查询慢查询日志相关的设置,找出慢查询的sql ,用explain查询sql的执行计划,该加索引的加索引(要知道索引正确使用场景如下面试题),尽量少 连接查询、select *、避免类型转换,减少回表次数。
2、索引的概念、类型,优缺点分析、索引应用场景和索引失效场景;
答:索引是帮助mysql高效获取数据的数据结构
优点:
a)可以保证数据库表中每一行的数据的唯一性,
b)可以大大加快数据的检索效率,
c)加速表与表之间的连接,
d)在使用分组和排序子句进行数据检索时,同样可以显著减少查询中分组和排序的时间。
f)通过使用索引对数据进行排序,降低数据排序的成本,降低cpu的消耗,可以在时间查询的过程中,使用优化隐藏器,提高系统的性能。
缺点:
a) 创建索引和维护索引要耗费时间,这种时间随着数据量的增加而增加。
b) 索引会占据磁盘空间。
c) 以表中的数据进行增、删、改的时候,索引也要动态的维护,这就降低了整数的维护速度。
索引类型:
主键索引:索引列中的值是唯一的并且不允许有空值
普通索引:mysql的基本索引类型,没有什么限制,允许有重复值和空值
唯一索引:索引列中的值是唯一的,但是允许有空值
还有其他索引 譬如全文索引、空间索引、前缀索引等不常见
4、mysql 几个存储引擎,innodb 和MyISAM区别
答:MySQL有多种存储引,MyISAM、InnoDB、MERGE、MEMORY(HEAP)等
InnoDB 和MyISAM 区别:
1). InnoDB 支持事务,MyISAM 不支持事务。这是 MySQL 将默认存储引擎从 MyISAM 变成 InnoDB 的重要原因之一;
2). InnoDB 支持外键,而 MyISAM 不支持。对一个包含外键的 InnoDB 表转为 MYISAM 会失败;
3). InnoDB 是聚集索引,MyISAM 是非聚集索引。聚簇索引的文件存放在主键索引的叶子节点上,因此 InnoDB 必须要有主键,通过主键索引效率很高。但是辅助索引需要两次查询,先查询到主键,然后再通过主键查询到数据。因此,主键不应该过大,因为主键太大,其他索引也都会很大。而 MyISAM 是非聚集索引,数据文件是分离的,索引保存的是数据文件的指针(就是物理地址)。主键索引和辅助索引是独立的 。
注意:MyISAM 无论是主键还是非主键索引 ,data存储的都是这条数据的物理地址(地址指针),innodb 主键索引的data就是这条数据,非主键索引的data是主键id,
高级
1.索引底层机制,B+树特性,和其他数据结构(二叉树、红黑树)区别,
答:这个属于高级特性,后续公众号会重点输出数据库相关的知识和面试题
2.mysql事务隔离级别、MVCC 是什么,
答:MVCC ,Multi-Version Concurrency Control,多版本并发控制。MVCC 是一种并发控制的方法,一般在数据库管理系统中,实现对数据库的并发访问;在编程语言中实现事务内存
3.数据库锁类型,什么是数据库死锁,如何避免?
答:从数据库系统角度分为三种:排他锁、共享锁、更新锁。
从程序员角度分为两种:一种是悲观锁,一种乐观锁,等等
避免死锁方式:
结构化数据建模:基于范式原则初级建模
热点业务排解:挖出核心业务模型
应用拆解:降低时间片复杂度
提升性能:优化代码,集群、超时机制、回滚机制
4.主从底层数据同步机制、binglog、redolog、undolog区别,
答:redo log:确保事务的持久性。防止在发生故障的时间点,尚有脏页未写入磁盘,在重启mysql服务的时候,根据redo log进行重做,从而达到事务的持久性这一特性。undo log:回滚日志保存了事务发生之前的数据的一个版本,可以用于回滚,同时可以提供多版本并发控制下的读(MVCC),也即非锁定读binlog:二进制日志作用:用于复制,在主从复制中,从库利用主库上的binlog进行重播,实现主从同步。 用于数据库的基于时间点的还原。
四.开发语言,java这块后续我会陆续推出一些java基础专栏,
面对对象三大特性、通俗解释,八大基本数据类型及其大小,循环、判断等语法
2.java集合 如arraylist、linkedlist、hashmap等特性和底层实现原理 ;
3.java锁类型,线程安全、线程池、juc并发组件、反射等;
4.Jvm内存结构,不同版本区别,gc方法,调优,命令等等;
5.springboot、spring、mybatis等框架的使用和常见面试题
6.单例、工厂、适配器等设计模式
7.zk、dubbo、springcloud等相关java框架是否接触过?底层原理
8.分布式事务、分布式锁、幂等性等常见分布式问题是否了解?解决方式?
五.自动化,这块是面试官重点去考察的地方,
1.自己开发的自动化框架吗?为啥要开发这么一个框架呢?市面上很多自动化平台为什么不用,却要自己搭建?想过投入产出比吗?
答:自己搭建,主要是项目每次上线之前,回归重复的功能占用大量迭代时间,通过自动化框架可以节约时间,市面上的测试平台得自己部署和维护,出现问题需要自己去查底层代码解决,学习门槛较高,并且很多功能几乎用不到,自己搭建的自动化框架,开发相对简单,上手特别快,特别符合当前的项目需要。
2.说下接口自动化分别用了哪些框架,怎么实现的,你主要负责哪些部分?
答:我的主要是springboot、testng、mysql、okhttpcilent、mq 那套东西。
3.你们这套框架最难的技术点有哪些?搭建框架过程中遇到哪些问题,怎么解决的?
答:难点技术有很多,譬如失败用例重跑机制,异步接口校验返回结果,场景测试中前置依赖接口怎么处理,涉及到mq 怎么操作等等
4.流程场景怎么设计用例的?假如流程比较长,你怎么保障前面流程成功?
答:可以引入失败用例重跑机制 testng有接口实现、简单接口,我们可以直接在数据库造数据。
5.数据放哪的?数据驱动怎么做的?关键字驱动怎么做的?
答:看情况,如果是灵活的数据,建议放在excel里面,做数据驱动,如果是账号、密码这种修改很少的数据,可以考虑放在配置文件中,如果是那种一成不变的可以写死(尽量别这么做)。
关键字驱动:测试用例的步骤(元素)和用例分离。关键字驱动表示把项目中的一些逻辑封装成关键字(一个函数名)。例如login、 register、order进行设置变量(Set Viriable),调用不同的关键字组合实现不同的业务逻辑,从而驱动测试用例执行。
数据驱动:数据和用例步骤分离,通过excel、yaml等文件保存数据。数据驱动是把测试用例里面的数据提取到excel或者yam文件里面,然后通过改变excel或yaml中的数据驱动测试用例执行。
6.这套框架覆盖了开发多少业务代码,怎么统计出来的?多少用例,跑一次多长时间?
答:主要覆盖所负责业务的主要流程和一些常见的异常流程,通过jacoco 覆盖率统计工具统计出来的,用例大概有100+个,涉及到30多个接口,跑一次将近2分钟左右。
7.开发修改接口和你的自动化代码怎么同步修改,以保证自动化测试代码不报错?
答:依靠规范、或者技术手段。
六.性能测试重中之重,内容包罗万象,涉及到性能测试方式、策略、监控、分析调优等方面
1.你们公司性能测试怎么做的,说一下流程?
答:基本流程就是产研测三方开会、一起定下tps基准值,测试设计性能测试计划和测试用例、用例评审、进行压测、观测数据找出性能瓶颈,调优持续压测等等
2.TPS上不去什么原因,怎么排查?响应时间太长怎么分析?
答:通过各种监控技术如prometheus 、skywalking等 观测系统瓶颈,基本上分为一下几个方面 带宽、连接池、硬件、垃圾回收机制、数据库等方面去分析。
3.线程阻塞和死锁问题怎么去定位分析,有什么现象?
答:在发生死锁之后,程序卡住没有任何反应,但程序仍在运行,因此需要借助一些命令来排查,用JDK自带的命令jstack -pid去查看线程信息,jstack很快就帮我们找到了死锁的位置(在实际运行中,往往dump一次信息,还不足以确认问题,建议多dump几次,如果每次dump都指向同一个问题,那么就可以确定是这个问题导致的线程死锁)
4.内存泄露和内存溢出有什么区别?分别会有什么现象?怎么定位分析?
答:内存溢出(Out Of Memory) :就是申请内存时,JVM没有足够的内存空间。通俗说法就是去蹲坑发现坑位满了。
内存泄露 (Memory Leak):就是申请了内存,但是没有释放,导致内存空间浪费,通俗点就是占着那啥不那啥。
5.数据库是怎么监控的,sql慢查询怎么监控分析?
答:见数据库sql优化面试题。
6.如何进行全链路监控分析,定位性能瓶颈?
答:自行百度
7.压测线上环境都会遇到什么问题,数据隔离怎么做的?如何减小对生产影响?
答:脏数据影响真实的业务响应和数据,可以考虑落入影子库,mock对象、或者数据带有明显标识等手段。
8.测试过程中都发现了哪些性能问题,怎么定位分析的?优化方案是什么?
答:每个人准备的问题不一致,我的就是遇到了jvm fullgc频繁导致接口响应时间慢,通过java一些命令定位分析发现jvm配置不合理。
9.项目架构是怎么样的?简单描述或者画图
答:微服务架构,两个入口、公众号和web端,请求先经过Nginx做负载均衡、流量均匀的打到项目的api网关,后面就是项目的微服务架构(采购单、供应商、库存、仓库物流等等)如果对后端采用的架构熟悉,可以顺带提一下,比如用了springcloud 全家桶、eureka做服务注册和发现,mq实现异步解耦,redis缓存有效减少数据库交互等等。
七.中间件相关问题,简历如果说了,面试官一般都会顺带问下
1.正向代理和反向代理区别?Nginx了解吗?负载均衡算法
答:Nginx是一款自由的、开源的、高性能的HTTP服务器和反向代理服务器;同时也是一个IMAP、POP3、SMTP代理服务器;Nginx可以作为一个HTTP服务器进行网站的发布处理,另外Nginx可以作为反向代理进行负载均衡的实现。
正向代理:服务器位于客户端和服务器之间,为了从服务器获取数据,客户端要向代理服务器发送一个请求,并指定目标服务器,代理服务器将目标服务器返回的数据转交给客户端。这里客户端需要要进行一些正向代理的设置的。举例:翻墙,正向代理中被代理的是客户端的请求
反向代理:客户端对代理是无感知的,客户端不需要任何配置就可以访问,客户端将请求发送到反向代理服务器,由反向代理服务器去选择目标服务器获取数据后,在返回给客户端,此时反向代理服务器和目标服务器对外就是一个服务器,暴露的是代理服务器地址,隐藏了真实服务器IP地址。
负载均衡算法:轮询、随机、最少连接、hash、加权等,说一下具体使用场景
2.mq是如何测试的?你项目中怎么应用的?mq的优缺点?为什么使用mq?怎么保障mq消息的有序性、幂等性、可靠性(不丢失)
答:消息中间件 具备解耦、削峰、异步的作用,具体可自行百度
3.为什么使用redis,redis五种数据类型,如何测试redis的,项目中如何应用的?
答:基于内存查询效率高,高并发情况下保护数据库,string、hash、list、set、zset五中数据类型,项目中主要用于请求token 保存和失效,防重分布式锁,冷数据(改动量小)保存,幂等性校验等等。
4.都发现过哪些缓存方面的bug,怎么定位的?
答:缓存和数据库数据不一致,缓存穿透,击穿,雪崩等
5.redis穿透,击穿,雪崩机制,被问了好几次......
答:自行百度
八.算法,一些大厂必问,百度、阿里、字节、腾讯等
1.常见的排序算法,冒泡,快排等
2.数组,字符串的相关算法操作比如找一个字符串中重复最长的字符串、两数之和等
3.简单的数据结构栈,队列,链表的基本的操作等
算法这块没有捷径,需要日积月累,一些常见的算法题,尽量在理解的基础上去默写并记熟,有些网站牛客网、LeetCode刷刷题加强一下。
九.其他
假如测试任务重,时间紧,但是人手不够你怎么处理?
答:向上反馈真实情况、加派人手、争取更多时间或削减不必要需求,测试中要充分理解需求,设计用例加强评审,需求排优先级等等
2.假如开发不认可你提出bug,怎么办?
答:自己重新复现一下提出的bug,如果确实是bug,可以和开发当面沟通清楚,沟通无效则向上反馈。
3.线上有碰到过漏测的bug吗?怎么处理的
答:碰到过,可以说一个不大不小的漏测案例(前提是别人的bug才导致的),重点说下防止下次漏测措施。
4.职业规划,离职原因。
答:这个开发性题目,离职原因尽量别说上家公司坏话。