ホームページ バックエンド開発 Golang ZooKeeper を使用して Beego でサービスの登録と検出を実装する

ZooKeeper を使用して Beego でサービスの登録と検出を実装する

Jun 22, 2023 am 08:21 AM
サービスディスカバリ zookeeper beego

マイクロサービス アーキテクチャでは、サービスの登録と検出は非常に重要な問題です。この問題を解決するには、ZooKeeper をサービス登録センターとして使用します。この記事では、Beego フレームワークで ZooKeeper を使用してサービスの登録と検出を実装する方法を紹介します。

1. ZooKeeper の概要

ZooKeeper は、オープンソースの分散調整サービスであり、Apache Hadoop のサブプロジェクトの 1 つです。 ZooKeeper の主な役割は、分散アプリケーションを調整し、分散ロック、ネーミング サービス、構成管理、分散同期などの機能を提供することです。マイクロサービス アーキテクチャでは、ZooKeeper がサービス レジストリとしてよく使用されます。

2. ZooKeeper のインストールと構成

ZooKeeper のインストールと構成については、公式 Web サイトのドキュメントを参照してください: https://zookeeper.apache.org/doc/r3.6.3/インデックス.html。ここでは、一般的に使用されるいくつかの設定項目のみを紹介します。 ZooKeeper は、ZooKeeper 設定ファイルzoo.cfgで設定できます。

以下は重要な設定項目の一部です:

  • tickTime: これは、ZooKeeper によって使用される基本時間 (ミリ秒単位) です。通常は 2000ms に設定されます。
  • initLimit: これは、選挙に参加するための時間制限です。ZooKeeper サーバー間の接続を開始するための最大時間であり、tickTime の倍数で表されます。通常は 5 に設定されます。
  • syncLimit: これは、リーダーから最新のトランザクションを受信するための時間制限であり、tickTime の倍数で表されます。通常は 2 に設定されます。
  • dataDir: これは ZooKeeper のデータ ディレクトリであり、デフォルトでは /var/lib/zookeeper です。
  • clientPort: これは、ZooKeeper サーバーがリッスンするクライアント接続ポートです。デフォルトは 2181 です。

3. Beego フレームワークは ZooKeeper を統合します

  1. ZooKeeper クライアント ライブラリの紹介

Beego フレームワークで ZooKeeper を使用するには、ZooKeeper を導入する必要がありますクライアントライブラリ。 Go Zookeeper クライアント ライブラリ zk を使用して、ZooKeeper クライアント操作を実装できます。

次のコマンドを使用してインストールできます:

go get github.com/samuel/go-zookeeper/zk

  1. サービスの登録と検出を実装します

Beego フレームワークでは、ZooKeeper でのサービス登録および検出操作のために ZooKeeper クライアント オブジェクトをカプセル化できます。

以下は、ZooKeeper クライアントのサンプル コードです。

package zk

import (
    "encoding/json"
    "fmt"
    "strings"
    "time"

    "github.com/samuel/go-zookeeper/zk"
)

type Server struct {
    Host string `json:"host"`
    Port int    `json:"port"`
}

type ZkClient struct {
    hosts          []string
    conn           *zk.Conn
    serversPath    string
    sessionTimeout time.Duration
}

func NewZkClient(hosts []string, serversPath string, sessionTimeout int) (*ZkClient, error) {
    // 链接zk,创建授权节点 /servers
    c, _, err := zk.Connect(hosts, time.Duration(sessionTimeout)*time.Second)
    if err != nil {
        return nil, err
    }
    if exists, _, err := c.Exists(serversPath); err != nil {
        return nil, err
    } else if !exists {
        if _, err := c.Create(serversPath, nil, 0, zk.WorldACL(zk.PermAll)); err != nil {
            return nil, fmt.Errorf("create znode error(%v)", err)
        }
    }
    return &ZkClient{
        hosts:          hosts,
        conn:           c,
        serversPath:    serversPath,
        sessionTimeout: time.Duration(sessionTimeout) * time.Second,
    }, nil
}

func (zk *ZkClient) Close() {
    zk.conn.Close()
}

// 检测授权节点是否存在
func (zk *ZkClient) ensureServerPath() error {
    exists, _, err := zk.conn.Exists(zk.serversPath)
    if err != nil {
        return err
    }
    if !exists {
        _, err = zk.conn.Create(zk.serversPath, []byte(""), 0, zk.WorldACL(zk.PermAll))
    }
    return err
}

