V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
kikione
V2EX  ›  程序员

分布式环境下,给所有用户分配自定义的虚拟号,要求顺序自增,如何设计?

  •  
  •   kikione · 2021-08-05 15:52:16 +08:00 · 1781 次点击
    这是一个创建于 1204 天前的主题,其中的信息可能已经有所发展或是发生改变。

    大家有什么比较好的方案,可给我参考参考

    11 条回复    2021-08-06 18:39:39 +08:00
    ipwx
        1
    ipwx  
       2021-08-05 15:57:14 +08:00
    专门放个机器,上面跑一个程序。写一个多线程 + 协程的 tcp server,atomic<int> 自增返回新的用户号。

    这难道不是最容易的手段么。。。
    tabris17
        2
    tabris17  
       2021-08-05 15:59:52 +08:00
    ai88030669
        3
    ai88030669  
       2021-08-05 16:37:20 +08:00
    redis 自增
    securityCoding
        4
    securityCoding  
       2021-08-05 16:41:27 +08:00
    redis+1
    xarthur
        6
    xarthur  
       2021-08-05 17:00:50 +08:00 via iPhone
    我觉得楼主可能还需要没有规律。
    可以了解一下推特的 snowflake (雪花算法)
    heavyrainn
        7
    heavyrainn  
       2021-08-05 17:45:24 +08:00
    snowflake 了解一下,专门为分布式有序自增设计的
    kiotech
        8
    kiotech  
       2021-08-06 10:18:01 +08:00
    snowflake +1
    qichengzx
        9
    qichengzx  
       2021-08-06 15:18:11 +08:00
    https://github.com/qichengzx/seqsvr
    之前按携程的文章实现过一个递增的计数器,应该可以满足。
    JKeita
        10
    JKeita  
       2021-08-06 16:30:55 +08:00
    我记得雪花算法不一定是顺序的吧
    hotcool100
        11
    hotcool100  
       2021-08-06 18:39:39 +08:00
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   975 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 20:53 · PVG 04:53 · LAX 12:53 · JFK 15:53
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.