测试面试题集锦三计算机网络和数据库

本文为霍格沃兹测试学院学员学习笔记,进阶学习文末加群。

本系列文章总结归纳了一些软件测试工程师常见的面试题,主要来源于个人面试遇到的、网络搜集(完善)、工作日常讨论等,分为以下十个部分,供大家参考。如有错误的地方,欢迎指正。有更多的面试题或面试中遇到的坑,也欢迎补充分享。希望大家都能找到满意的工作,共勉之!

软件测试工程师面试题系列篇

目录

测试常见问题与流程篇

测试工具篇

计算机网络知识与数据库篇

Linux篇

Python编程篇

自动化测试篇:包含Selenium、Appium和接口测试

性能测试篇

软素质篇:10大灵魂拷问

反问面试官篇

计算机网络篇(基础知识)

擅长哪些开发语言?

学习过Java,C等

半精通Python

输入URL到网页显示出来的全过程

输入网址

DNS解析

建立tcp连接

客户端发送HTTP请求

服务器处理请求

服务器响应请求

浏览器展示HTML

浏览器发送请求获取其他在HTML中的资源。

HTTP和HTTPS的区别

HTTPS里面是要有证书的,HTTP并没有证书。证书的作用是证明你是这个网站的拥有者。谁去证明?最顶级的CA去帮你证明,这些顶级的CA都是浏览器、操作系统本身就自动帮你集成,而且自动添加到设置信任里面去;

HTTPS要兼顾安全+性能的方面,由于对称式加密虽然速度很快,但是安全性特别的低,因为双方要规定对称式加密的秘钥,别人都无法知道,但你怎么能确保别人不知道你的秘钥呢,因此需要有非对称式加密去保证安全,但非对称式加密速度又很慢,如果客户端和服务器端都用非对称式加密,网络得卡死了。所以当双方建立好了非对称加密后,再约定一个随机数,等大家都非对称解密了之后呢,就拿到只有对方知道的唯一随机数(秘钥),就可以用秘钥来进行对称式加密和解密了;

HTTP的报文结构

HTTP请求报文:一个HTTP请求报文由请求行、请求头部、空行和请求数据4个部分组成

HTTP响应报文:HTTP响应也由三个部分组成,分别是:状态行、消息报头、响应正文

HTTP常见的响应状态码

请求已成功,请求所希望的响应头或数据体将随此响应返回。

请求已经被实现,而且有一个新的资源已经依据请求的需要而建立,且其URI已经随Location头信息返回

服务器已接受请求,但尚未处理

(永久移动)请求的网页已永久移动到新位置。服务器返回此响应(对GET或HEAD请求的响应)时,会自动将请求者转到新位置。

(临时移动)服务器目前从不同位置的网页响应请求,但请求者应继续使用原有位置来进行以后的请求。

(查看其他位置)请求者应当对不同的位置使用单独的GET请求来检索响应时,服务器返回此代码。

(未修改)自从上次请求后,请求的网页未修改过。服务器返回此响应时,不会返回网页内容。

(使用代理)请求者只能使用代理访问请求的网页。如果服务器返回此响应,还表示请求者应使用代理。

(临时重定向)服务器目前从不同位置的网页响应请求,但请求者应继续使用原有位置来进行以后的请求。

当前请求需要用户验证。如果当前请求已经包含了Authorization证书,那么响应代表着服务器验证已经拒绝了那些证书

服务器已经理解请求,但是拒绝执行它。与响应不同的是,身份验证并不能提供任何帮助,而且这个请求也不应该被重复提交

请求失败,请求所希望得到的资源未被在服务器上发现

服务器遇到了一个未曾预料的状况,导致了它无法完成对请求的处理。一般来说,这个问题都会在服务器的程序码出错时出现。

服务器不支持当前请求所需要的某个功能。当服务器无法识别请求的方法,并且无法支持其对任何资源的请求。

作为网关或者代理工作的服务器尝试执行请求时,从上游服务器接收到无效的响应。

由于临时的服务器维护或者过载,服务器当前无法处理请求。这个状况是临时的,并且将在一段时间以后恢复。

cookie和session机制的区别

cookies数据保存在客户端,session数据保存在服务器端;

cookies可以减轻服务器压力,但是不安全,容易进行cookies欺骗;

session较安全,但占用服务器资源

TCP和UDP的区别

TCP:面向连接,可靠的,速度慢,效率低

UDP:无连接、不可靠、速度快、效率高

TCP为什么是三次握手和四次挥手

三次握手能保证数据可靠传输又能提高传输效率。若握手是两次:如果只是两次握手,至多只有连接发起方的起始序列号能被确认,另一方选择的序列号则得不到确认;

