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

Go語言操作etcd的示例詳解

 更新時間:2024年03月14日 10:32:28   作者:別人家的孩子zyh  
etcd是使用Go語言開發(fā)的一個開源的、高可用的分布式key—value存儲系統(tǒng),可以用于配置共享和服務(wù)的注冊和發(fā)現(xiàn),下面我們就來看看Go語言是如何操作etcd的吧

etcd介紹

etcd是使用Go語言開發(fā)的一個開源的、高可用的分布式key—value存儲系統(tǒng),可以用于配置共享和服務(wù)的注冊和發(fā)現(xiàn),基于raft算法實現(xiàn)具有強一致性

etcd中涉及了數(shù)據(jù)一致性、多版本并發(fā)控制、watch監(jiān)控、磁盤IO讀寫等知識點

etcd的特性:

1.簡單:etcd的安裝簡單,為用戶提供了HTTP的接口,使用也很簡單

2.存儲:etcd的基本功能,基本信息存儲在文件中

3.Watch機制:watch指定的鍵的更改會通知

4.安全通信:SSL證書驗證

5.高性能:2K/s讀操作,提供了基準測試的工具

6.一致可靠:raft一致性算法

類似的項目有zookeeper和consul。

etcd具有以下的特點:

1.完全復(fù)制:集群中的每個節(jié)點都可以使用完整的存檔

2.高可用性:Etcd可用于避免硬件的單點故障或網(wǎng)絡(luò)問題

3.一致性:每次讀取都會返回跨多主機的最新寫入

4.簡單:包括一個定義良好、面向用戶的API(gRPC)

5.安全:實現(xiàn)了帶有可選的客戶端證書身份驗證的自動化TLS

6.快速:每秒10000次寫入的基準速度

7.可靠:使用Raft算法實現(xiàn)了強一致、高可用的服務(wù)存儲目錄

etcd的常見分布式場景:

1.鍵值對存儲

2.服務(wù)注冊與發(fā)現(xiàn)

3.消息訂閱與發(fā)布

4.分布式鎖

go語言操作etcd

首先在后臺啟動etcd

寫一段go代碼

package main

import (
	"context"
	"fmt"
	clientv3 "go.etcd.io/etcd/client/v3"
	"time"
)

func main() {
	// 創(chuàng)建客戶端,連接etcd
	cli, err := clientv3.New(clientv3.Config{
		Endpoints:   []string{"127.0.0.1:2379"},
		DialTimeout: 5 * time.Second,
	})
	if err != nil {
		fmt.Printf("connect to etcd failed, err:%v\n", err)
		return
	}
	fmt.Println("connect to etcd success")
	defer cli.Close()
	str := `[{"path":"d:/logs/s4.logs","topic":"s4_logs"},{"path":"d:/logs/web.logs","topic":"web_logs"}`
	// put操作
	_, err = cli.Put(context.TODO(), "collect_log_conf", str)
	if err != nil {
		fmt.Printf("put to etcd failed, err:%v\n", err)
		return
	}
	 get操作
	resp, err := cli.Get(context.TODO(), "collect_log_conf") // 獲取指定Key的值
	if err != nil {
		fmt.Printf("get to etcd failed")
		return
	}
	for _, ev := range resp.Kvs {
		fmt.Printf("key:%s,value:%s\n", ev.Key, ev.Value)
	}
	 delete 刪除key
	//if _,err = cli.Delete(context.TODO(), "testetcd");err != nil{
	//	fmt.Println("delete key failed")
	//}else{
	//	fmt.Println("delete key success")
	//}
}

也可以直接使用ectdctl工具查看key

etcdctl.exe --endpoints=127.0.0.1:2379 get collect_log_conf

