微服务篇之接口幂等性

一、幂等接口

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

基于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只处理一次业务,就保证了幂等性。

相关推荐
小白鼠幻想家7 小时前
Agent 上下文爆炸:200 万退款事故复盘
架构
阿里云云原生8 小时前
AgentTeams 和 Claude Tag 都进入群聊模式,是新范式还是新叙事?
云原生·agent
Flittly8 小时前
【AgentScope Java新手村系列】(16)从RAG到多路检索
java·spring boot·spring
Ruihong8 小时前
Vue withDefaults 转 React:VuReact 怎么处理?
vue.js·react.js·面试
小兔崽子去哪了9 小时前
Java 生成二维码解决方案
java·后端
kyriewen9 小时前
别再这样写 async/await 了:我在 Code Review 中见过最多的 8 个错误
前端·javascript·面试
杉氧11 小时前
副作用 (Side Effects) 全攻略:如何像大师一样掌控 Composable 的生命周期?
android·架构·android jetpack
徐小夕12 小时前
jitword 协同文档3.2发布:打造浏览器中最强word编辑器
前端·架构·github
人活一口气13 小时前
从JVM调优到MCP协议:Java全栈技术体系深度总结与企业级架构实践
java·spring boot
烬羽15 小时前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试