要保证双方都关闭了连接。因为TCP是全双工的,就是要等到两边都发送fin包确认双方都没有数据传输后才关闭;

TCP为什么最后挥手后会有time_wait

为了保证可靠的断开TCP的双向连接,确保足够的时间让对方收到ACK包。若客户端回复的ACK丢失,server会在超时时间到来时,重传最后一个fin包,处于TIME_WAIT状态的client可以继续回复Fin包,发送ACK。

保证让迟来的TCP报文段有足够的时间被识别和丢弃,避免新旧连接混淆。有些路由器会缓存没有收到的数据包,如果新的连接开启,这些数据包可能就会和新的连接中的数据包混在一起。连接结束了,网络中的延迟报文也应该被丢弃掉,以免影响立刻建立的新连接。

简要说明HTTP请求中的Post和Get有哪些区别的地方

请求头多了content-length和content-type字段

Post可以附加body,可以支持form、json、xml、binary等各种数据格式

行业通用规范

无状态变化的建议使用Get

数据的写入与状态的修改建议使用Post

基于HTTP协议:都是请求返回数据,Get将请求体放在头上,只发一次请求,Post将请求体放在内部,需要发送两次请求

GET在浏览器回退时是无害的,而POST会再次提交请求。

GET请求会被浏览器主动cache,而POST不会,除非手动设置。

GET请求只能进行URL编码,而POST支持多种编码方式。

GET请求在URL中传送的参数是有长度限制的,而POST么有。

对参数的数据类型,GET只接受ASCII字符,而POST没有限制。

GET比POST更不安全,因为参数直接暴露在URL上,所以不能用来传递敏感信息。

如果一个请求,返回的状态码是,但是没有内容,可能发生了什么?

请求头缺失或错误

参数length不符

以上为个人理解,有误请指正。

数据库篇

工作中常使用的SQL语法有哪些?

createtable、createview、selectfromwhere、insertinto、updatesetvalues、delete、alter、orderby、having

数据库存储过程

一组数据库操作命令,当作是自己写的一个方法,一系列步骤自己去封装(个人理解)

SQL常见查询语句编写(此处仅举例常见的查询语句,如有更多坑,希望补充)

查询所有学生的数学成绩,显示学生姓名name,分数,由高到低。

SELECTa.name,b.scoreFROMstudenta,gradebWHEREa.id=b.idANDkemu=数学ORDERBYscoreDESC;

统计每个学生的总成绩(由于学生可能有重复名字),显示字段:学生id,姓名,总成绩。

SELECTa.id,a.name,c.sum_scorefromstudenta,(SELECTb.id,sum(b.score)assum_scoreFROMgradebGROUPBYid)cWHEREa.id=c.idORDERBYsum_scoreDESC;

列出各门课程成绩最好的学生,要求显示字段:学号,姓名,科目,成绩

SELECTc.id,a.name,c.kemu,c.scoreFROMgradec,studenta,(SELECTb.kemu,MAX(b.score)asmax_scoreFROMgradebGROUPBYkemu)tWHEREc.kemu=t.kemuANDc.score=t.max_scoreANDa.id=c.id

慢查询是什么意思?

开启慢查询日志,可以让MySQL记录下查询超过指定时间的语句,通过定位分析性能的瓶颈,才能更好的优化数据库系统的性能。

导致数据库性能差的可能原因有哪些?

硬件环境问题,如磁盘IO

查询语句问题,如join、子查询、没建索引

索引失效,建了索引,查询的时候没用上

查询关联了太多的join

服务器关联缓存,线程数等

表中存在冗余字段,在生成笛卡尔积时耗费多余的时间

Redis缓存应用场景

需要将数据缓存在内存中,提升查询效率

这里希望大家补充

怎么定位Redis缓存失效问题(缓存坏了)

Redis的知识,了解的不是很多

抛砖引玉,请大家指正和补充。

推荐学习

推荐霍格沃兹出品《测试开发实战进阶》课程,BAT大厂前沿实践,开源项目作者亲授。4个月20+项目实战强化训练,测试大咖思寒授之以渔,一站式掌握BAT测试开发工程师必备核心技能(对标阿里P6+,年薪50W+)!学员直推BAT名企测试经理,普遍涨薪50%+!

??14期开课中??

戳“阅读原文”,提升自己的核心竞争力吧!预览时标签不可点收录于话题#个上一篇下一篇



转载请注明地址:http://www.yulinbing999.net/mnabys/12665.html
  • 上一篇文章:
  • 下一篇文章: 没有了
  • 热点文章

    • 没有热点文章

    推荐文章

    • 没有推荐文章