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

java web在高并发和分布式下实现订单号生成唯一的解决方案

发布时间:2020-12-14 20:59:52 所属栏目:Java 来源:网络整理
导读:方案一: 如果没有并发,订单号只在一个线程内产生,那么由于程序是顺序执行的,不同订单的生成时间戳正常不同,因此用时间戳+随机数(或自增数)就可以区分各个订单。如果存在并发,且订单号是由一个进程中的多个线程产生的,那么只要把线程ID添加到序列号

方案一:

如果没有并发,订单号只在一个线程内产生,那么由于程序是顺序执行的,不同订单的生成时间戳正常不同,因此用时间戳+随机数(或自增数)就可以区分各个订单。如果存在并发,且订单号是由一个进程中的多个线程产生的,那么只要把线程ID添加到序列号中就可以保证订单号唯一。如果存在并发,且订单号是由同一台主机中的多个进程产生的,那么只要把进程ID添加到序列号中就可以保证订单号唯一。如果存在并发,且订单号是由不同台主机产生的,那么MAC地址、IP地址或CPU序列号等能够区分主机的号码添加到序列号中就可以保证订单号唯一。

方案二:

时间戳+用户ID+几个随机数+乐观锁。

方案三:

用redis的原子递增,做好高可用集群。

方案四(非纯数字):

java自带uuid。

事例代码

java获取线程ID

Thread.currentThread().getId() 

java获取进程ID

 // get name representing the running Java virtual machine.  
    String name = ManagementFactory.getRuntimeMXBean().getName();  
    System.out.println(name);  
    // get pid  
    String pid = name.split("@")[0];  
    System.out.println("Pid is:" + pid);  

java获取mac地址

InetAddress ia = InetAddress.getLocalHost(); 
byte[] mac = NetworkInterface.getByInetAddress(ia).getHardwareAddress(); 
String macStr = DatatypeConverter.printHexBinary(mac);

总结

以上所述是小编给大家介绍的java web在高并发和分布式下实现订单号生成唯一的解决方案,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程小技巧网站的支持!

(编辑:李大同)

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

    推荐文章
      热点阅读