到此這篇關(guān)于Go語言操作etcd的示例詳解的文章就介紹到這了,更多相關(guān)Go操作etcd內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Golang測試func?TestXX(t?*testing.T)的使用詳解

    Golang測試func?TestXX(t?*testing.T)的使用詳解

    一般Golang中的測試代碼都以xxx_test.go的樣式,在命名測試函數(shù)的時候以Testxx開頭,下面給大家介紹Golang測試func?TestXX(t?*testing.T)的使用,感興趣的朋友跟隨小編一起看看吧
    2024-08-08
  • Go語言中實現(xiàn)完美錯誤處理實踐分享

    Go語言中實現(xiàn)完美錯誤處理實踐分享

    Go?語言是一門非常流行的編程語言,由于其高效的并發(fā)編程和出色的網(wǎng)絡(luò)編程能力,越來越受到廣大開發(fā)者的青睞。本文我們就來深入探討一下Go?語言中的錯誤處理機制吧
    2023-04-04
  • 在Visual Studio Code中配置GO開發(fā)環(huán)境的詳細教程

    在Visual Studio Code中配置GO開發(fā)環(huán)境的詳細教程

    這篇文章主要介紹了在Visual Studio Code中配置GO開發(fā)環(huán)境的詳細教程,需要的朋友可以參考下
    2017-02-02
  • 基于Golang實現(xiàn)Excel表格的導(dǎo)入導(dǎo)出功能

    基于Golang實現(xiàn)Excel表格的導(dǎo)入導(dǎo)出功能

    最近項目開發(fā)中有涉及到Excel的導(dǎo)入與導(dǎo)出功能,特別是導(dǎo)出表格時需要特定的格式,所以本文給大家介紹了基于Golang實現(xiàn)Excel表格的導(dǎo)入導(dǎo)出功能,文中通過代碼示例和圖文介紹的非常詳細,需要的朋友可以參考下
    2023-12-12
  • 深入了解Go語言中web框架的中間件運行機制

    深入了解Go語言中web框架的中間件運行機制

    大家在使用iris框架搭建web系統(tǒng)時,一定會用到中間件。那么你了解中間件的運行機制嗎?你知道為什么在iris和gin框架的請求處理函數(shù)中要加c.Next()函數(shù)嗎?本文就和大家一起探究該問題的答案
    2023-02-02
  • go?generate代碼自動生成指南

    go?generate代碼自動生成指南

    這篇文章主要介紹了go?generate代碼自動生成指南,本文將探討?go?generate?命令的使用方法、原理以及一些實際應(yīng)用場景,希望讀者能夠更好地理解和運用這個強大的工具
    2024-01-01
  • 如何使用騰訊云go sdk 查詢對象存儲中最新文件

    如何使用騰訊云go sdk 查詢對象存儲中最新文件

    這篇文章主要介紹了使用騰訊云go sdk 查詢對象存儲中最新文件,這包括如何創(chuàng)建COS客戶端,如何逐頁檢索對象列表,并如何對結(jié)果排序以找到最后更新的對象,我們還展示了如何優(yōu)化用戶體驗,通過實時進度更新和檢索多個文件來改進程序,需要的朋友可以參考下
    2024-03-03
  • 手把手帶你走進Go語言之語法基礎(chǔ)解析

    手把手帶你走進Go語言之語法基礎(chǔ)解析

    這篇文章主要介紹了手把手帶你走進Go語言之語法基礎(chǔ),本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09
  • golang使用jaeger進行鏈路追蹤

    golang使用jaeger進行鏈路追蹤

    鏈路追蹤是指在分布式系統(tǒng)中,將一次請求的處理過程進行記錄并聚合展示的一種方法,目的是將一次分布式請求的調(diào)用情況集中在一處展示,本文將介紹golang如何使用jaeger進行鏈路追蹤,需要的朋友可以參考下
    2024-06-06
  • golang?xorm?自定義日志記錄器之使用zap實現(xiàn)日志輸出、切割日志(最新)

    golang?xorm?自定義日志記錄器之使用zap實現(xiàn)日志輸出、切割日志(最新)

    這篇文章主要介紹了golang?xorm?自定義日志記錄器,使用zap實現(xiàn)日志輸出、切割日志,包括連接postgresql數(shù)據(jù)庫的操作方法及?zap日志工具?,本文結(jié)合實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-10-10

最新評論