Go 言語では、関数のキャッシュは sync/cache ライブラリを使用して実装されます。関数呼び出しとその結果をキャッシュすることにより、待ち時間の短縮、スループットの向上、コストの削減などの利点が得られます。
#Go 言語関数キャッシュとマイクロサービス アーキテクチャの統合
はじめに#Inマイクロサービス アーキテクチャでは、関数キャッシュはパフォーマンスを大幅に向上させ、待ち時間を短縮できる強力なテクノロジです。この記事では、Go 言語に関数キャッシュを統合する方法を検討し、実践的なケースを示します。
関数キャッシュ関数キャッシュには、関数呼び出しとその結果が保存されます。関数が再度呼び出されると、キャッシュは保存された結果を返すことができるため、繰り返し実行による計算オーバーヘッドが回避されます。これにより、次のような方法でパフォーマンスが大幅に向上します。
#CPU 使用率の削減
Go 言語は、関数キャッシュを実装するための標準ライブラリ sync/cache
を提供します。これは、キーを値にマップする同時実行性が安全なマップです。sync/cache キャッシュ関数呼び出しの使用例を次に示します。
import ( "sync" ) var cache = sync.Map{} func CachedFunction(key string) (string, error) { v, ok := cache.Load(key) if !ok { // 函数未缓存,执行计算并将其存储在缓存中 value, err := CalculateValue(key) if err != nil { return "", err } cache.Store(key, value) } return v.(string), nil }
CalculateValue は、キャッシュする関数です。 実践的なケース: マイクロサービス API 呼び出しのキャッシュ
次は、関数のキャッシュをマイクロサービス アーキテクチャに統合して API 呼び出しをキャッシュする方法を示す実践的なケースです。
import ( "fmt" "net/http" "sync" "github.com/go-chi/chi" ) var cache = sync.Map{} func main() { r := chi.NewRouter() r.Get("/api/users", CachedAPIHandler) http.ListenAndServe(":8080", r) } func CachedAPIHandler(w http.ResponseWriter, r *http.Request) { key := r.URL.Query().Get("id") v, ok := cache.Load(key) if !ok { // API 调用未缓存,执行调用并将其存储在缓存中 user, err := GetUserData(key) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return } cache.Store(key, user) } fmt.Fprintf(w, "%s", v.(string)) }
GetUserData
は、キャッシュされる API 呼び出しです。利点
統合関数キャッシュの利点は次のとおりです:
レイテンシの短縮:関数キャッシュは、マイクロサービス アーキテクチャのパフォーマンスを大幅に向上できる強力なツールです。 Go 言語の sync/cache ライブラリを使用すると、関数キャッシュをサービスに簡単に統合し、その利点を体験できます。
以上がgolang 関数キャッシュとマイクロサービス アーキテクチャを統合する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。