func (zk *ZkClient) Register(server *Server) error {
    if err := zk.ensureServerPath(); err != nil {
        return fmt.Errorf("register: ensureServerPath error(%v)", err)
    }
    //在 /servers 节点下创建一个临时性节点,节点名为 IP:Port。
    path := fmt.Sprintf("%s/%s:%d", zk.serversPath, server.Host, server.Port)
    if _, err := zk.conn.Create(path, []byte(""), zk.FlagEphemeral, zk.WorldACL(zk.PermAll)); err != nil {
        return fmt.Errorf("register: create error(%v)", err)
    }
    return nil
}

// 获取所有服务器列表
func (zk *ZkClient) GetServers() ([]Server, error) {
    list, _, err := zk.conn.Children(zk.serversPath)
    if err != nil {
        return nil, err
    }
    servers := make([]Server, 0, len(list))
    for _, node := range list {
        data, _, err := zk.conn.Get(zk.serversPath + "/" + node)
        if err != nil {
            continue
        }
        arr := strings.Split(node, ":")
        servers = append(servers, Server{
            Host: arr[0],
            Port: str2Int(arr[1]),
        })
    }
    return servers, nil
}

func (zk *ZkClient) WatchServers() ([]Server, <-chan zk.Event, error) {
    list, _, ch, err := zk.conn.ChildrenW(zk.serversPath)
    if err != nil {
        return nil, nil, err
    }
    servers := make([]Server, 0, len(list))
    for _, node := range list {
        data, _, err := zk.conn.Get(zk.serversPath + "/" + node)
        if err != nil {
            continue
        }
        arr := strings.Split(node, ":")
        servers = append(servers, Server{
            Host: arr[0],
            Port: str2Int(arr[1]),
        })
    }
    return servers, ch, nil
}

// 删除授权节点
func (zk *ZkClient) Remove(server *Server) error {
    path := fmt.Sprintf("%s/%s:%d", zk.serversPath, server.Host, server.Port)
    return zk.conn.Delete(path, -1)
}

func str2Int(str string) int {
    var (
        num int
        err error
    )
    if num, err = strconv.Atoi(str); err != nil {
        panic(err)
    }
    return num
}
ログイン後にコピー

ZooKeeper クライアント オブジェクトを実装した後、そのオブジェクトを使用してサービスを登録し、呼び出すことができます。

Beego フレームワークでは、初期化関数で ZooKeeper クライアント オブジェクトを作成できます。同時に、API リクエスト処理では、このオブジェクトを使用してサービスを検出し、呼び出すことができます。

次は、ZooKeeper を使用してサービスを登録および呼び出すためのサンプル コードです:

package controllers

import (
    "encoding/json"
    "fmt"
    "log"

    "github.com/astaxie/beego"
    "github.com/my/go-zk"
)

type MyController struct {
    beego.Controller
    zkCli *zk.ZkClient
}

func (c *MyController) Prepare() {
    var (
        err error
    )
    // 初始化ZooKeeper客户端
    servers := []string{"localhost:2181"}
    serversPath := "/myapp/servers"
    sessionTimeout := 30
    c.zkCli, err = zk.NewZkClient(servers, serversPath, sessionTimeout)
    if err != nil {
        log.Fatal(err)
    }
}

func (c *MyController) Get() {
    // 查询服务列表
    servers, _, err := c.zkCli.WatchServers()
    if err != nil {
        c.Data["json"] = map[string]interface{}{
            "code":    1001,
            "message": fmt.Sprintf("get servers error(%v)", err),
        }
        c.ServeJSON()
        return
    }
    // 随机调用一个服务
    if len(servers) == 0 {
        c.Data["json"] = map[string]interface{}{
            "code":    1002,
            "message": "no available servers",
        }
        c.ServeJSON()
        return
    }
    server := servers[rand.Intn(len(servers))]
    url := fmt.Sprintf("http://%s:%d/hello", server.Host, server.Port)
    resp, err := http.Get(url)
    if err != nil {
        c.Data["json"] = map[string]interface{}{
            "code":    1003,
            "message": fmt.Sprintf("call server error(%v)", err),
        }
        c.ServeJSON()
        return
    }
    defer resp.Body.Close()
    result, err := ioutil.ReadAll(resp.Body)
    if err != nil {
        c.Data["json"] = map[string]interface{}{
            "code":    1004,
            "message": fmt.Sprintf("read response error(%v)", err),
        }
        c.ServeJSON()
        return
    }
    var respData struct {
        Code int    `json:"code"`
        Msg  string `json:"msg"`
    }
    if err = json.Unmarshal(result, &respData); err != nil {
        c.Data["json"] = map[string]interface{}{
            "code":    1005,
            "message": fmt.Sprintf("parse response error(%v)", err),
        }
        c.ServeJSON()
        return
    }
    c.Data["json"] = respData
    c.ServeJSON()
}

