java web在高併發和分佈式下實現訂單號生成唯一的解決方案

方案一:

如果沒有併發,訂單號只在一個線程內產生,那麼由於程序是順序執行的,不同訂單的生成時間戳正常不同,因此用時間戳+隨機數(或自增數)就可以區分各個訂單。如果存在併發,且訂單號是由一個進程中的多個線程產生的,那麼只要把線程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在高併發和分佈式下實現訂單號生成唯一的解決方案,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對腳本之家網站的支持!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章