為什麼我選擇'golly”框架來建立我的下一個基於 Golang 的 REST API?
為什麼選擇Go(Golang)進行伺服器端開發?
選擇 Go (Golang) 進行伺服器端開發通常是由其關鍵優勢驅動的:
效能:Go 的並發模型是基於 Goroutine 和 Channel,可以同時高效處理多個任務,非常適合高效能伺服器應用。
簡單性:語言的設計簡單易讀,語法簡約。這使得維護變得更容易,即使對於大型專案也是如此。
快速編譯和執行:Go 直接編譯為機器碼,與 Python 或 Node.js 等解釋性語言相比,執行速度更快。
可擴展性:Go 內建的並發性和輕量級特性使其成為建立可處理大量請求的可擴展服務的不錯選擇。
強大的標準庫:Go 附帶了強大的標準庫,特別是用於建立網路服務、處理 HTTP 和管理並發,減少對外部依賴的需求。
這些因素使 Go 非常適合現代伺服器端應用程序,特別是當效能和可擴展性很重要時。
如何在 Golang 中建立 REST API 伺服器?
有很多框架可以在 Golang 中建立 REST API 伺服器,例如 Gin、Gorrilla-Mux 等等。
我們將使用一個新的框架 golly,它提供了一套全面的工具來建立您的 Golang 應用程式。
讓我們深入了解實作
我們想要建立的所需 API
GET /api/v1/users POST /api/v1/users PUT /api/v1/users/:id DELETE /api/v1/users/:id
一旦我們定義了所需的 API,我們就開始啟動 go 專案。使用以下指令:-
mkdir my-go-server cd my-go-server go mod init rest_server go get oss.nandlabs.io/golly
執行上述操作後,您應該可以看到如下所示的資料夾結構
現在我們可以開始建立我們想要的伺服器結構
建立一個 main.go 文件,其中包含 main(),即 golang 應用程式的入口點
package main import "rest_server/server" func main() { // create the instance of your server srv := server.NewServer() // start your server srv.Start() }
建立一個 /server/server.go 文件,其中包含您的伺服器設定
package server import ( "rest_server/handlers" "rest_server/store" "oss.nandlabs.io/golly/lifecycle" "oss.nandlabs.io/golly/rest/server" ) type Server struct { store *store.Store } func NewServer() *Server { return &Server{ store: store.NewStore(), } } func (s *Server) Start() { // register the router by creating the server object restServer, err := server.Default() if err != nil { panic(err) } // Add path prefix if you want restServer.Opts().PathPrefix = "/api/v1" // register routes restServer.Get("/users", handlers.GetUsers) restServer.Post("/users", handlers.AddUser) restServer.Put("/users/:id", handlers.UpdateUser) restServer.Delete("/users/:id", handlers.DeleteUser) // create the http.Server object and register the router as Handler // provide the necessary configurations such as PORT, ReadTimeout, WriteTimeout... manager := lifecycle.NewSimpleComponentManager() // Register the server manager.Register(restServer) // start the server manager.StartAndWait() }
您想要實現的應用程式結構如下
在 /store/store.go 下建立記憶體儲存以測試您的 CRUD 操作。
package store import "rest_server/models" type Store struct { data map[string]models.Item } var initStore *Store func NewStore() *Store { initStore = &Store{data: make(map[string]models.Item)} return initStore } func GetStore() *Store { return initStore } func (s *Store) GetAll() []models.Item { items := []models.Item{} for _, item := range s.data { items = append(items, item) } return items } func (s *Store) GetById(id string) (item models.Item, exists bool) { item, exists = s.data[id] return } func (s *Store) Put(id string, item models.Item) { s.data[id] = item } func (s *Store) Delete(id string) { delete(s.data, id) }
這指的是 /models/item.go 下的模型
GET /api/v1/users POST /api/v1/users PUT /api/v1/users/:id DELETE /api/v1/users/:id
處理程序將包含 /server/server.go 下定義的每個端點的處理程序。
/handlers/AddUser.go 的一個這樣的實作如下
mkdir my-go-server cd my-go-server go mod init rest_server go get oss.nandlabs.io/golly
類似地,您可以使用所需的邏輯來建立其他處理程序。
完整範例可以在此 github 儲存庫中找到
建立伺服器後,您可以使用下列命令啟動伺服器
package main import "rest_server/server" func main() { // create the instance of your server srv := server.NewServer() // start your server srv.Start() }
輸出應如下圖
您可以看到註冊的端點以及伺服器的啟動位置。
伺服器啟動後,您可以使用 Postman 或 Curl 指令來呼叫您的 API。
您可以看到我們使用 golang 中的 golly 框架啟動 REST 伺服器的速度有多快。
使用 golly 作為建立 Go 應用程式的首選框架的好處
- 所有使用的函式庫,包括生命週期管理、UUID 產生、日誌記錄、休息伺服器管理等等,都是由 golly 開箱即用提供的。
- 存在大量內建程式庫,我不必導入多個第三方庫,這使我的 go.mod 保持乾淨和易於管理。
- 簡單快速的模組實施,輕鬆的學習曲線。
- 開源函式庫
有關 golly 的更多詳細信息,請訪問存儲庫 Golly。您可以查看程式碼並隨時貢獻!
感謝您閱讀這篇文章! !
如果您有任何疑問,請在評論中添加。
以上是為什麼我選擇'golly”框架來建立我的下一個基於 Golang 的 REST API?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Go語言在構建高效且可擴展的系統中表現出色,其優勢包括:1.高性能:編譯成機器碼,運行速度快;2.並發編程:通過goroutines和channels簡化多任務處理;3.簡潔性:語法簡潔,降低學習和維護成本;4.跨平台:支持跨平台編譯,方便部署。

Golang在並發性上優於C ,而C 在原始速度上優於Golang。 1)Golang通過goroutine和channel實現高效並發,適合處理大量並發任務。 2)C 通過編譯器優化和標準庫,提供接近硬件的高性能,適合需要極致優化的應用。

Golang和Python各有优势:Golang适合高性能和并发编程,Python适用于数据科学和Web开发。Golang以其并发模型和高效性能著称,Python则以简洁语法和丰富库生态系统著称。

Golang在性能和可擴展性方面優於Python。 1)Golang的編譯型特性和高效並發模型使其在高並發場景下表現出色。 2)Python作為解釋型語言,執行速度較慢,但通過工具如Cython可優化性能。

goimpactsdevelopmentpositationality throughspeed,效率和模擬性。 1)速度:gocompilesquicklyandrunseff,IdealforlargeProjects.2)效率:效率:ITScomprehenSevestAndardArdardArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdEcceSteral Depentencies,增強的Depleflovelmentimency.3)簡單性。

Golang和C 在性能競賽中的表現各有優勢:1)Golang適合高並發和快速開發,2)C 提供更高性能和細粒度控制。選擇應基於項目需求和團隊技術棧。

C 更適合需要直接控制硬件資源和高性能優化的場景,而Golang更適合需要快速開發和高並發處理的場景。 1.C 的優勢在於其接近硬件的特性和高度的優化能力,適合遊戲開發等高性能需求。 2.Golang的優勢在於其簡潔的語法和天然的並發支持,適合高並發服務開發。

Golang和C 在性能上的差異主要體現在內存管理、編譯優化和運行時效率等方面。 1)Golang的垃圾回收機制方便但可能影響性能,2)C 的手動內存管理和編譯器優化在遞歸計算中表現更為高效。
