常见场景题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. 根据堆栈信息找到代码中哪个类的第几行出现了问题
相关推荐
一条大祥脚2 小时前
26.1.21 根号分治 相向双指针
java·开发语言·redis
迦蓝叶2 小时前
JDBC元数据深度实战:企业级数据资源目录系统构建指南
java·jdbc·企业级·数据资源·数据血缘·数据元管理·构建指南
chilavert3182 小时前
技术演进中的开发沉思-327 JVM:内存区域与溢出异常(下)
java·jvm
冲刺逆向2 小时前
【js逆向案例六】创宇盾(加速乐)通杀模版
java·前端·javascript
洛阳纸贵3 小时前
JAVA高级工程师-消息中间件RabbitMQ工作模式(二)
java·rabbitmq·java-rabbitmq
沛沛老爹3 小时前
Web开发者转型AI安全核心:Agent Skills沙盒环境与威胁缓解实战
java·前端·人工智能·安全·rag·web转型升级
像少年啦飞驰点、3 小时前
Java大厂面试真题:Spring Boot + Kafka + Redis 在电商场景下的实战应用
java·spring boot·redis·分布式·kafka·面试题·电商秒杀
小李广3 小时前
修改MS源码—开发新接口:查询所有项目下面的模块
java·linux·服务器
CHrisFC3 小时前
环境第三方检测机构LIMS系统选型:从合规基础到效率制胜
java·大数据·人工智能