滴滴打車如何找出方圓一千米內的乘客?揭開 GeoHash 的神祕面紗
背景–不知道大家是否思考過一個問題,在一些場景下(如大家在使用高德地圖打車的時候,鄰近的司機是如何知道你在他的附近並將你的打車通知推送給他去接單的?)是如何實現的?一般來講,大家也許會想到,首先肯定需要知道每位乘客的經緯度 (lng,lat),也即是二維座標(當然這是在絕對理想的情況,不考慮上下坡度)。而在知道了經緯度之後,一個暴力簡單且容易想到的思路就是將經緯度這個「二元組」 都存放在一個「 ⌘ Read more
負載均衡器有什麼用?
負載均衡器是一種在多個服務器之間分配網絡或應用程序流量的設備或軟件應用程序。其主要目的是確保沒有一臺服務器承擔過多的需求,從而提高應用程序的響應速度和可用性。在計算機發展的早期,負載均衡是一個手動過程。管理員手動配置 DNS 設置,在服務器之間分配流量。專用負載均衡設備的概念出現於 20 世紀 90 年代。思科和 F5 Networks 等公司開始開發硬件負載均衡器,提供更復雜、更自動化的流量分配 ⌘ Read more
Rust 編程範式最佳實踐
面向對象的 Rust與前面討論的函數式和命令式示例相反,讓我們引入一個新的結構體 FileFilter,它封裝了過濾文件和文件迭代的邏輯。pub struct FileFilter { predicates: VecBox ⌘ Read more
Go 實現可複用的通用內存緩存
本文介紹瞭如何在 Go 語言中創建一個可重用的內存通用緩存,並提供了具體的實現代碼和使用示例。Prerequisites安裝 Go go-cache package
Go:log 庫的全面指南與使用技巧
引言–在 Go 語言的標準庫中,log包提供了簡單而強大的日誌功能。日誌記錄是軟件開發中不可或缺的一部分,它不僅幫助開發人員調試和排查問題,還在系統運行中提供了寶貴的運行時信息。本文將詳細講解 Go 語言log庫的各種功能及其使用技巧,幫助開發者更好地掌握和應用這一重要工具。log 包簡介——-log包是 Go 語言標準庫的一部分,提供了基本的日誌記錄功能。它支持日誌消息的格式化、日誌輸 ⌘ Read more
深入理解 AI 大模型:參數、Token、上下文窗口、上下文長度和溫度
隨着人工智能技術的不斷髮展,AI 大模型在各個領域展現出強大的能力,也引起了廣泛關注。在瞭解這些模型時,我們經常會看到諸如「參數」、「Token」、「上下文窗口」、「上下文長度」 和「溫度」等術語。這些術語代表着什麼意思?它們對 AI 大模型有何影響?本文將深入淺出地爲你解析這些概念,並結合實際案例和數據,幫助你理解 AI 大模型的運作機制。Parameter 參數:模型的複雜度和性能指標—- ⌘ Read more
Go 實現雙 buffer id 生成器
本文通過 Go 實現一個 Leaf——美團點評分佈式 ID 生成系統 雙 buffer 的 id 獲取器。一. 主流程———-主流程看圖似乎步驟非常多,但實際上總結起來就以下三個步驟:客戶端發起請求 id 獲取器從緩存中獲取 如果 id 已經被消耗超過閾值,則重新加載新的號段到內存中 接下來我們來具體看一下 Go 代碼是如何實現的二. 代碼實現——-2.1 S ⌘ Read more
說一說 linux 虛擬機的 ringbuffer 大小由來
linux 下的網卡 ringbuffer 大小可以通過 ethtool -g eth0 獲取,eth0 是網卡設備名,如果是其他網卡則更換爲對應網卡名即可。
超級底層:10WQPS-PB 級海量存儲 HBase-RocksDB,底層 LSM 結構是什麼?
一次穿透:10WQPS/PB 級海量存儲 HBase/RocksDB 的底層 LSM 結構———————————————LSM tree 是很多數據庫內部的核心數據結構,包括 BigTable,ClickHouse、Cassandra, Scylla, RocksDB,HBase。ClickHouse、Cassandra, Scylla, ⌘ Read more
Go:For-Select-Done 併發設計模式應用
引言Go 語言支持的併發模型是其一大亮點,它內建的 Goroutine 機制爲構建高性能併發應用提供了基礎。在這種環境下,使用 For-Select-Done 設計模式可以優雅地處理併發任務和通道(Channel)的交互,從而實現高效的數據處理和狀態管理。For-Select-Done 設計模式概述For-Select-Done 模式是一種結構化的方式來處理 Go 中的多個通道讀寫操作,使代碼更加 ⌘ Read more
Netflix 如何打造高可靠在線有狀態系統
作者 | Joseph Lynch譯者 | 王強策劃 | Tina要點可靠性意味着花錢將故障概率、爆炸半徑和恢復時間都降至零。 大規模可靠服務的構建工作必須在客戶端、服務器和 API 上三管齊下。 可靠的服務器是冗餘的、對負載優化的和被大量緩存的。它們提供快速數據恢復和跨多個雲可用區利用多個複製副本的能力。 可靠的客戶端會持續迭代前進,並使用來自服務器的信號來學習如何重試或對沖請 ⌘ Read more
多模態大模型:基礎架構
文|龐德公編輯|郭嘉大模型技術論文不斷,每個月總會新增上千篇。本專欄精選論文重點解讀,主題還是圍繞着行業實踐和工程量產。若在某個環節出現卡點,可以回到大模型必備腔調或者 LLM 背後的基礎模型重新閱讀。而最新科技(Mamba,xLSTM,KAN)則提供了大模型領域最新技術跟蹤。若對於具身智能感興趣的請移步具身智能專欄。技術宅麻煩死磕 AI 架構設計。當然最重要的是訂閱 “魯班模錘”。 多模態大型 ⌘ Read more
10 分鐘瞭解 Golang 泛型
泛型是 Golang 在 1.18 版本引入的強大工具,能夠幫助我們在合適的場合實現簡潔、可讀、可維護的代碼。原文: Go Generics: Everything You Need To Know
如何優雅關閉過期訂單?
如何關閉過期訂單?設計一個關閉過期訂單的系統至關重要:資源管理 通過關閉過期訂單,系統可確保資源(如庫存、資金和人員)得到有效分配,不會被未完成或過期訂單佔用。用戶體驗 該系統允許與客戶就其訂單狀態進行清晰及時的溝通,防止出現混亂和潛在的不滿情緒。通過關閉過期訂單,系統可以集中精力處理有效訂單,提高整體服務效率和速度。運行效率 從活動隊列中刪除過期訂單可減少雜亂和簡化數據處理,從 ⌘ Read more
Rust 中的編程範式:命令式和函數式編程範式
Rust 是一種多範式編程語言,支持命令式、面向對象和函數式編程風格。風格的選擇通常取決於開發人員的背景和他們要解決的具體問題。隨着 Rust 吸引了來自 C++、Java、Python 和 Haskell 等不同背景的開發人員,它已經形成了自己獨特的風格和習慣用法。這種多樣性是一種優勢,但它也會導致在不同場景中使用哪種風格的不確定性。Rust 當然受到面向對象編程概念的影響,將它與其他面嚮對象語 ⌘ Read more
duckdb: 一個超火的數據庫,背後公司只有 18 人?
簡介–DuckDB 是一個嵌入式、內存中、SQL OLAP 數據庫管理系統。它提供了一種高效的方式來查詢和分析數據, 可以被集成到各種應用程序或編程語言中。最近非常的 🔥,一個月下載超過 200 萬次。實際上,這家位於荷蘭阿姆斯特丹的小型公司只有 18 人,下面這篇公衆號介紹了它的背景:震驚:開發一款世界矚目的數據庫僅需 18 人。這讓我想起了 clickhous。duckdb 的簡單易用、提供 ⌘ Read more
Zig 分配器的應用
假設我們想爲 Zig 編寫一個 HTTP 服務器庫
AI 大模型技術的四大核心架構演進之路
隨着人工智能技術的飛速發展,大模型技術已經成爲 AI 領域的重要分支。本文將深入探討四種關鍵的大模型技術架構:純粹 Prompt 提示詞法、Agent + Function Calling 機制、RAG(檢索增強生成)以及 Fine-tuning 微調技術,揭示它們的特性和應用場景。一、純粹 Prompt 提示詞法:構建直觀交互模式純粹 Prompt 提示詞法是 AI 大模型交互的直接形式,它通過 ⌘ Read more
cassowary: 現代跨平臺的 Go 語言 HTTP 負載測試工具
在現代互聯網應用程序中,性能和響應速度是決定用戶體驗的關鍵因素。負載測試是確保我們的應用程序在高併發下仍能穩定運行的一種重要手段。本文將帶你瞭解一個現代的跨平臺 HTTP 負載測試工具——cassowary,並展示其安裝和使用方法。什麼是 cassowary?————–cassowary 是一個用 Go 語言編寫的現代跨平臺 HTTP 負載測試工具。它設計簡潔、易於使用,支持高併 ⌘ Read more
在 Go 中如何優雅的使用 wire 依賴注入工具提高開發效率?上篇
如果你做過 Java 開發,那麼想必一定聽說或使用過依賴注入。依賴注入是一種軟件設計模式,它允許將組件的依賴項外部化,從而使組件本身更加模塊化和可測試。在 Java 中,依賴注入廣泛應用於各種框架中,幫助開發者解耦代碼和提高應用的靈活性。本文就來介紹下什麼是依賴注入,以及在 Go 語言中如何實踐依賴注入,提高 Go 項目的開發效率和可維護性。什麼是依賴注入?正如前文所述,依賴注入(dependen ⌘ Read more
如何在 Rust 中實現事件循環模式?
事件循環是編程中的一個基本概念,用作管理異步操作和確保系統響應的機制。它的功能是不斷檢查程序中的新事件或消息,根據需要處理它們,然後繼續檢查更多事件或消息。這種模式對於處理輸入 / 輸出操作、網絡通信和用戶交互等任務至關重要,從而不會阻塞其他代碼的執行。事件循環的重要意義在於它能夠有效地併發處理多個任務,而不依賴於傳統的同步方法,後者可能導致性能瓶頸和應用程序無響應。事件循環使程序在事件發生時異步 ⌘ Read more
基於 Rust 語言實現的去中心化 AI 網絡節點
在當今的技術世界中,去中心化和人工智能(AI)是兩個極具潛力的發展方向。Gaia 項目正是將這兩者結合起來,創造了一個去中心化的 AI 網絡節點。本文將深入探討 Gaia 項目的技術細節,通過豐富的示例和詳細描述,幫助讀者全面理解並掌握該技術。什麼是 Gaia?———Gaia 是一個去中心化的人工智能網絡,它旨在通過區塊鏈技術和去中心化網絡架構,提供安全、可靠且高效的 AI 服務。Ga ⌘ Read more
Go: 深入探究 uintptr 類型
Go 語言作爲一種靜態類型、編譯型語言,其獨特的類型系統爲編程提供了強大的支持。在衆多類型中,uintptr 是一個較爲特殊的類型,它用於存儲指針值的整數表示。本文將詳細介紹 uintptr 的概念、使用場景及其與普通指針類型的區別。uintptr 的定義與特性在 Go 語言中,uintptr 是一個無符號整數類型,其大小足以存儲任意指針的位模式。具體來說,uintptr 的定義如下:type u ⌘ Read more
conmon-rs 服務啓動流程源碼分析
conmon-rs 是一個用 Rust 編寫的 pod 級別的 OCI 容器運行時監視器,旨在擴展並取代現有的 conmon 功能,不僅監視單個容器,還監視整個 pod。通過 UNIX 域套接字處理新容器和執行進程的請求,提升了管理效率。本文主要分析 conmon-rs 服務的啓動流程。 涉及源碼版本:v0.6.31. 函數入口// conmon-rs/server/src/main.rs:4f ⌘ Read more
如何在 API 設計中執行分頁
在 API 設計中,分頁對於高效處理大型數據集和提高性能至關重要。以下是六種常用的分頁技術:01 基於偏移的分頁———-這種技術使用 offset 和 limit 參數來定義起點和要返回的記錄數。例如:GET /orders?offset=0&limit=3優點:易於實現和理解。 缺點:由於需要掃描和跳過記錄,因此偏移量較大時效率可能會降低。 02 基於遊標的分頁—– ⌘ Read more
Kafka 如何實現每秒百萬級高併發寫入?
大家好,我是 mikechen。磁盤順序寫Kafka 採用順序寫入日誌文件的方式,這種方式比隨機寫入快得多。爲什麼採用磁盤順序寫要快很多呢?如下圖所示:一般,完成一次磁盤 I/O(輸入 / 輸出)操作,通常需要經歷以下三個主要步驟:尋道、旋轉、和數據傳輸。尋道:磁頭從當前位置,移動到包含目標數據的軌道,這個過程可能需要幾毫秒時間; 旋轉:盤片旋轉直到目標數據正好位於磁頭下方,通常也需要幾毫秒 ⌘ Read more
乖乖,PG 高可用咱不用主從流複製了,咱試試 patroni
作者:IT邦德中國DBA聯盟(ACDU)成員,10餘年DBA工作經驗,Oracle、PostgreSQL ACECSDN博客專家及B站知名UP主,全網粉絲10萬+擅長主流Oracle、MySQL、PG、高斯及Greenplum備份恢復,安裝遷移,性能優化、故障應急處理微信:jemdbQQ交流羣:587159446公衆號:IT邦德前言 Patroni 用於構建高可用 PostgreSQL 集羣的工 ⌘ Read more
一文了解 Rust 語言中的雙向鏈表
Rust 作爲一門面向安全性和性能的系統編程語言,提供了強大的內建數據結構支持,其中LinkedList是其標準庫std::collections中一個重要的組成部分。本文將深入探討 Rust 中的雙向鏈表,包括其特性、應用場景以及高效使用方法。什麼是雙向鏈表?——–在講述雙向鏈表之前,我們先簡要回顧下鏈表的概念。鏈表是一種常見的線性數據結構,它由一系列節點組成,每個節點包含數據部分和指 ⌘ Read more
從原理到實踐:完全掌握零拷貝技術
零拷貝技術是一種優化數據傳輸的技術,旨在減少數據在內存之間的拷貝次數,從而提高數據傳輸性能和降低 CPU 的負載。傳統的數據傳輸方式涉及多次拷貝操作:首先將數據從磁盤讀取到內核緩衝區,然後再將數據從內核緩衝區複製到應用程序緩衝區。而零拷貝技術通過避免不必要的數據拷貝,直接將數據從磁盤讀取或網絡接收到用戶空間應用程序所使用的內存中。它利用了文件描述符、DMA(直接內存訪問)等機制,在內核態和用戶態之 ⌘ Read more
簡易評論系統設計
需求分析—-評論系統是互聯網社區網站的重要組成部分,對增強用戶參與度、提高網站活躍度等方面都具有重要價值。一個簡易的評論系統(在線社區平臺)通常包含以下功能用戶評論:用戶可以對某個產品、主題進行評論,包括文字評論。 評論展示:所有用戶的評論將會在產品或服務頁面下方展示,其他用戶可以查看。 評論的展示有多種組織方式,參考《評論系統的幾種展示結構和存儲設計》,本文主要針對常見的二級嵌套 ⌘ Read more
RAE:通過檢索增強來完成事件提取任務
Decompose, Enrich, and Extract! Schema-aware Event Extraction using LLMs 大型語言模型(LLMs)在處理自然語言數據方面能力卓越,能從多樣的文本資源中高效提取知識,助力情境洞察與決策支持。但其易產生幻覺的弱點,導致上下文信息失真,引發擔憂。本研究聚焦於利用 LLMs 自動提取事件,創新性地將任務拆分爲事件檢測與事件論 ⌘ Read more
實時數據的處理一致性如何保證?
摘要:在當今快速發展的數字化世界中,實時數據處理變得至關重要。無論是金融服務、在線零售、社交媒體還是物聯網 (IoT),實時數據流爲企業提供了即時的洞察和決策支持。然而,隨着數據量的激增和處理速度的加快,保證數據的一致性成爲了一個巨大挑戰。 實時數據一致性的定義以及面臨的挑戰 實時數據處理系統如何保障一致性 01 實時數據一致性的定義以及面臨的挑戰數據一致性通常指的是數據在整 ⌘ Read more
五分鐘學 NGINX - 詳解 Nginx 如何處理 HTTP 頭部
Nginx 作爲高性能的 HTTP 服務器和反向代理服務器,在處理 HTTP 請求時,對 HTTP 頭部的處理是至關重要的一環。接收請求事件模塊 Nginx 使用了一個事件驅動的架構,這使得它能夠高效地處理大量的併發連接。下面是 Nginx 處理 HTTP 請求的詳細流程:1. 建立連接———– 三次握手:客戶端通過發送 SYN 包開始與 Nginx 建立 TCP ⌘ Read more
給 Rust 新手力薦的《Learning Rust》教程
引言—-作爲一個系統級編程語言,Rust 以其高性能和內存安全著稱。然而對於初學者來說,Rust 的學習曲線比較陡峭。今天我想給大家推薦一本很棒的 Rust 學習教程——《Learning Rust》,它可以幫助 Rust 新手更好地掌握這門語言。創作背景—-《Learning Rust》是 GitHub 上的一個開源項目,項目地址爲 https://github.com/QuineDot ⌘ Read more
內存管理中分頁和分段有什麼區別?
分頁和分段是操作系統在內存管理中用於有效分配內存和管理進程的兩種基本技術。01 分頁(Paging)————-分頁是一種無需連續分配物理內存的內存管理方案。進程的地址空間被劃分爲固定大小的塊,稱爲頁,而物理內存被劃分爲固定大小的塊,稱爲幀。關鍵概念頁:進程地址空間的固定大小塊。 幀:物理內存的固定大小塊。 頁表:用於將虛擬地址映射到物理地址的數據結構。頁表中的每個條目對 ⌘ Read more
深入理解一致性 Hash 和虛擬節點
在分佈式系統中架構中我們經常提到一致性哈希算法,那麼什麼是一致性哈希算法,爲什麼需要一致性哈希算法呢? 1、爲什麼需要一致性哈希算法 假設現在有三臺緩存服務器(緩存服務器 A、緩存服務器 B、緩存服務器 C),現在將數據預熱到這三臺服務器,我們可以使用負載均衡的方法將數據緩存到服務器上,如下圖所示: 通過負載均衡的方式可以把數據均勻的分發到三臺緩存服務器上,在讀取緩存 ⌘ Read more
【網絡協議】精講 UDP 協議特點和報文格式!圖解超讚超詳細!!!
大家好,我是 風雲說通信 ,深耕無線通信網絡協議領域: CSDN 博客:https://blog.csdn.net/jly20220520?type=blog 更多藍牙知識,盡在博客專欄:精講藍牙協議棧、精講 BLE 協議棧、Android Bluetooth Stack * 更多 3GPP 協議知識,盡在博客專欄:*精講 3GPP 協議棧1. UDP 定 ⌘ Read more
一文了解 OTA 升級功能
當今這個年代,大家對於汽車上的 OTA 升級功能都不再陌生,因爲大多數車都支持這一功能,一年當中總會碰到一兩次 OTA 免費升級的推送信息。source:http://it.cha138.com/android/show-77091.html既然 OTA 功能已經這麼普遍,那麼本文就來詳細瞭解 OTA 是什麼?OTA 有什麼用?等等問題。1 什麼是 OTA隨着智能網聯和智能駕駛的快速發展,汽車控制 ⌘ Read more
6 大分庫分表中間件詳解 -圖文全面總結-
大家好,我是 mikechen。分庫分表是大型架構的必備技能,也是大廠經常考察的重點對象,下面我就全面來詳解分庫分表中間件 @mikechen分庫分表分庫分表:是數據庫水平擴展的一種常見策略,用於處理大規模數據、和高併發請求。如下圖所示:分庫分表,這裏分爲兩個方面,包含:分庫、和分表兩種策略。1、分庫分庫:就是將數據水平分散到多個數據庫實例中,每個數據庫實例可以部署在不同的服務器上,從而減輕單個數 ⌘ Read more
TCP-IP 協議、三次握手、四次揮手詳解
TCP/IP 協議模型(TCP 協議) 傳輸控制協議是一種面向連接的、可靠的、基於字節流的方式進行有序的無差錯的數據傳輸通訊協議,它負責完成傳輸層所指定的功能,利用重發技術和擁塞控制機制,嚮應用程序提供可靠的通信連接,使它能夠自動適應網上的各種變化。比如:數據報檢測、流量控制、擁塞控制、數據排序、超時重發等TCP/IP 是一個協議族,包括 TCP、IP、UDP、ICMP、RIP、SMTP、ARP、 ⌘ Read more
這些單片機也能運行 Rust 啦!
隨着 Rust 的快速發展,Rust 在嵌入式中的支持越來越豐富。目前已經有非常多的 Rust 嵌入式項目和 Rust 單片機外設支持庫。理論上來說,目前大部分的 ARM、RISC-V 單片機 都能運行 Rust,但大部分單片機官方沒有編寫 Rust 外設庫,因此用戶暫時無法直接開發 Rust 應用。本文將介紹幾個已經支持 Rust 外設庫的常用單片機,包括 STM、 ESP、 AVR 、NRF ⌘ Read more
高可用存儲架構:集羣和分區
主備、主從、和主主架構都基於一個共同的前提:主機需要有能力存儲所有數據。然而,主機的存儲和處理容量是有限的。以歷史發展爲例,Intel 386 時代的服務器僅能存儲幾百 MB 數據,到了 Intel 奔騰時代則能夠存儲幾十 GB,而進入 Intel 酷睿多核時代後,服務器的存儲能力增加到了數 TB。儘管從硬件發展角度看,存儲能力的提升速度相當快,但與業務需求的增長速度相比,這種提升還是遠遠不夠。例 ⌘ Read more
【網絡協議】精講 TCP 狀態機!圖解超讚超詳細!!!
大家好,我是 風雲說通信 ,深耕無線通信網絡協議領域: CSDN 博客:https://blog.csdn.net/jly20220520?type=blog 更多藍牙知識,盡在博客專欄:精講藍牙協議棧、精講 BLE 協議棧、Android Bluetooth Stack * 更多 3GPP 協議知識,盡在博客專欄:*精講 3GPP 協議棧今天我們來學習下 ⌘ Read more
深入理解分佈式鎖——以 Redis 爲例
一、分佈式鎖簡介——–1. 什麼是分佈式鎖分佈式鎖是一種在分佈式系統環境下,通過多個節點對共享資源進行訪問控制的一種同步機制。它的主要目的是防止多個節點同時操作同一份數據,從而避免數據的不一致性。線程鎖: 也被稱爲互斥鎖(Mutex),主要用於控制同一進程中的多個線程對共享資源的訪問。 進程鎖 進程鎖是用於控制同一臺機器上的多個進程對共享資源的訪問。進程 ⌘ Read more
7 個強大的文字轉語音 TTS 引擎
文本到語音(TTS)技術讓機器能以人聲般自然地 “說話”,架起了人機溝通的新橋樑。探索這一技術,開源 TTS 引擎以其開放性和經濟性,成爲創新者們的寵兒,爲智能應用注入活力。本文分享 7 個好用的開源文本到語音 (TTS) 引擎,爲讀者在技術選擇上提供清晰的視角和實用的參考。文本到語音 (TTS) 引擎文本到語音(TTS)引擎,是一種將文字信息轉化爲口語表達的智能軟件。它通過自然語言處理(NLP) ⌘ Read more
實戰 Linux I-O 多路複用:藉助 epoll,單線程高效管理 10-000 - 併發連接
引言– 在應對高併發連接的傳統策略中,普遍採取爲每個連接配置單獨線程或進程的直接方式,管理其 I/O 操作。此法雖直觀易行,但隨業務規模擴張,線程資源需求急劇上升。相反,Linux 下的 I/O 多路複用技術,尤其是epoll,展示了一種高效路徑:單一線程即可監控成千上萬的文件描述符,極大提升了資源使用效率。 I/O 多路複用的場景有很多,也比較實用。通常用法epoll線程 + 線程 / ⌘ Read more
Fastwhisper - Pyannote 實現 ASR - 說話者識別
前言最近在研究ASR相關的業務,也是調研了不少模型,踩了不少坑,ASR這塊,目前中文普通話效果最好的應該是阿里的modelscope上的中文模型了,英文的話,還是非whisper莫屬了,而且whisper很變態,粵語效果也還不錯,因此,如果實際業務中需要涉及到不同的語言,還是更推薦whisper多一點一、faster-whisper 簡單介紹faster-whisper是使用CTranslate2 ⌘ Read more
圖解支付系統的交易訂單狀態機設計
大家好,我是隱墨星辰,今天和大家聊聊交易單據狀態機的設計與核心代碼實現。假如你做的是支付、電商等這類交易系統,但沒有聽過狀態機,或者你聽過但沒有寫過,又或者你是使用 if else 或 switch case 來寫交易訂單的狀態推進,建議花點時間看看,一定會有不一樣的收穫。如果你是產品經理,可以考慮推薦給你們的研發同學,說不定能提升系統的健壯性。這篇文章主要講清楚:清楚什麼是狀態機,簡潔的狀態機對 ⌘ Read more
Rust - 性能超越 Kotlin 的跨平臺方案
現如今很多應用程序,爲了覆蓋儘可能多的用戶羣體會選擇同時在多個主流平臺上進行開發:移動端:iOS,android 桌面端:osx,windows,linux Web 端 所有平臺都基於各自的原生技術開發,雖然用戶體驗好但開發效率卻很低。爲了兼顧用戶體驗和開發效率,市面上誕生了一批跨平臺解決方案:移動端:apache cordova,react native,weex,flutte ⌘ Read more
Go 事件驅動編程:實現一個簡單的事件總線
前言在當今微服務和分佈式系統盛行的背景下,事件驅動架構(Event-Driven Architecture,EDA)扮演着一個至關重要的角色,此架構的設計使得服務間可以通過事件進行同步或異步通信,替代了傳統的直接接口調用。基於事件的交互方式,促進了服務之間的松耦合,提高系統的可擴展性。發佈 - 訂閱模式是實現事件驅動架構的模式之一,它允許系統的不同組件或服務發佈事件,而其他組件或服務可以訂閱這些事 ⌘ Read more