加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

linux – 短唯一ID

发布时间:2020-12-14 00:03:25 所属栏目:Linux 来源:网络整理
导读:我正在设计一个HTTP服务,每天的容量高达5亿个请求(由多个独立机器提供服务). 对于每个请求,我必须生成唯一ID并将其返回给用户.在10分钟的窗口内,ID必须是100%唯一的. (首选1天,全局唯一ID是理想的.)生成该ID不需要服务器 – 服务器通信. 愚蠢的伪会话示例:
我正在设计一个HTTP服务,每天的容量高达5亿个请求(由多个独立机器提供服务).

对于每个请求,我必须生成唯一ID并将其返回给用户.在10分钟的窗口内,ID必须是100%唯一的. (首选1天,全局唯一ID是理想的.)生成该ID不需要服务器 – 服务器通信.

愚蠢的伪会话示例:

Client: GET /foo

Server: Content-Type: text/xml

        <root>
            <id>ab9d1972-2844-11e0-86b2-000c29544403</id>
            <other_data/>
        </root>

在上一代HTTP服务中,我使用了UUID.

我对UUID很满意,但有一个问题:它们太长了.在这些请求数量上,这个额外的大小在磁盘空间中明显浪费了日志文件.

创建简短但唯一的标识符的最佳方法是什么?为了让事情变得有价值,我想,算法应该产生UUID长度的一半,而一整天都是唯一的(10分钟应该更短).

理想情况下,建议的算法将在简单的C中具有理智,轻量级的生产质量实现.

更新:生成的ID在GET请求中传递时不应要求URI编码.

解决方法

为每台机器提供唯一的前缀.给每台机器一个柜台.要生成ID,请递增计数器,并将其值附加到前缀.

如果要对ID进行模糊处理,请加密它们 – 密码是可逆转换,因此将其应用于唯一值将产生唯一值.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读