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

做pc端网站要成本么十大引擎网址

做pc端网站要成本么,十大引擎网址,wordpress 女生,网站内页权重查询简介 接口幂等性就是说用户使用相同的参数请求同一个接口无论是一次还是多次都应该是一样的。不会因为多次的点击产生不同效果。 举个栗子:一个用户在手机APP上提200块钱,然后一不小心点击了两次,那么就应该只提取出200块钱,不应…

简介

接口幂等性就是说用户使用相同的参数请求同一个接口无论是一次还是多次都应该是一样的。不会因为多次的点击产生不同效果。

举个栗子:一个用户在手机APP上提200块钱,然后一不小心点击了两次,那么就应该只提取出200块钱,不应该出来400(当然,真实场景下取钱操作是一个复杂事务,不可能一个接口点击就出来了)。对于这种场景下,即使用户点了两次也应该只取出一次的钱,就是接口幂等性。

如何解决幂等性

1、 接口的前一层做拦截

对于直接和接口做交互的部分(Web、App)做一层拦截,例如禁止表单重复提交、点击按钮后按钮置灰等操作。

这种解决方法只能是针对于普通用户的常规操作而言,并不会覆盖全场景。很多恶意攻击者都会直接去访问你的后台代码试图写入脏数据。

2、数据库层面解决

2.1 insert语句前先select

优点:实现简单

缺点:局限性大,效率低

对于新写入数据类型的业务场景,可以在新增数据的时候先select一下关键的字段(操作类型、设备id、设备等),如果存在就update,否则insert。此方法针对局限性小的业务,基本上效率极低,不推荐使用

2.2 悲观锁

优点:严格保证防重复

缺点:用事务锁死,效率低,后续大量接口会按序请求,积攒接口请求。不适合高并发

使用sql锁住单行数据

select * from user id=123 for update;

这个语句就是锁定了user表中id为123的数据行,保证其他人不会使用

注意点:

1、mysql使用innodb引擎,这个支持事务

2、要锁住的字段要是主键或者唯一索引,不然会锁表

2.3 乐观锁

优点:比悲观锁效率高

缺点:数据从0到1的时候应该如何判断,这点我还没想明白过来

要修改的数据行中加入字段timestamp/version

要执行修改数据前,先查询此数据,

select id, name, update_time from user id=123;

如果别人改了不发生修改(默认别人的修改是正确的)

update user set name = "zhangsan"
where id=123 and update_time = 1695803269;

靠这种方式,如果update_time不是最开始查询的数值,那么写入时也会失效,保证了只会有一个数据对数据进行修改

2.4 加唯一索引

优点:效率高,一次sql,可以防重

缺点:防重过滤压力在数据库上,访问量大容易导致同库访问效率下降;需要单独写一个错误捕捉返回业务错误给前端

在加入唯一索引后,在业务代码中根据规则生成不可重复的code码,但是相同参数请求接口是一摸一样的

alter table `user` add UNIQUE KEY `un_code` (`code`);

这样在插入更新新数据的时候,如果code相同,会在sql层面进行报错,保证插入数据的唯一性

2.5 防重表

优点:即使针对同一个表,可能不同操作的防重需求也不同,用此方式可以灵活根据业务进行防重

缺点:加了一个表,存储维护成本上升。业务逻辑复杂性提升

新建一个数据库表,专门用来防重判断用。

具体步骤就是

1、数据来了 我要去写数据了,根据业务请求参数生成唯一code

2、使用code去insert防重表:成功,执行业务数据insert。失败,返回业务失败。

3、业务代码层面

 3.1状态机

优点:从业务代码进行去重,数据库无压力

缺点:业务代码复杂性上升

这个状态是针对于业务的,很多实际的业务表中有状态顺序。例如电商系统1-下单 、 2-已支付、 3-完成、 4-撤销等状态。根据这些状态字段进行数据更新时,就可以保证是唯一了。

update `dingdan` set status=3 where id=1 and status=2;

http://www.hkea.cn/news/893216/

相关文章:

  • 网站设计与管理论文百度账号注册平台
  • 网站空间商推荐seo是什么职位缩写
  • 怎么建设boss网站文件外链
  • 百度推广网站建设费百度搜索引擎的网址是多少
  • php 手机网站 上传图片定制网站建设
  • 关于网站建设的问题百度关键词分析
  • 登录官方网站装修公司网络推广方案
  • 设计网站官网入口网站搜索优化方法
  • 网站优化qq群山东做网站
  • wordpress icomoon太原seo快速排名
  • 中华建设杂志网站记者数据指数
  • 网站开发测试情况南召seo快速排名价格
  • 上海仓储公司小红书seo优化
  • 南京建设公司网站网络营销整合推广
  • wordpress更改语言沈阳seo优化
  • wordpress免费网站世界大学排名
  • 做网站的属于什么专业?百度爱采购竞价推广
  • 网站建设一年多少恰东莞网站到首页排名
  • 新企业网站应该怎么做SEO优化广告联盟有哪些
  • 手机app开发网站建设软文推广文章案例
  • 网站自然排名百度经验官网登录
  • dz网站模板沧州网站优化公司
  • 桂林论坛天涯社区培训行业seo整站优化
  • 做伊瑞尔竞技场的网站搜索引擎简称seo
  • 46云虚拟主机股票发行ipo和seo是什么意思
  • 新泰做网站菏泽seo
  • 网站建设排名东莞seo收费
  • 做网站前后端的发布流程自己如何制作网站
  • 网站营销与推广策略百度一下官网首页百度
  • 网站建设张世勇100个免费推广b站