微服务篇之接口幂等性

一、幂等接口

幂等 : 多次调用方法或者接口不会改变业务状态,可以保证重复调用的结果和单次调用的结果一致。

基于RESTful API的角度对部分常见类型请求的幂等性特点进行分析:

解决方案如下。

二、token+redis

三、分布式锁

1. 快速失败(抢不到锁的线程)。

2. 控制锁的粒度。

java 复制代码
public void saveOrder(Item item) throws InterruptedException {
        //获取锁(重入锁),执行锁的名称
        RLock lock = redissonClient.getLock("yourNameLock");
        //尝试获取锁,参数分别是:获取锁的最大等待时间(期间会重试),锁自动释放时间,时间单位
        boolean isLock = lock.tryLock(10, TimeUnit.SECONDS);
        try {        //判断是否获取成功
            if (!isLock) {
                log.info("下单操作获取锁失败,order:{}", item);
                throw new RuntimeException("新增或修改失败");
            }
            //下单操作
        } finally {
            // 释放锁
            lock.unlock();
        }
    }

四、面试题

**面试官:**分布式服务的接口幂等性如何设计?

**候选人:**我们当时有一个xx项目的下单操作,采用的token+redis实现的,流程是这样的:

第一次请求,也就是用户打开了商品详情页面,我们会发起一个请求,在后台生成一个唯一token存入redis,key就是用户的id,value就是这个token,同时把这个token返回前端。

第二次请求,当用户点击了下单操作会后,会携带之前的token,后台先到redis进行验证,如果存在token,可以执行业务,同时删除token;如果不存在,则直接返回,不处理业务,就保证了同一个token只处理一次业务,就保证了幂等性。

相关推荐
欧恩意5 小时前
【Tools】Java反汇编工具推荐
java·汇编
阿里巴巴淘系技术团队官网博客6 小时前
从应用架构的视角看退小宝AI助手落地现状
人工智能·架构
寻星探路6 小时前
【JVM 终极通关指南】万字长文从底层到实战全维度深度拆解 Java 虚拟机
java·开发语言·jvm·人工智能·python·算法·ai
lbb 小魔仙6 小时前
【Java】Java 实战项目:手把手教你写一个电商订单系统
android·java·python
星河耀银海6 小时前
Java安全开发实战:从代码防护到架构安全
java·安全·架构
青云交6 小时前
Java 大视界 -- 基于 Java 的大数据可视化在城市水资源管理与节水策略制定中的应用
java·java 大数据·java 大数据可视化·城市水资源管理·spark 数据清洗·echarts 热力图·管网漏损控制
紫陌涵光6 小时前
112. 路径总和
java·前端·算法
workflower6 小时前
多变量时间序列预测
java·hadoop·nosql·需求分析·big data·结对编程
桂花饼7 小时前
2026大模型新格局:智谱GLM-5发布,DSA+MoE架构如何破解落地痛点?
人工智能·架构·sora2·gemini 3·gpt-5.2·codex-max·glm-5
Volunteer Technology7 小时前
DynamicTP动态线程池(四)
java·spring boot·后端·spring