高并发下怎么生成惟一订单号

方案一:java

  若是没有并发的话,订单号只在一个线程中产生,不一样订单的时间戳不一样,    redis

        时间戳+随机数(自增数)区分订单并发

   若是有并发的话,而且订单号在同一台主机产生多个进程,只要把进程的ID添加到序列号中就能够保证订单号惟一。jvm

     若是有并发,订单在不一样主机中,把IP地址  CPU序列号  能区分的号码添加到序列号中就能保证惟一。spa

 

 方案二: 线程

       时间戳+用户ID+随机数+乐观锁进程

方案三: get

   能够用redis的原子递增,作高可用集群string

方案四:class

   java自带的UUID

 

 

实例代码

                 java中获取线程ID

  Thread.currentThread().getId()

                 java 获取进程 ID

  1. //java获取进程ID 2. RuntimeMXBean runtime = ManagementFactory.getRuntimeMXBean(); 3. Field jvm = runtime.getClass().getDeclaredField("jvm"); 4. jvm.setAccessible(true); 5. VMManagement mgmt = (VMManagement) jvm.get(runtime); 6. Method pidMethod = mgmt.getClass().getDeclaredMethod("getProcessId"); 7. pidMethod.setAccessible(true); 8. int pid = (Integer) pidMethod.invoke(mgmt);

      java 获取 mac 地址

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

相关文章
相关标签/搜索