腾讯金融科技测开一面凉经

1.自我介绍(自我介绍中有提到实习中有用到postman)
答:

2.实习的项目中有用postman进行接口测试,有用pytest框架对系统核心API进行封装,编写测试用例脚本,那你pytest里面会用postman吗?
答:pytest框架里面不会用到postman,postman的话,是自己在页面上通过F12复制接口URL到postman之后,会显示各种参数的名称以及参数的值,会更加方便在pytest里面写测试用例脚本。

3.那你用pytest框架能用来做接口测试吗?
答:可以的,通过调用各自的接口,然后传递所需的参数即可。

4.为什么用到pytest还要用postman?
答:postman的话,是自己在页面上通过F12复制接口URL到postman之后,会显示各种参数的名称以及参数的值,会更加方便在pytest里面写测试用例脚本。

5.假设用pytest怎么做postman的事情?用pytset写python用例的话,怎么去调用这个接口?
答:本质上是调用接口,所以需要请求接口,需要调用requests 库来执行 HTTP 请求。

6.必须要用Yaml吗?
答:在编写自动化测试用例时,不一定需要使用 YAML。使用 YAML 的主要原因通常是为了方便管理测试数据、配置文件或测试用例,使得测试代码与数据分离,易于维护。如果不使用这个Yaml的话,可以定义字典,列表等来存储相应的数据。

7.最终调用这个接口的话是通过调用什么库来调?python调通这个接口的话,想知道具体是使用什么来调用的?
答:本质上是调用接口,所以需要请求接口,需要调用requests 库来执行 HTTP 请求。

8.项目中涉及到一个商品的购买,假设多人去抢购这个商品,假设你这个商品的数量是100个的话,怎么保证商品不会被超卖?
答:使用redis分布式锁来保证每次只有一个进程可以进行库存的扣减操作。这样的话可以保证商品不会被超卖。

9.提到了redis,假设没有redis,现在库存的数据是记录在MySQL中的,假设MySQL中有一个字段存储商品的剩余个数,假设每卖一个就减1,假设每一个用户过来购买商品的时候,他会去查询这个商品的库存,然后去把库存去减1,那这个MySQL操作里面是如何保证库存的扣减的?举个例子,第一个用户去查询的是100去减1,第二个用户在减1之前查到库存为100,然后他也去减1,然后算完了之后大家都是99,这种问题应该去怎么避免?
答:为了避免这个问题,可以使用数据库的事务机制和行级锁 来确保并发情况下数据的一致性,
        1.悲观锁通过锁住数据库中的记录,确保在事务执行期间,其他事务无法修改这些记录。这样可以避免多个用户同时操作同一个库存记录(在减库存之前,先通过 SELECT xxx FOR UPDATE; 查询库存并锁住该行数据。这个锁会一直持续到当前事务提交或回滚为止,确保在锁住的情况下其他事务不能修改该库存数据)。
       2.乐观锁假设并发操作不会频繁发生,因此不会提前锁住资源,而是依赖在更新时的版本号来判断数据是否被其他事务修改过。如果发现冲突,则让事务失败并重试。在商品表中增加一个 version 字段,每次更新库存时同时检查和更新版本号。如果在更新时发现版本号已经被其他事务修改,则该事务回滚,提示用户重试。
        实现方式:通过版本号字段  1.查询库存和版本号 2.执行更新时,检查版本号是否一致:

10.了解过MySQL的加锁吗?
答:同9

11.比如刚刚的问题,我就想先把这条记录先锁了,再更新,就这种MySQL的操作是怎么操作的?就是MySQL语句?
答:同9

12.你这个项目是在Linux里面安装的吗?(面试官想问一些Linux的东西)

13.假设linux机器上部署了很多服务,你想看他们的cpu的占用用什么命令?
答;top命令

14.说到了负载过载,但是我想问的是从显示上来说,它显示的是超过百分之百,但是从理论上来说,应该不存在进程超过百分之百的cpu占用率?
答:top 命令中显示的 CPU 占用率是相对于每个 CPU 核心的使用情况,而不是整个系统的总 CPU 资源。因此,当一个进程运行在多核 CPU 上时,它的 CPU 使用率可以超过 100%。

