java生成流水號唯一 javaWeb 在系統(tǒng)高并發(fā)的情況下生成有序流水號?
javaWeb 在系統(tǒng)高并發(fā)的情況下生成有序流水號?1. 如果主題不要求ID是數字,建議使用最簡單的一個,即UUID,它包含機器代碼、時間戳、隨機數等,但UUID最終生成一個全局唯一的字符串,而不是整
javaWeb 在系統(tǒng)高并發(fā)的情況下生成有序流水號?
1. 如果主題不要求ID是數字,建議使用最簡單的一個,即UUID,它包含機器代碼、時間戳、隨機數等,但UUID最終生成一個全局唯一的字符串,而不是整數,并且看起來順序不對。
2. MySQL自己添加ID。它使用一個表來存儲各種業(yè)務id。每個分布式系統(tǒng)插入一個ID后,生成1000萬個本地號碼與ID拼接,然后每個系統(tǒng)得到一個ID,相當于生成1000萬個ID,足夠長時間使用。這1000萬個ID可以預先定義,并在系統(tǒng)啟動時放入內存。因為它們只是ID,所以不會占用太多內存。MySQL可以內置到集群中,這不會影響自增IDs的使用。
3. 與MySQL的auto-increment ID類似,redis的incr實現了自動增量。每個分布式系統(tǒng),比如redis,都是用incr插入一個ID,然后生成1000萬個本地號碼與ID拼接,如果每個系統(tǒng)都有一個ID,相當于生成1000萬個ID,足夠長時間使用。這1000萬個ID可以預先定義,并在系統(tǒng)啟動時放入內存。因為它只是一個ID,所以不會占用太多內存。Redis也可以內置到集群中,這不會影響自增ID的使用。Twitter的雪花算法與UUID類似,包括機器碼、時間戳、隨機數等,但最終生成的是64位整數,可以滿足許多分布式系統(tǒng)的要求。如果Id必須是整數,建議使用snowflake而不是UUID。
現在開發(fā)JAVA后臺,主要用哪些技術?
您的系統(tǒng)有多大,您的技術有多強大
!從我們公司的角度來看,使用java開發(fā)后臺服務使用了以下幾點
!2. 數據庫映射框架:mybatis
!3. 數據庫連接池:Druid
!4. 原木框架:slf4j
!5. 項目建設工具:Maven
!6. 版本控制工具:SVN和git
!7. 緩存:redis
!9. 工作流引擎:activiti
!10. 規(guī)則引擎:口水
!11. 微型服務容器:docker
!12、圖片、文件等上傳工具OSS
!14,原型視圖工具:Axure RP
!15. 后臺服務模擬訪問:郵遞員
!16,腳本:shell或Python
!17,語言:java8
!這些是工作中使用的后端技術??梢哉f程序員是全能的!可能還有更多,有待繼續(xù)