亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

go任務調度7(etcd的watch的用法)

發布時間:2020-08-02 18:32:30 來源:網絡 閱讀:1097 作者:梁十八 欄目:編程語言

監聽etcd中的kv變化,常用來做集群中的配置下發、狀態同步,非常有價值。

package main

import (
    "go.etcd.io/etcd/clientv3"
    "time"
    "fmt"
    "context"
    "go.etcd.io/etcd/mvcc/mvccpb"
)

func main() {
    var (
        config clientv3.Config
        client *clientv3.Client
        err error
        kv clientv3.KV
        watcher clientv3.Watcher
        getResp *clientv3.GetResponse
        watchStartRevision int64
        watchRespChan <-chan clientv3.WatchResponse
        watchResp clientv3.WatchResponse
        event *clientv3.Event
    )

    // 客戶端配置
    config = clientv3.Config{
        Endpoints: []string{"0.0.0.0:2379"},
        DialTimeout: 5 * time.Second,
    }

    // 建立連接
    if client, err = clientv3.New(config); err != nil {
        fmt.Println(err)
        return
    }

    // KV
    kv = clientv3.NewKV(client)

    // 模擬etcd中KV的變化
    go func() {
        for {
            kv.Put(context.TODO(), "/cron/jobs/job7", "i am job7")

            kv.Delete(context.TODO(), "/cron/jobs/job7")

            time.Sleep(1 * time.Second)
        }
    }()

    // 先GET到當前的值,并監聽后續變化
    if getResp, err = kv.Get(context.TODO(), "/cron/jobs/job7"); err != nil {
        fmt.Println(err)
        return
    }

    // 現在key是存在的
    if len(getResp.Kvs) != 0 {
        fmt.Println("當前值:", string(getResp.Kvs[0].Value))
    }

    // 當前etcd集群事務ID, 單調遞增的(監聽/cron/jobs/job7后續的變化,也就是通過監聽版本變化)
    watchStartRevision = getResp.Header.Revision + 1

    // 創建一個watcher(監聽器)
    watcher = clientv3.NewWatcher(client)

    // 啟動監聽
    fmt.Println("從該版本向后監聽:", watchStartRevision)

    ctx, cancelFunc := context.WithCancel(context.TODO())
    //5秒鐘后取消
    time.AfterFunc(5 * time.Second, func() {
        cancelFunc()
    })
    //這里ctx感知到cancel則會關閉watcher
    watchRespChan = watcher.Watch(ctx, "/cron/jobs/job7", clientv3.WithRev(watchStartRevision))

    // 處理kv變化事件
    for watchResp = range watchRespChan {
        for _, event = range watchResp.Events {
            switch event.Type {
            case mvccpb.PUT:
                fmt.Println("修改為:", string(event.Kv.Value), "Revision:", event.Kv.CreateRevision, event.Kv.ModRevision)
            case mvccpb.DELETE:
                fmt.Println("刪除了", "Revision:", event.Kv.ModRevision)
            }
        }
    }
}

輸出:

[root@bogon etcd]# go run demo8.go
當前值: i am job7
從該版本向后監聽: 33
刪除了 Revision: 33
修改為: i am job7 Revision: 34 34
刪除了 Revision: 35
修改為: i am job7 Revision: 36 36
刪除了 Revision: 37
修改為: i am job7 Revision: 38 38
刪除了 Revision: 39
修改為: i am job7 Revision: 40 40
刪除了 Revision: 41
[root@bogon etcd]#

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

邯郸县| 阿荣旗| 六盘水市| 宁远县| 平阳县| 鄱阳县| 台南县| 邮箱| 靖州| 泽库县| 衡东县| 耒阳市| 福建省| 凌源市| 黄平县| 阳春市| 元氏县| 定陶县| 景泰县| 无为县| 宁都县| 阜南县| 静海县| 平定县| 安平县| 密山市| 方正县| 鄂伦春自治旗| 洱源县| 当雄县| 夏邑县| 太仓市| 阳高县| 平昌县| 平邑县| 庆元县| 吐鲁番市| 揭阳市| 福清市| 天镇县| 鹤壁市|