日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > windows >内容正文

windows

高并发分布式系统中生成全局唯一(订单号)Id

發布時間:2024/9/21 windows 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 高并发分布式系统中生成全局唯一(订单号)Id 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

2019獨角獸企業重金招聘Python工程師標準>>>

高并發分布式系統中生成全局唯一(訂單號)Id

1、GUID數據因毫無規律可言造成索引效率低下,影響了系統的性能,那么通過組合的方式,保留GUID的10個字節,用另6個字節表示GUID生成的時間(DateTime),這樣我們將時間信息與GUID組合起來,在保留GUID的唯一性的同時增加了有序性,以此來提高索引效率,在NHibernate中,COMB型主鍵的生成代碼如下所示:

?

/// <summary>/// 保留GUID的10個字節,用另6個字節表示GUID生成的時間(DateTime)組合方式/// </summary>/// <returns></returns>public static Guid GenerateComb(){byte[] guidArray = Guid.NewGuid().ToByteArray();DateTime baseDate = new DateTime(1900, 1, 1);DateTime now = DateTime.Now;// Get the days and milliseconds which will be used to build //the byte string TimeSpan days = new TimeSpan(now.Ticks - baseDate.Ticks);TimeSpan msecs = now.TimeOfDay;// Convert to a byte array // Note that SQL Server is accurate to 1/300th of a // millisecond so we divide by 3.333333 byte[] daysArray = BitConverter.GetBytes(days.Days);byte[] msecsArray = BitConverter.GetBytes((long)(msecs.TotalMilliseconds / 3.333333));// Reverse the bytes to match SQL Servers ordering Array.Reverse(daysArray);Array.Reverse(msecsArray);// Copy the bytes into the guid Array.Copy(daysArray, daysArray.Length - 2, guidArray,guidArray.Length - 6, 2);Array.Copy(msecsArray, msecsArray.Length - 4, guidArray,guidArray.Length - 4, 4);return new Guid(guidArray);}

?

上述方法循環測試生成id如下圖

?結論:適合大型應用。即保留GUID的唯一性的同時增加了GUID有序性,提高了索引效率;解決了關聯表業務問題;生成的Id不夠友好;占據了32位。

?

2、將GUID轉為了19位數字

?

/// <summary>/// 根據GUID獲取19位的唯一數字序列/// </summary>public static long GuidToLong(){byte[] buffer = Guid.NewGuid().ToByteArray();return BitConverter.ToInt64(buffer, 0);}

?

上述方法循環測試生成id如下圖

結論:適合大型應用,從業務上來說,有一個規則的編碼能體現產品的專業成度。

轉載于:https://my.oschina.net/demons99/blog/2120461

總結

以上是生活随笔為你收集整理的高并发分布式系统中生成全局唯一(订单号)Id的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。