当前位置: 首页 > news >正文

app开发 杭州祁东seo公司

app开发 杭州,祁东seo公司,网站开发有什么软件有哪些,建一个大型网站多少钱前言 同样是 面试问题 如何确保接口的 幂等性 幂等是一个 较为抽象的概念, 多次重复访问, 不会导致业务逻辑的异常 这里从增删改查, 几个方面列一下 一般来说, 我们核心需要关注的就是 新增 和 更新 对于 增加元素, 首先针对唯一约束进行校验, 然后再处理新增的相关业…前言 同样是 面试问题  如何确保接口的 幂等性  幂等是一个 较为抽象的概念, 多次重复访问, 不会导致业务逻辑的异常  这里从增删改查, 几个方面列一下  一般来说, 我们核心需要关注的就是 新增 和 更新 对于 增加元素, 首先针对唯一约束进行校验, 然后再处理新增的相关业务, 严格一点需要 加锁, 分布式并发控制  对于 删除元素, 就是检查元素存不存在, 存在 则删除, 不存在 返回相关状态吗, 或者直接成功都 OK 元素的新增 基于持久化的数据库的机制 比如 mysql 这边目标表, 增加唯一索引, 或者 主键 比如, 我们这里 限定在 用户表 中 用户名 不能重复, 这个只有特定的业务场景中可以这么处理  CREATE TABLE auth_user (id int(11) NOT NULL,name varchar(256) DEFAULT NULL,age int(11) DEFAULT NULL,PRIMARY KEY (id),UNIQUE KEY name (name) USING BTREE COMMENT name ) ENGINEInnoDB DEFAULT CHARSETutf8 然后 服务器这边 就不用做 过多的控制, 核心业务部分直接 ”insert into” 都可以  由 mysql 这边本身的机制 来确保 用户名 的不能重复, 防止 用户多次提交 造成的业务问题 分布式并发过滤控制  数据库的悲观锁 我们这里展现一下 完整的处理流程, 主要是包含了 外层的并发过滤控制, 数据库校验控制, 数据库加锁插入 控制 这里分布式并发控制这里模拟实现, 是 userRunningStore 部分 1. 并发过滤控制这边处理如下, 基于 spring 的 注解  aop Target(ElementType.METHOD) Retention(RetentionPolicy.RUNTIME) public interface ConcurrentLatch {} 并发过滤控制的处理如下 Component Aspect public class ConcurrentLatchAop {Pointcut(annotation(ConcurrentLatch))public void concurrentLatchAop() {}SetString userRunningStore new LinkedHashSet();Around(concurrentLatchAop())public Object doProcess(ProceedingJoinPoint point) throws Throwable {Object[] args point.getArgs();AuthUser user (AuthUser) args[0];String name user.getName();// lockif (userRunningStore.contains(name)) {throw new RuntimeException(String.format(有其他用户在新增用户 %s, 请刷新后重试, name));}userRunningStore.add(name);// unlockObject result point.proceed();return result;}} 数据库校验控制, 数据库加锁插入控制 如下  PutMapping(/user) ConcurrentLatch public AuthUser add(AuthUser user) {// physic verifyif (user.getAge() 0 user.getAge() 111) {throw new RuntimeException(用户的 age 必须在合法的区间);}// logistic verifyMapString, Object existsUser JdbcTemplateUtils.queryOne(jdbcTemplate, String.format( select * from auth_user where name %s; , user.getName()));if (existsUser ! null) {throw new RuntimeException(该用户已经存在, 用户名称不能重复);}// do other biz// lock then insertexistsUser JdbcTemplateUtils.queryOne(jdbcTemplate, String.format( select * from auth_user where name %s for update; , user.getName()));if (existsUser ! null) {throw new RuntimeException(该用户已经存在, 用户名称不能重复);}jdbcTemplate.execute(String.format(INSERT INTO auth_user(name, age) VALUES (%s, %s);, user.getName(), user.getAge()));return user; } token分布式并发控制  数据库的悲观锁 这个就主要是 整体的交互机制调整, 增加了一层 token 的获取 和 验证 token 的分派这边如下, 做限流, 生成 token 的相关处理  public static MapString, AtomicInteger interf2Counter new LinkedHashMap(); public static SetString tokenStore new LinkedHashSet();// pre install all interfs static {interf2Counter.put(IdempotentController.add, new AtomicInteger()); }GetMapping(/requestToken) public String requestToken(String interf) {AtomicInteger counter interf2Counter.get(interf);int incred counter.getAndIncrement();// rate limitif (incred 20) {counter.getAndDecrement();throw new RuntimeException( 服务器繁忙, 请稍后重试 );}String token UUID.randomUUID().toString();String compositeToken interf token;tokenStore.add(compositeToken);return token; } 并发控制这边处理如下  /*** ConcurrentLatchAop** author Jerry.X.He* version 1.0* date 2023/9/21 10:17*/ Component Aspect public class ConcurrentLatchAop {Pointcut(annotation(ConcurrentLatch))public void concurrentLatchAop() {}Around(concurrentLatchAop())public Object doProcess(ProceedingJoinPoint point) throws Throwable {Object[] args point.getArgs();String interf get interf from request;String token get token from request;// lockif (!IdempotentController.tokenStore.contains(token)) {throw new RuntimeException(服务器异常, 请刷新后重试);}IdempotentController.tokenStore.remove(token);// unlockObject result point.proceed();AtomicInteger counter IdempotentController.interf2Counter.get(interf);counter.getAndDecrement();return result;}} 元素的更新 以上 三种处理方式 在元素的更新中同样可以使用 元素的更新 数据库的更新控制这边可以使用 基于数据库的乐观锁  数据库的乐观锁更新 并发控制这边 和上面类似, 我们这里着重关注 数据库的更新这边  数据库的更新这边, 主要是增加一个版本号的字段, 然后 更新的时候 在原有的 id 条件之外, 再增加一个 version 控制的字段  根据 mysql 这边更新, 会增加行排他锁, 具体的处理如下  /*** IdempotentController** author Jerry.X.He* version 1.0* date 2023/9/21 9:58*/ RestController RequestMapping(/idempotent) public class IdempotentController {Resourceprivate JdbcTemplate jdbcTemplate;PostMapping(/user)ConcurrentLatchpublic AuthUser update(AuthUser user) {// physic verifyif (user.getAge() 0 user.getAge() 111) {throw new RuntimeException(用户的 age 必须在合法的区间);}// logistic verifyMapString, Object existsUser JdbcTemplateUtils.queryOne(jdbcTemplate, String.format( select * from auth_user where name %s; , user.getName()));if (existsUser null) {throw new RuntimeException(该用户不存在, 请确认输入);}// do other biz// lock then insertString id String.valueOf(existsUser.get(id));String version String.valueOf(existsUser.get(version));int updatedCount jdbcTemplate.update(String.format(update auth_user set name %s, age %s where id %s and version %s;, user.getName(), user.getAge(), id, version));if (updatedCount 0) {throw new RuntimeException(该用户信息已经发生改变, 请刷新后重试);}return user;}} 完
http://www.zqtcl.cn/news/739176/

相关文章:

  • 织梦动漫网站模版wordpress 页面文章列表
  • 东莞做网站沃德长沙市网站开发
  • 哪些网站做的最好厦门网站建设网站
  • 网站安全事件应急处置机制建设类似百度的网站
  • 内蒙古知名网站建设网站测速工具
  • 怎样建立网站赚钱怎么登录住建局官网
  • 建站自学网页转向功能网站
  • 网站都有什么费用做酒店网站有哪些目录
  • 本地郑州网站建设东莞网站优化中易
  • 动态域名可以建网站德州公司做网站
  • 深圳建设银行官方网站wordpress 添加qq
  • 甘肃第九建设集团公司网站网站对企业的好处
  • 论坛网站建设规划书公司网站建设与设计制作
  • 做棋牌游戏网站犯法吗如何进行搜索引擎的优化
  • 常见的网站首页布局有哪几种陈光锋网站运营推广新动向
  • 手机网站活动策划方案开一个设计公司
  • 宝塔建设网站教程visual studio 2010 网站开发教程
  • 做网站购买服务器做谷歌网站使用什么统计代码吗
  • 网站系统与网站源码的关系emlog轻松转wordpress
  • 网站的简介怎么在后台炒做吉林省住房城乡建设厅网站首页
  • 泉州易尔通网站建设国际酒店网站建设不好
  • 网页下载网站福田企业网站推广公司
  • 北京网站建设开发公司哪家好网站添加在线留言
  • 新建的网站怎么做seo优化平面广告创意设计
  • yy陪玩网站怎么做软件项目管理计划
  • 西安建网站价格低百度推广区域代理
  • 中英网站模板 照明公司注册在自贸区的利弊
  • 全球十大网站排名wordpress标题连接符
  • 网站开发可能遇到的问题四川建筑人才招聘网
  • 镇江网站托管怎么做淘宝网站赚钱吗