15.想知道服务的端口号,用什么命令?
答:netstat -tuln

16.,netstat命令打印内容的话,可以看到它的状态,比如它在通信中的话就是ESTABLISHED这种状态,那还有一种是TIME_WAIT 状态,那这是一种什么状态?
答:TIME_WAIT 状态是一种与 TCP 连接的关闭过程相关的状态,主动关闭连接的一方在完成四次挥手后进入 TIME_WAIT 状态。此状态等待足够的时间以确保对方收到 ACK,并防止旧数据包干扰新连接。

17.你写过sorckect网络编程没有,就是写一个简单的客户端服务端这种?
答:没有

18.你为什么要去在第二项目去使用到这个websocket呢?
答:主要是为了实现用户催单和来单提醒功能,达到实时通讯的一个效果

19.手撕:
    二分查找实现
    输入:1 2 3 5 5 7 11 13
                5
    输出:3 4 
    条件:完成程序输出
               对异常输入进行处理
                设计单测用例  
    
反问:
1.简历还有没有什么需要修改的?
答:你这个简历的这两个项目,就是很多人都会写这两个项目,而且大概东西都是一样的,重复度太高了,可以把这个乐享优选换成一个别的东西,这种就是非常的多,怎么能体现你这个有什么亮点。
2.是需要把这个项目换掉还是换个场景?
答:项目可以是这个项目,但你这个职责描述这里所有人都是这样做的,体现跟大家不一样的点;
3.后续还需要加强哪个方面?
答:就是你在用一些东西的时候,举个例子,就是我刚刚问你超卖的问题,超卖的这个都是用redis和lua来做的,所有人都是用这个,那真的只有这个吗?或者是不用这个东西怎么做?哪几种做法?从基础知识的角度上来说,这个应该怎么做,先不管项目是怎么做的,他本质上应该是是个什么问题?
全部评论

相关推荐

2024-12-02 15:33
已编辑
University of California San Diego golang
最近好像还有同学在面虾皮,攒点人品,希望自己和大家都能拿到想要的offer💐二面面经:https://www.nowcoder.com/feed/main/detail/f4d03bc74cd04f04b20a330d4f9ee52a?sourceSSRtimeline:8.31 一面9.07 二面9.24 HR面12.02 offer call + offer----1. channel的实现2. 读写channel的过程中需要注意哪些问题?3 channel一般在什么场景下使用?4. 如果需要实现数据的一致性,或者说保证channel的数据在panic后不丢失,有什么方式?5. 提示:考虑一下分布式的方向,比如说redis,MQ能够做到。但是redis单机也有这个问题。6. 对Kafka或者RabbitMQ有了解吗?它们怎么保证数据不丢失?如果对MQ不了解,说MySQL的也行。7. MySQL崩溃重启后,数据还在,它的底层是怎么实现的?8. 如果是多机的情况呢?9. MySQL性能优化的方式有哪些?10. 如果一条SQL语句耗时比较久,我们如何对它进行分析?11. 如果一张表有上亿条数据,即使设计了索引也很影响性能,该怎么办?12. 假设一个电商平台的表有一些字段:订单id,商品id,用户id,支付价格等,你会怎么分表?13. 用户侧有时候想要查询自己的历史订单记录。后台管理员有时候想要查询一个月的订单数据信息等,怎么做?14. 如果内部想要分析一个用户的数据,是不是需要遍历每个月的表?15. 有了解过网络的负载均衡吗?16. 有了解一致性哈希吗17. 在过去有没有遇到印象深刻的数据结构或者算法18. Raft算法最重要的特点是什么?19. 分布式比较经典的问题是网络分区,Raft是如何解决的?20. Http有哪些版本,每个版本的特点,解决了哪些问题。经典八股,介绍了 1.0, 1.1, 2.0, 3.0的特点21. 算法15. 三数之和#面经##虾皮##虾皮一面##虾皮2025#
查看20道真题和解析
点赞 评论 收藏
分享
评论
3
9
分享

创作者周榜

更多
牛客网
牛客企业服务