欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

etcd通信接口之客戶端API核心方法實戰(zhàn)

 更新時間:2022年06月17日 16:26:19   作者:aoho  
這篇文章主要為大家介紹了etcd通信接口之客戶端API核心方法實戰(zhàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

前言

我們在前面介紹了 etcd 的整體架構(gòu)。學(xué)習(xí)客戶端與 etcd 服務(wù)端的通信以及 etcd 集群節(jié)點的內(nèi)部通信接口對于我們更好地使用和掌握 etcd 組件很有幫助,也是所必需了解的內(nèi)容。我們將會介紹 etcd 的 gRPC 通信接口以及客戶端的實踐。

etcd clientv3 客戶端

etcd 客戶端 clientv3 接入的示例將會以 Go 客戶端為主,讀者需要準(zhǔn)備好基本的開發(fā)環(huán)境。

首先是 etcd clientv3 的初始化,我們根據(jù)指定的 etcd 節(jié)點,建立客戶端與 etcd 集群的連接。

    cli,err := clientv3.New(clientv3.Config{
        Endpoints:[]string{"localhost:2379"},
        DialTimeout: 5 * time.Second,
    })

如上的代碼實例化了一個 client,這里需要傳入的兩個參數(shù):

  • Endpoints:etcd 的多個節(jié)點服務(wù)地址,因為我是單點本機測試,所以只傳 1 個。
  • DialTimeout:創(chuàng)建 client 的首次連接超時,這里傳了 5 秒,如果 5 秒都沒有連接成功就會返回 err;值得注意的是,一旦 client 創(chuàng)建成功,我們就不用再關(guān)心后續(xù)底層連接的狀態(tài)了,client 內(nèi)部會重連。

etcd 客戶端初始化

解決完包依賴之后,我們初始化 etcd 客戶端??蛻舳顺跏蓟a如下所示:

// client_init_test.go
package client
import (
	"context"
	"fmt"
	"go.etcd.io/etcd/clientv3"
	"testing"
	"time"
)
// 測試客戶端連接
func TestEtcdClientInit(t *testing.T) {
	var (
		config clientv3.Config
		client *clientv3.Client
		err    error
	)
	// 客戶端配置
	config = clientv3.Config{
		// 節(jié)點配置
		Endpoints:   []string{"localhost:2379"},
		DialTimeout: 5 * time.Second,
	}
	// 建立連接
	if client, err = clientv3.New(config); err != nil {
		fmt.Println(err)
	} else {
		// 輸出集群信息
		fmt.Println(client.Cluster.MemberList(context.TODO()))
	}
	client.Close()
}

如上的代碼,預(yù)期的執(zhí)行結(jié)果如下:

=== RUN   TestEtcdClientInit
&{cluster_id:14841639068965178418 member_id:10276657743932975437 raft_term:3  [ID:10276657743932975437 name:"default" peerURLs:"http://localhost:2380" clientURLs:"http://0.0.0.0:2379" ] {} [] 0} <nil>
--- PASS: TestEtcdClientInit (0.08s)
PASS

可以看到 clientv3 與 etcd Server 的節(jié)點 localhost:2379 成功建立了連接,并且輸出了集群的信息,下面我們就可以對 etcd 進行操作了。

client 定義

接著我們來看一下 client 的定義:

type Client struct {
    Cluster
    KV
    Lease
    Watcher
    Auth
    Maintenance
    // Username is a user name for authentication.
    Username string
    // Password is a password for authentication.
    Password string
}

注意,這里顯示的都是可導(dǎo)出的模塊結(jié)構(gòu)字段,代表了客戶端能夠使用的幾大核心模塊,其具體功能介紹如下:

  • Cluster:向集群里增加 etcd 服務(wù)端節(jié)點之類,屬于管理員操作。
  • KV:我們主要使用的功能,即操作 K-V。
  • Lease:租約相關(guān)操作,比如申請一個 TTL=10 秒的租約。
  • Watcher:觀察訂閱,從而監(jiān)聽最新的數(shù)據(jù)變化。
  • Auth:管理 etcd 的用戶和權(quán)限,屬于管理員操作。
  • Maintenance:維護 etcd,比如主動遷移 etcd 的 leader 節(jié)點,屬于管理員操作

以上就是etcd通信接口之客戶端API核心方法實戰(zhàn)的詳細(xì)內(nèi)容,更多關(guān)于etcd通信接口客戶端API的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 基于原生Go語言開發(fā)一個博客系統(tǒng)

    基于原生Go語言開發(fā)一個博客系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了如何基于原生Go語言開發(fā)一個簡單的博客系統(tǒng),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-02-02
  • Go語言使用ioutil.ReadAll函數(shù)需要注意基本說明

    Go語言使用ioutil.ReadAll函數(shù)需要注意基本說明

    這篇文章主要為大家介紹了Go語言使用ioutil.ReadAll函數(shù)需要注意基本說明,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • go?doudou開發(fā)單體RESTful服務(wù)快速上手教程

    go?doudou開發(fā)單體RESTful服務(wù)快速上手教程

    這篇文章主要為大家介紹了go?doudou開發(fā)單體RESTful服務(wù)快速上手教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • 在Go中創(chuàng)建隨機的安全密碼

    在Go中創(chuàng)建隨機的安全密碼

    今天小編就為大家分享一篇關(guān)于在Go中創(chuàng)建隨機的安全密碼,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-10-10
  • Golang中間件設(shè)計示例詳解

    Golang中間件設(shè)計示例詳解

    這篇文章主要介紹了Golang中間件設(shè)計示例,中間件是在HTTP請求處理過程中,對請求進行處理的一種模式,中間件可以在請求到達處理器之前或之后對請求進行攔截,修改或者增強,同時可以對響應(yīng)進行處理,需要的朋友可以參考下
    2023-05-05
  • Golang操作excel的方法

    Golang操作excel的方法

    這篇文章主要介紹了Golang操作excel的方法,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-10-10
  • Golang基于JWT與Casbin身份驗證授權(quán)實例詳解

    Golang基于JWT與Casbin身份驗證授權(quán)實例詳解

    這篇文章主要為大家介紹了Golang基于JWT與Casbin實現(xiàn)身份驗證授權(quán)實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • golang內(nèi)存對齊詳解

    golang內(nèi)存對齊詳解

    在golang中,每一種數(shù)據(jù)類型都有其對應(yīng)的數(shù)據(jù)類型大小,也就是占用了多少內(nèi)存空間,我們可以通過unsafe.Sizeof函數(shù),來確定一個變量占用的內(nèi)存字節(jié)數(shù),本文將詳細(xì)給大家介紹golang內(nèi)存對齊,需要的朋友可以參考下
    2023-10-10
  • golang數(shù)據(jù)結(jié)構(gòu)之golang稀疏數(shù)組sparsearray詳解

    golang數(shù)據(jù)結(jié)構(gòu)之golang稀疏數(shù)組sparsearray詳解

    這篇文章主要介紹了golang數(shù)據(jù)結(jié)構(gòu)之golang稀疏數(shù)組sparsearray的相關(guān)知識,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09
  • Go語言基礎(chǔ)變量的聲明及初始化示例詳解

    Go語言基礎(chǔ)變量的聲明及初始化示例詳解

    這篇文章主要為大家介紹了Go語言基礎(chǔ)變量的聲明及初始化示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助祝大家多多進步,早日升職加薪
    2021-11-11

最新評論