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

html5 网站开发谷歌paypal官网下载

html5 网站开发,谷歌paypal官网下载,河南工程信息网官网,重庆网站托管在工作过程中接触了很多id生成策略,但是有一些问题 雪花id 强依赖时钟,对于时钟回拨无法很好解决 tinyid 滴滴开源,依赖mysql数据库,自增,无业务属性 uuid 生成是一个字符串没有顺序,数据库索引组织数据…

在工作过程中接触了很多id生成策略,但是有一些问题

雪花id

强依赖时钟,对于时钟回拨无法很好解决

tinyid

滴滴开源,依赖mysql数据库,自增,无业务属性

uuid

生成是一个字符串没有顺序,数据库索引组织数据是按顺序处理,如果用于主键存储,对于数据库来说会造成频繁的索引页合并,增加数据库的负担,不建议。

还有其他的id生成策略,对于一些简单的应用可以

分布式id特点

个人考虑,分布式id需要具有的特点如下

业务编号

通过此信息可以确定此编号是用于干什么的

数据中心编号

对于大型的互联网项目,会有分区域部署的情况,分流、负载均衡

当前时间

当前时间精确到秒

ip地址

对于集群使用,用于记录当前请求服务节点的ip,好知道是哪个节点发起的请求,需要将Ip转int进行处理

当前序号

从1开始,可以做成自增

拿经常使用的myql来说,索引中数据排序是按照主键来的,所以全部用数字来表示,考虑到上面的特点排序以及长度如下

业务标识(7位)+当前时间(年月日时分秒,yyyyMMddHHmmss,14位)+数据中心编号(5位)+ip地址(10位)+序号(19位)

当前id为55位,这样的id可读性强,看到这个id就知道哪个业务什么时候的数据,长度需要实际情况进行调整

业务标识,7位,最多代表9999999种业务,对于互联网公司一般来说足够了

当前时间,14位,精确到秒

数据中心,5位,一般足够

ip地址,对于地址进行int转换,10位

序号,19位,对应long类型的有符号最大值,与当前时间进行组合,一秒内生成19位id足够了

对于分页查询来讲,查询的时候需要确保此id属于哪个业务,先按条件进行匹配最大的数据id,然后根据此id进行范围匹配,这样可以最大限度使用索引,防止过多数据加载到内存中通过偏移量只选其中一部分数据。

对于时钟回拨问题

当前时间和序号使用redis进行分别存储,对于redis做sentinel三节点高可用

发号器机器当期时间<redis的时间

即redis时间在后,发号器时间在前,发号器当前时间滞后,如下

发号器当前时间
20230727121211
redis当前存储时间
20230727121212

这种情况有可能是时钟回拨。

为了不影响现有的数据,造成id重复导入插入数据库异常的情况,在现有的序号基础上进行自增。

发号器机器当期时间>=redis时间或者当前机器时间发生变化

如下

发号器当前时间
20230727121212
redis当前存储时间
20230727121211

按照发号器的时间处理,序号重置从0开始自增,需要事务锁定当前时间和序号,防止后面的请求造成争用。

对于redis的特性,单线程多个请求过来需要入队列、高并发、lua脚本操作的原子性,可以考虑每次请求调用lua脚本进行序号自增或者当前时间修改。

从redis 6 开始支持多线程,对于redis并发特性,做了一下测试

redis 5 单线程

redis-benchmark -t set,get -n 100000 -r 100000  -d 512 -c 500 -q
SET: 83472.46 requests per second
GET: 80971.66 requests per second

redis 6 两个线程

redis-benchmark -t set,get -n 100000 -r 100000 --threads 2 -d 512 -c 500 -q
SET: 107642.62 requests per second
GET: 110253.59 requests per second

可知,在多线程下多了不到一倍吞吐。

上面这些可以做成一个web服务,在 k8s 中做成一个负载均衡服务,请求时传入当前节点所在的数据中心id。

http://www.zhongyajixie.com/news/51224.html

相关文章:

  • 营销型网站建设论坛软文推送
  • 网站建设明细报价单鄂州seo
  • 哪里有做网站较好的公司推广引流
  • 北京网站建设新闻班级优化大师官方网站
  • wordpress super cacheseo推广知识
  • 百度收不到我的网站中国最大的企业培训公司
  • 免费windows7云主机下载网站seo诊断优化方案
  • 自己做网站app大连谷歌seo
  • 企业公司网站制作湖北seo服务
  • 香港做批发的网站有哪些新站seo优化快速上排名
  • 东至网站建设下载百度官方版
  • 呼市企业网站制作pc网站优化排名
  • 做网站比较专业的有哪些公司黑帽seo工具
  • 35岁学网站开发怎么样企业推广宣传文案
  • 东营做网站建设的公司广州各区风险区域最新动态
  • 湘潭网站建设选择磐石网络优化营商环境建议
  • 怎么自己做网站发优惠券十大免费引流平台
  • b2b网站做推广重庆网站建设与制作
  • 备案网站查询廊坊网站排名优化公司哪家好
  • php网站开发练手项目优化大师破解版app
  • 厦门企业建站模板百度网盘app下载
  • 做中英文网站公司北京seo收费
  • jsp和html做的招聘网站上海培训机构排名榜
  • wordpress前端发布插件什么是搜索引擎优化推广
  • php网站开发技术要点福州短视频seo机会
  • 免费代理加盟项目宁波seo推荐
  • 做海岛旅游预定网站的好口碑关键词优化
  • 济南网站设计制作要多久百度官网
  • 政府网站改版建设建议seo优化推荐
  • 网站开发维护前景微信视频号小店