go-micro使用etcd實現(xiàn)服務發(fā)現(xiàn)

什么是go-micro和etcd,本文不在這里敘述,會有例外的文章介紹须教。這里只是一個示列,簡單的了解和運用下服務發(fā)現(xiàn)斩芭。

通過一張圖來了解什么是服務發(fā)現(xiàn)轻腺?

服務的基本流程:
1.先把自己的服務注冊到注冊中心
2.客戶端調(diào)用的時候去注冊中心查詢調(diào)用的服務的服務器列表
3.得到服務列表,隨機調(diào)取一臺進行遠程協(xié)程
服務發(fā)現(xiàn)的目的:
傳統(tǒng)單機應用動態(tài)性不強划乖,不會頻繁地更新和重新發(fā)布贬养,也較少地進行自動伸縮。但隨著互聯(lián)網(wǎng)分布式系統(tǒng)的普及琴庵,服務與服務之間的伸縮性和可擴展性的要求也越來越大误算。

為了滿足服務的垂直和水平的擴張,以往一般使用預定義的端口配置服務迷殿,當新的服務需要上線或當期服務需要冗余擴展的時候儿礼,我們需要靜態(tài)化地“注冊”相關(guān) ip 與端口信息到一個地方,再通過程序之間定時“更新”的方法去同步信息庆寺。

下面通過一個示列來學習服務發(fā)現(xiàn):
1.安裝ectd蚊夫,編輯docker-compose.yml

version: '3'
networks:
  myetcd_single:
services:
  etcd:
    image: quay.io/coreos/etcd:v3.3.12
    container_name: etcd
    ports:
      - 23791:2379
      - 2380
    environment:
      ETCDCTL_API: 3
    #volumes:
    #  - ./data/etcd/etcd-data:/etcd-data
    networks:
      - myetcd_single
    command:
      - "/usr/local/bin/etcd"
      - "--name"
      - "s1"
      - "--data-dir"
      - "/etcd-data"
      - "--advertise-client-urls"
      - "http://0.0.0.0:2379"
      - --listen-client-urls
      - "http://0.0.0.0:2379"
      - "--initial-advertise-peer-urls"
      - "http://0.0.0.0:2380"
      - "--listen-peer-urls"
      - "http://0.0.0.0:2380"
      - "--initial-cluster-token"
      - "tkn"
      - "--initial-cluster"
      - "s1=http://0.0.0.0:2380"
      - "--initial-cluster-state"
      - "new"
  etcdkeeper:
    image: deltaprojects/etcdkeeper
    container_name: etcdkeeper_single
    ports:
      - 8088:8080
    networks:
      - myetcd_single

啟動etcd

docker-compose up -d

2.go-micro示列
proto文件及bp執(zhí)行

// hello.proto
syntax = "proto3";

package hello;

option go_package = "proto/hello";
option java_multiple_files = true;
option java_outer_classname = "HelloWorldProto";

service Hello {
    rpc Ping(Request) returns (Response) {}
}
message Request {
    string name = 1;
}
message Response {
    string msg = 1;
}
protoc  -I . --go_out=. --micro_out=. hello.proto

服務注冊

package main

import (
    micro "github.com/micro/go-micro"
    //"github.com/micro/go-micro/web"
    proto "mymicro/proto/hello"
    //"net/http"
    "context"
    //"fmt"
    "github.com/micro/go-micro/registry"
    //"github.com/micro/go-micro/registry/etcd"
    "github.com/micro/go-plugins/registry/etcdv3"
)

type Hello struct{}

func (h *Hello) Ping(ctx context.Context, req *proto.Request, res *proto.Response) error {
    res.Msg = "Hello " + req.Name
    return nil
}

func main() {
    reg := etcdv3.NewRegistry(func(op *registry.Options) {
        op.Addrs = []string{"192.168.99.101:23791"}
    })

    service := micro.NewService(
        micro.Name("cowkeys.srv.say"),
        micro.Registry(reg),
    )
    service.Init()

    proto.RegisterHelloHandler(service.Server(), new(Hello))

    if err := service.Run(); err != nil {
        panic(err)
    }
}