func (c *MyController) Delete() {
    var (
        server zk.Server
        err    error
    )
    // 解析请求数据
    if err = json.Unmarshal(c.Ctx.Input.RequestBody, &server); err != nil {
        c.Data["json"] = map[string]interface{}{
            "code":    1001,
            "message": "invalid parameters",
        }
        c.ServeJSON()
        return
    }
    // 删除ZooKeeper中保存的服务节点
    if err = c.zkCli.Remove(&server); err != nil {
        c.Data["json"] = map[string]interface{}{
            "code":    1001,
            "message": fmt.Sprintf("delete server error(%v)", err),
        }
        c.ServeJSON()
        return
    }
    c.Data["json"] = map[string]interface{}{
        "code":    200,
        "message": "success",
    }
    c.ServeJSON()
}

func (c *MyController) Post() {
    var (
        server zk.Server
        err    error
    )
    // 解析请求数据
    if err = json.Unmarshal(c.Ctx.Input.RequestBody, &server); err != nil {
        c.Data["json"] = map[string]interface{}{
            "code":    1001,
            "message": "invalid parameters",
        }
        c.ServeJSON()
        return
    }
    // 注册服务到ZooKeeper
    if err = c.zkCli.Register(&server); err != nil {
        c.Data["json"] = map[string]interface{}{
            "code":    1001,
            "message": fmt.Sprintf("register server error(%v)", err),
        }
        c.ServeJSON()
        return
    }
    c.Data["json"] = map[string]interface{}{
        "code":    200,
        "message": "success",
    }
    c.ServeJSON()
}

func (c *MyController) Finish() {
    // 关闭ZooKeeper客户端
    c.zkCli.Close()
}
ログイン後にコピー

4. 概要

この記事では、Beego フレームワークで ZooKeeper を使用する方法を紹介しました。 . サービスの登録と検出。最初に ZooKeeper のインストールと構成について紹介し、次に ZooKeeper クライアントをカプセル化するサンプル コードを作成しました。最後に、Beego フレームワークを使用して、このサンプル コードを使用してサービスの登録と検出を実装する方法を示しました。この記事が皆さんのお役に立てば幸いです。

以上がZooKeeper を使用して Beego でサービスの登録と検出を実装するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Prometheus と Grafana を使用して Beego で監視と警報を実装する Prometheus と Grafana を使用して Beego で監視と警報を実装する Jun 22, 2023 am 09:06 AM

クラウド コンピューティングとマイクロサービスの台頭により、アプリケーションの複雑さは増大しています。したがって、監視と診断は重要な開発タスクの 1 つになります。この点に関して、Prometheus と Grafana は、開発者がアプリケーションをより適切に監視および分析できるようにする 2 つの人気のあるオープンソース監視および視覚化ツールです。この記事では、Prometheus と Grafana を使用して、Beego フレームワークに監視と警報を実装する方法を説明します。 1. はじめに Beego は、オープンソースの高速開発 Web アプリケーションです。

Google Analytics を使用して Beego の Web サイトデータをカウントする Google Analytics を使用して Beego の Web サイトデータをカウントする Jun 22, 2023 am 09:19 AM

インターネットの急速な発展に伴い、Web アプリケーションの使用がますます一般的になり、Web アプリケーションの使用状況をどのように監視および分析するかが開発者や Web サイト運営者の焦点になっています。 Google Analytics は、Web サイト訪問者の行動を追跡および分析できる強力な Web サイト分析ツールです。この記事では、Beego で Google Analytics を使用して Web サイトのデータを収集する方法を紹介します。 1. Google Analytics アカウントを登録するには、まず次のことを行う必要があります。

分散システムの構築: Nginx Proxy Manager を使用してサービス検出とルーティングを実装する 分散システムの構築: Nginx Proxy Manager を使用してサービス検出とルーティングを実装する Sep 26, 2023 am 10:03 AM

