常见场景题3(面试)

设计一个接口需要考虑什么

  1. 入参合法性校验。参数范围是否合理,参数类型是否正确等
  2. 接口考虑幂等性重复调用的结果和单次调用的结果一致
  3. 减少接口的响应时间。如数据库加索引。添加redis 缓存
  4. 选择合适的接口请求日志不同接口设置不同的日志级别
  5. 统一响应数据格式 。需要返回统一格式的响应体,响应数据会包含三个属性: 状态码(code),信息描述(message),响应数据(data)
  6. 接口单一职责

如何保证接口安全

  1. 使用https协议
  2. 参数校验。参数范围是否合理,参数类型是否正确等
  3. 统一封装返回值 。需要返回统一格式的响应体,响应数据会包含三个属性: 状态码(code),信息描述(message),响应数据(data)
  4. 区分不同的访问形式。比如是否登录,账号是普通账号还是会员账号,或者管理员账号
  5. 加验证码
  6. 限制访问频率。比如发送短信后,60秒后才能再次发送

慢接口如何排查

线上接口过慢,原因有以下三点:

1.内存使用过高,频繁gc导致cpu占满

2.内存使用不高,但出现了类似死循环的场景

3.死锁。

  1. 使用 top -c指令找到负载高的进程id
  2. top -Hp X指令查看该进程的线程id的CPU负载情况,找到CPU负载高的线程id
  3. 使用jstack命令查看该线程的堆栈信息
  4. 根据堆栈信息找到代码中哪个类的第几行出现了问题
相关推荐
小明的小名叫小明11 小时前
区块链核心知识点梳理(面试高频考点4)-以太坊交易全流程
面试·区块链
risc12345611 小时前
【备忘录】java.lang.Throwable#addSuppressed这个是干嘛的?
java·开发语言
__万波__11 小时前
二十三种设计模式(十)--外观模式
java·设计模式·外观模式
Geoking.11 小时前
深度理解 Java 中的 switch —— 从基础到进阶的完整指南
java
棋啊_Rachel11 小时前
面试高频详解:Redis 缓存击穿、雪崩、穿透
redis·缓存·面试
今天你TLE了吗11 小时前
Java:基于注解实现去重表消息防止重复消费
java·spring boot·分布式·spring cloud·幂等
没有bug.的程序员11 小时前
大规模微服务下的 JVM 调优实战指南
java·jvm·spring·wpf·延迟
北友舰长11 小时前
基于Springboot+vue大型商场应急预案管理系统的设计与实现【Java毕业设计·安装调试·代码讲解·文档报告】
java·vue.js·spring boot·mysql·商场·应急处理·应急
赵庆明老师11 小时前
在ASP.NET Core Web Api中添加身份验证和授权
java·前端·asp.net
菜鸟小九11 小时前
redis基础(java客户端)
java·redis·bootstrap