高併發下怎樣生成唯一的訂單號
阿新 • • 發佈:2019-02-04
方案一:
如果沒有併發,訂單號只在一個執行緒內產生,那麼由於程式是順序執行的,不同訂單的生成時間戳正常不同,因此用時間戳+隨機數(或自增數)就可以區分各個訂單。
如果存在併發,且訂單號是由一個程序中的多個執行緒產生的,那麼只要把執行緒ID新增到序列號中就可以保證訂單號唯一。
如果存在併發,且訂單號是由同一臺主機中的多個程序產生的,那麼只要把程序ID新增到序列號中就可以保證訂單號唯一。
如果存在併發,且訂單號是由不同臺主機產生的,那麼MAC地址、IP地址或CPU序列號等能夠區分主機的號碼新增到序列號中就可以保證訂單號唯一。
方案二:
時間戳+使用者ID+幾個隨機數+樂觀鎖。
方案三:
用redis的原子遞增,做好高可用叢集。
方案四(非純數字):
java自帶uuid。
事例程式碼
java獲取執行緒ID
java獲取程序ID
java獲取mac地址
如果沒有併發,訂單號只在一個執行緒內產生,那麼由於程式是順序執行的,不同訂單的生成時間戳正常不同,因此用時間戳+隨機數(或自增數)就可以區分各個訂單。
如果存在併發,且訂單號是由一個程序中的多個執行緒產生的,那麼只要把執行緒ID新增到序列號中就可以保證訂單號唯一。
如果存在併發,且訂單號是由同一臺主機中的多個程序產生的,那麼只要把程序ID新增到序列號中就可以保證訂單號唯一。
如果存在併發,且訂單號是由不同臺主機產生的,那麼MAC地址、IP地址或CPU序列號等能夠區分主機的號碼新增到序列號中就可以保證訂單號唯一。
方案二:
時間戳+使用者ID+幾個隨機數+樂觀鎖。
方案三:
用redis的原子遞增,做好高可用叢集。
方案四(非純數字):
java自帶uuid。
事例程式碼
java獲取執行緒ID
Thread.currentThread().getId()
java獲取程序ID
//java獲取程序ID RuntimeMXBean runtime = ManagementFactory.getRuntimeMXBean(); Field jvm = runtime.getClass().getDeclaredField("jvm"); jvm.setAccessible(true); VMManagement mgmt = (VMManagement) jvm.get(runtime); Method pidMethod = mgmt.getClass().getDeclaredMethod("getProcessId"); pidMethod.setAccessible(true); int pid = (Integer) pidMethod.invoke(mgmt);
java獲取mac地址
InetAddress ia = InetAddress.getLocalHost();
byte[] mac = NetworkInterface.getByInetAddress(ia).getHardwareAddress();
String macStr = DatatypeConverter.printHexBinary(mac);