分散システムの構築: NginxProxyManager を使用したサービス検出とルーティングの実装 概要: 最新の分散システムでは、サービス検出とルーティングは非常に重要な機能です。サービス ディスカバリにより、システムは利用可能なサービス インスタンスを自動的に検出して登録できるようになり、ルーティングによりリクエストが適切なサービス インスタンスに正しく転送されることが保証されます。この記事では、NginxProxyManager を活用してシンプルかつ強力なサービス検出およびルーティング ソリューションを構築する方法を紹介し、具体的なコード例を示します。

Beego でのエラー処理 - アプリケーションのクラッシュを防ぐ Beego でのエラー処理 - アプリケーションのクラッシュを防ぐ Jun 22, 2023 am 11:50 AM

Beego フレームワークでは、エラー処理は非常に重要な部分です。アプリケーションに正しく完全なエラー処理メカニズムが備わっていないと、アプリケーションがクラッシュしたり、正しく実行されなくなる可能性があり、これはプロジェクトとユーザーの両方にとって重要です。非常に深刻な問題。 Beego フレームワークは、これらの問題を回避し、コードをより堅牢で保守しやすくするのに役立つ一連のメカニズムを提供します。この記事では、Beego フレームワークのエラー処理メカニズムを紹介し、それらがエラーの回避にどのように役立つかについて説明します。

テクノロジーの世界を探索できる、厳選された 5 つの Go 言語オープンソース プロジェクト テクノロジーの世界を探索できる、厳選された 5 つの Go 言語オープンソース プロジェクト Jan 30, 2024 am 09:08 AM

今日の急速な技術発展の時代では、雨後の筍のようにプログラミング言語が出現しています。多くの注目を集めている言語の 1 つは Go 言語です。Go 言語は、そのシンプルさ、効率性、同時実行の安全性などの機能により多くの開発者に愛されています。 Go 言語は、多くの優れたオープンソース プロジェクトがある強力なエコシステムで知られています。この記事では、厳選された 5 つの Go 言語オープンソース プロジェクトを紹介し、読者を Go 言語オープンソース プロジェクトの世界へ導きます。 KubernetesKubernetes は、自動化されたオープンソースのコンテナ オーケストレーション エンジンです。

Beego での分散調整と管理のための ZooKeeper と Curator の使用 Beego での分散調整と管理のための ZooKeeper と Curator の使用 Jun 22, 2023 pm 09:27 PM

インターネットの急速な発展に伴い、分散システムは多くの企業や組織のインフラストラクチャの 1 つになりました。分散システムが適切に機能するには、調整して管理する必要があります。この点で、ZooKeeper と Curator は使用する価値のある 2 つのツールです。 ZooKeeper は、クラスター内のノード間のステータスとデータを調整するのに役立つ、非常に人気のある分散調整サービスです。 Curator は ZooKeeper のカプセル化です

Beego の Docker と Kubernetes を使用した本番環境のデプロイと管理 Beego の Docker と Kubernetes を使用した本番環境のデプロイと管理 Jun 23, 2023 am 08:58 AM

インターネットの急速な発展に伴い、ますます多くの企業がアプリケーションをクラウド プラットフォームに移行し始めています。 Docker と Kubernetes は、クラウド プラットフォームでのアプリケーションの展開と管理のための 2 つの非常に人気のある強力なツールになりました。 BeegoはGolangで開発されたWebフレームワークで、HTTPルーティング、MVC階層化、ロギング、構成管理、セッション管理などの豊富な機能を提供します。この記事では、Docker と Kub の使用方法について説明します。

Go 言語開発の要点: 5 つの人気のあるフレームワークの推奨事項 Go 言語開発の要点: 5 つの人気のあるフレームワークの推奨事項 Mar 24, 2024 pm 01:15 PM

「Go 言語開発の要点: 5 つの人気フレームワークの推奨事項」 高速で効率的なプログラミング言語として、Go 言語はますます多くの開発者に好まれています。開発効率を向上させ、コード構造を最適化するために、多くの開発者はフレームワークを使用してアプリケーションを迅速に構築することを選択します。 Go 言語の世界には、選択できる優れたフレームワークが数多くあります。この記事では、5 つの人気のある Go 言語フレームワークを紹介し、読者がこれらのフレームワークをよりよく理解して使用できるように、具体的なコード例を示します。 1.GinGin は高速な軽量 Web フレームワークです。

See all articles