改良版雪花算法,分布式唯一ID神器!
本期項目概覽:
- IdGenerator:唯一 ID 生成器
- JNotepad:跨平臺文本編輯器
- Fury:高性能多語言序列化框架
- x-easypdf:快速生成 PDF 文檔
- Jarboot:可視化 Java 進程管理平臺
IdGenerator:唯一 ID 生成器
項目介紹:
- 和 UidGenerator、Leaf 一樣,IdGenerator 也是一款基于 Snowflake(雪花算法)的唯一 ID 生成器。
- IdGenerator 生成的唯一 ID 更短,速度更快,兼容所有雪花算法(號段模式或經典模式),且不依賴外部存儲系統。
- IdGenerator 解決了時間回撥問題,支持手工插入新 ID
- IdGenerator 原生支持 C#/Java/Go/C/Rust/Python/Node.js/PHP(C 擴展)/SQL/ 等語言,并提供多線程安全調用動態庫(FFI)。
- 默認配置下,IdGenerator 生成的 ID 可用 71000 年不重復。
IdGenerator 生成的唯一 ID 組成:
IdGenerator 生成的 ID 組成
- timestamp (位數不固定):時間差,是生成 ID 時的系統時間減去 BaseTime(基礎時間,也稱基點時間、原點時間、紀元時間,默認值為 2020 年) 的總時間差(毫秒單位)。初始為 5bits,隨著運行時間而增加。如果覺得默認值太老,你可以重新設置,不過要注意,這個值以后最好不變。
- worker id (默認 6 bits):機器 id,機器碼,最重要參數,是區分不同機器或不同應用的唯一 ID,最大值由 WorkerIdBitLength(默認 6)限定。如果一臺服務器部署多個獨立服務,需要為每個服務指定不同的 WorkerId。
- sequence (默認 6 bits):序列數,是每毫秒下的序列數,由參數中的 SeqBitLength(默認 6)限定。增加 SeqBitLength 會讓性能更高,但生成的 ID 也會更長。
相關地址:
- 項目地址:https://github.com/yitter/IdGenerator
- Java 語言使用示例:https://github.com/yitter/idgenerator/tree/master/Java
JNotepad:跨平臺文本編輯器
項目介紹 :基于 JavaFX 開發的文本編輯器,供了完善的文本編輯和查看功能,支持 Mac / Windows / Linux。
效果展示:
目前還是處于玩具項目的階段,bug 挺多,體驗也比較差。
相關地址 :
- 項目地址:https://gitee.com/jcnc-org/JNotepad
- JNotepad 開發者指南:https://gitee.com/jcnc-org/docs/blob/master/CN/Dev-Guide/JNotepad-Dev-Guide/JNotepad-Dev-Guide.md
Fury:高性能多語言序列化框架
項目介紹:
- Fury 是一個基于 JIT 動態編譯和零拷貝的多語言序列化框架,支持 Java/Python/Golang/JavaScript/C++ 等語言,提供極致的性能和易用性。
- Fury 可以用于替代 JDK、Kryo、Hessian 等序列化框架,無需修改任何代碼。
詳細介紹可以查看這篇文章:比 JDK 最高快 170 倍,螞蟻開源的這款序列化框架有點厲害!!
性能對比:
Fury 與其他常見序列化框架的性能對比如下圖所示。
更多 benchmark 數據請參考 Fury Github 官方文檔:https://github.com/alipay/fury/tree/main/docs/benchmarks
x-easypdf:快速生成 PDF 文檔
項目介紹:基于 pdfbox/fop 二次封裝的框架,分為 pdfbox 模塊(主打 pdf 編輯功能)和 fop 模塊(主打 pdf 導出功能)。兩個模塊均可單獨使用,也可以結合使用,幫助開發者快速生成 pdf 文檔。
軟件架構:
使用效果:
創建 PDF:
// 定義pdf輸出路徑
String outputPath = "E:\\pdf\\test\\pdfbox\\test.pdf";
// 構建文檔
XEasyPdfHandler.Document.build().addPage(
// 構建頁面
XEasyPdfHandler.Page.build(
// 構建組件
XEasyPdfHandler.Text.build("文本內容")
)
// 保存文檔并關閉
).save(outputPath).close();
編輯 PDF:
// 定義pdf輸出路徑
String sourcePath = "E:\\pdf\\test\\pdfbox\\test.pdf";
// 定義pdf輸出路徑
String outputPath = "E:\\pdf\\test\\pdfbox\\output.pdf";
// 讀取文檔
XEasyPdfDocument document = XEasyPdfHandler.Document.load(sourcePath);
// 獲取頁面
XEasyPdfPage page = document.getPageList().get(0);
// 創建文本組件
XEasyPdfText text = XEasyPdfHandler.Text.build("test");
// 將組件添加到頁面
page.addComponent(text);
// 保存文檔并關閉
document.save(outputPath).close();
相關地址:
- 項目地址:https://x-easypdf.cn/
- 官網:https://gitee.com/dromara/x-easypdf
Jarboot:可視化 Java 進程管理平臺
項目介紹:
- Jarboot 是一款對業務代碼無侵入的可視化 Java 進程管理平臺,支持 Java 進程啟停、診斷、監控。
- Jarboot 支持開發者使用調試命令對其啟動的進程進行調試,有些命令是 Arthas 中的命令,用法大致相同。
效果預覽:
服務配置
在線診斷:
jad 反編譯:
系統實時數據面板:
原理:
Jarboot 具體的技術原理是通過 JavaAgent + ASM 來往目標 Java 進程注入代碼:
- JavaAgent 可以在加載 Java 文件之前對字節碼進行修改,也可以在運行期間對已經加載的類的字節碼進行修改。
- ASM 是一個 Java 字節碼操作框架,可以幫助我們操作 Java 字節碼。
市面上絕大部分的 Java 診斷/分析工具的原理都類似,只是具體使用的字節碼操作框架的不一樣。
Jarboot 基于 Vue3(前端) + SpringBoot(后端),通過 WebSocket 向前端界面實時推送進程的相關信息,同時與啟動的 Java 進程維持一個長連接,以監控其狀態。
類似于 Arthas,Jarboot 也提供了一些開箱即用的命令(如獲取 JVM 信息、 監控線程狀態、獲取線程棧信息等),并且,你還可以通過 SPI 擴展(支持 JDK 和 Spring 的 SPI)機制來實現自己的命令。
相關地址:
- Gitee 地址:https://gitee.com/majz0908/jarboot
- 文檔:https://www.yuque.com/jarboot