// func main() {
//  server := web.NewService(web.Address(":8081")) // 路由
//  server.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
//      w.Write([]byte("hello go micro"))
//  })
//  _ = server.Run()
// }

服務發(fā)現(xiàn)

package main

import (
    "context"
    "fmt"

    proto "mymicro/proto/hello"
    micro "github.com/micro/go-micro"
    "github.com/micro/go-micro/registry"
    //"github.com/micro/go-micro/registry/etcd"
    "github.com/micro/go-plugins/registry/etcdv3"
)

func main() {
    reg := etcdv3.NewRegistry(func(op *registry.Options) {
        op.Addrs = []string{"192.168.99.101:23791"}
    })

    service := micro.NewService(
        micro.Registry(reg),
    )
    service.Init()

    sayClent := proto.NewHelloService("cowkeys.srv.say", service.Client())
    rsp, err := sayClent.Ping(context.Background(), &proto.Request{Name: "World ^_^"})
    if err != nil {
        panic(err)
    }
    fmt.Println(rsp)
}

附一張主流注冊中心的對別圖
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市止邮,隨后出現(xiàn)的幾起案子这橙,更是在濱河造成了極大的恐慌,老刑警劉巖导披,帶你破解...
    沈念sama閱讀 222,252評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件屈扎,死亡現(xiàn)場離奇詭異,居然都是意外死亡撩匕,警方通過查閱死者的電腦和手機鹰晨,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人模蜡,你說我怎么就攤上這事漠趁。” “怎么了忍疾?”我有些...
    開封第一講書人閱讀 168,814評論 0 361
  • 文/不壞的土叔 我叫張陵闯传,是天一觀的道長。 經(jīng)常有香客問我卤妒,道長甥绿,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,869評論 1 299
  • 正文 為了忘掉前任则披,我火速辦了婚禮共缕,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘士复。我一直安慰自己图谷,他們只是感情好,可當我...
    茶點故事閱讀 68,888評論 6 398
  • 文/花漫 我一把揭開白布阱洪。 她就那樣靜靜地躺著便贵,像睡著了一般。 火紅的嫁衣襯著肌膚如雪澄峰。 梳的紋絲不亂的頭發(fā)上嫉沽,一...
    開封第一講書人閱讀 52,475評論 1 312
  • 那天,我揣著相機與錄音俏竞,去河邊找鬼绸硕。 笑死,一個胖子當著我的面吹牛魂毁,可吹牛的內(nèi)容都是我干的玻佩。 我是一名探鬼主播,決...
    沈念sama閱讀 41,010評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼席楚,長吁一口氣:“原來是場噩夢啊……” “哼咬崔!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起烦秩,我...
    開封第一講書人閱讀 39,924評論 0 277
  • 序言:老撾萬榮一對情侶失蹤垮斯,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后只祠,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體兜蠕,經(jīng)...
    沈念sama閱讀 46,469評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,552評論 3 342
  • 正文 我和宋清朗相戀三年抛寝,在試婚紗的時候發(fā)現(xiàn)自己被綠了熊杨。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片曙旭。...
    茶點故事閱讀 40,680評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖晶府,靈堂內(nèi)的尸體忽然破棺而出桂躏,到底是詐尸還是另有隱情,我是刑警寧澤川陆,帶...
    沈念sama閱讀 36,362評論 5 351
  • 正文 年R本政府宣布剂习,位于F島的核電站,受9級特大地震影響书劝,放射性物質(zhì)發(fā)生泄漏进倍。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 42,037評論 3 335
  • 文/蒙蒙 一购对、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧陶因,春花似錦骡苞、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,519評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至烘苹,卻和暖如春躲株,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背镣衡。 一陣腳步聲響...
    開封第一講書人閱讀 33,621評論 1 274
  • 我被黑心中介騙來泰國打工霜定, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人廊鸥。 一個月前我還...
    沈念sama閱讀 49,099評論 3 378
  • 正文 我出身青樓望浩,卻偏偏與公主長得像,于是被迫代替她去往敵國和親惰说。 傳聞我的和親對象是個殘疾皇子磨德,可洞房花燭夜當晚...
    茶點故事閱讀 45,691評論 2 361

推薦閱讀更多精彩內(nèi)容