次の Golang ベースの REST API を構築するために golly フレームワークを選択したのはなぜですか?
サーバーサイド開発に Go (Golang) を選択する理由
サーバーサイド開発に Go (Golang) を選択するのは、多くの場合、その主な強みによって決まります。
パフォーマンス: Go の同時実行モデルは、ゴルーチンとチャネルに基づいており、複数のタスクを同時に効率的に処理できるため、高パフォーマンスのサーバー アプリケーションに最適です。
シンプルさ: この言語は、最小限の構文でシンプルで読みやすいように設計されています。これにより、大規模なプロジェクトであってもメンテナンスが容易になります。
高速なコンパイルと実行: Go はマシン コードに直接コンパイルされるため、Python や Node.js などのインタープリタ型言語と比較して実行時間が高速になります。
スケーラビリティ: Go の組み込み同時実行性と軽量な性質により、多数のリクエストを処理できるスケーラブルなサービスを構築するのに適しています。
強力な標準ライブラリ: Go には、特にネットワーク化されたサービスの構築、HTTP の処理、同時実行性の管理のための強力な標準ライブラリが付属しており、外部依存関係の必要性が軽減されます。
これらの要素により、Go は、特にパフォーマンスとスケーラビリティが重要な場合に、最新のサーバーサイド アプリケーションに最適になります。
Golang で REST API サーバーを構築するにはどうすればよいですか?
Gin、Gorrilla-Mux など、Golang で REST API サーバーを構築するためのフレームワークが多数存在します。
Golang アプリケーションを構築するための包括的なツール セットを提供する新しいフレームワーク goly を使用します。
実装を詳しく見てみましょう
構築したい望ましい API
GET /api/v1/users POST /api/v1/users PUT /api/v1/users/:id DELETE /api/v1/users/:id
必要な API を定義したら、プロジェクトを開始することから始めます。次のコマンドを使用します:-
mkdir my-go-server cd my-go-server go mod init rest_server go get oss.nandlabs.io/golly
上記のアクションを実行すると、以下のようなフォルダー構造が表示されるはずです
これで、目的のサーバー構造の作成を開始できます
main()、つまり golang アプリケーションのエントリ ポイントを含む main.go ファイルを作成します
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() }
実現したいアプリケーション構造は以下のようなものです
CRUD 操作をテストするために、/store/store.go にインメモリ ストアを作成します。
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 の実装の 1 つを以下に示します。
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 の goly フレームワークを使用して、いかに迅速に REST サーバーを起動できたかがわかります。
Go アプリケーションを構築するための頼りになるフレームワークとして golly を使用する利点
- ライフサイクル管理、UUID 生成、ロギング、残りサーバー管理など、使用されるすべてのライブラリは golly によってすぐに提供されます。
- 多数の組み込みライブラリが存在し、複数のサードパーティ ライブラリをインポートする必要がないため、go.mod がクリーンで管理しやすくなります。
- モジュールのシンプルかつ迅速な実装、容易な学習曲線。
- オープンソース ライブラリ
Golly の詳細については、Golly リポジトリを参照してください。コードをチェックアウトして、お気軽に貢献してください!
この記事をお読みいただきありがとうございます!!
ご質問がございましたら、コメントにご記入ください。
以上が次の Golang ベースの REST API を構築するために golly フレームワークを選択したのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











OpenSSLは、安全な通信で広く使用されているオープンソースライブラリとして、暗号化アルゴリズム、キー、証明書管理機能を提供します。ただし、その歴史的バージョンにはいくつかの既知のセキュリティの脆弱性があり、その一部は非常に有害です。この記事では、Debian SystemsのOpenSSLの共通の脆弱性と対応測定に焦点を当てます。 Debianopensslの既知の脆弱性:OpenSSLは、次のようないくつかの深刻な脆弱性を経験しています。攻撃者は、この脆弱性を、暗号化キーなどを含む、サーバー上の不正な読み取りの敏感な情報に使用できます。

Beegoormフレームワークでは、モデルに関連付けられているデータベースを指定する方法は?多くのBEEGOプロジェクトでは、複数のデータベースを同時に操作する必要があります。 Beegoを使用する場合...

バックエンド学習パス:フロントエンドからバックエンドへの探査の旅は、フロントエンド開発から変わるバックエンド初心者として、すでにNodeJSの基盤を持っています...

redisstreamを使用してGo言語でメッセージキューを実装する問題は、GO言語とRedisを使用することです...

Golandのカスタム構造ラベルが表示されない場合はどうすればよいですか?ゴーランドを使用するためにGolandを使用する場合、多くの開発者はカスタム構造タグに遭遇します...

Go Crawler Collyのキュースレッドの問題は、Go言語でColly Crawler Libraryを使用する問題を調査します。 �...

この記事では、自動拡張を実現するためにDebianシステムでMongodbを構成する方法を紹介します。主な手順には、Mongodbレプリカセットとディスクスペース監視のセットアップが含まれます。 1。MongoDBのインストール最初に、MongoDBがDebianシステムにインストールされていることを確認してください。次のコマンドを使用してインストールします。sudoaptupdatesudoaptinstinstall-yymongodb-org2。mongodbレプリカセットMongodbレプリカセットの構成により、自動容量拡張を達成するための基礎となる高可用性とデータ冗長性が保証されます。 Mongodbサービスを開始:Sudosystemctlstartmongodsudosys
