GO 微服务GO-Micro(10)-纯个人学习笔记记录:切换Docker方案启动etcd服务中心

etcd简介与应用场景

etcd 是一个分布式一致性k-v存储系统,通常我们可用于服务注册发现与共享配置,它主要有以下特点:

  1. 简单: 基于HTTP+JSON的API让你可以用CURL命令就可以轻松使用。
  2. 安全: 可以选择SSL客户认证机制。
  3. 快速: 每个实例每秒支持一千次写操作。
  4. 可信: 使用 Ralf 算法充分实现了分布式。

说明

之前我们的服务中心是再我们注册到默认的MDNS,还有consul,但是发现我们在使用consul的时候,查询相关的服务的时候,总是查询不到服务的列表。
如我们的启动我们的服务之后:

D:\code\go\Mi_Onse\greeter>go run main_consul.go
2021-01-26 14:45:42  file=v2@v2.9.1/service.go:200 level=info Starting [service] go.micro.service.greeter
2021-01-26 14:45:42  file=grpc/grpc.go:864 level=info Server [grpc] Listening on [::]:58790
2021-01-26 14:45:42  file=grpc/grpc.go:881 level=info Broker [http] Connected to 127.0.0.1:58791
2021-01-26 14:45:42  file=grpc/grpc.go:697 level=info Registry [consul] Registering node: go.micro.service.greeter-893e627e-9e1a-4974-bc6b-7dd6a4d35853
2021-01-26 14:45:42  file=grpc/grpc.go:730 level=info Subscribing to topic: go.micro.service.greeter

查询当前注册中心的服务列表

D:\code\go\Mi_Onse>micro --registry etcd list services
{"level":"warn","ts":"2021-01-26T14:55:27.439+0800","caller":"clientv3/retry_interceptor.go:61","msg":"retrying of unary invoker failed","target":"endpoint://client-a76adcde-e089-422b-bf12-6452ed5130c2/127.0.0.1:2379","attempt":0,"e
rror":"rpc error: code = DeadlineExceeded desc = latest balancer error: all SubConns are in TransientFailure, latest connection error: connection error: desc = \"transport: Error while dialing dial tcp 127.0.0.1:2379: connectex: No
connection could be made because the target machine actively refused it.\""}
context deadline exceeded

D:\code\go\Mi_Onse>micro --registry consul list services
Registry consul not found

D:\code\go\Mi_Onse>micro --registry mdns list services

D:\code\go\Mi_Onse>

使用Docker方案启动etcd

因为之前也有学习过如何使用Docker,为方便快捷,我们这也直接的使用Docker快速启动我们的etcd来搭建我们的环境。

启动我们之前新建的安装好Docker的虚拟机环境,然后启动etcd单一节点:

docker run -d \
  -p 2379:2379 \
  -p 2380:2380 \
  --name etcd2 \
  quay.io/coreos/etcd:v3.3.8 \
  /usr/local/bin/etcd \
  --name s1 \
  --listen-client-urls http://0.0.0.0:2379 \
  --advertise-client-urls http://0.0.0.0:2379
image.png

耐心等待启动后,查看一下当前我们的docker
查看我们的启动的服务:

[root@localhost ~]# docker ps
CONTAINER ID        IMAGE                        COMMAND                  CREATED             STATUS              PORTS                              NAMES
54c16f197329        quay.io/coreos/etcd:v3.3.8   "/usr/local/bin/etcd…"   4 minutes ago       Up 4 minutes        0.0.0.0:2379-2380->2379-2380/tcp   etcd2
[root@localhost ~]#

1.使用命令的形式把我们的服务注册到我们的ECTD上:

D:\code\go\Mi_Onse\greeter>go run main.go --registry=etcd --registry_address=192.168.219.130:2379

因为我们的是使用Docker的形式启动我们的环境,所以此时我们的需要注意使用registry_address来指定注册的地址
,不然默认是会去查询本地的121.0.0.1
操作结果:

D:\code\go\Mi_Onse\greeter>go run main.go --registry=etcd --registry_address=192.168.219.130:2379
2021-01-26 15:35:30  file=v2@v2.9.1/service.go:200 level=info Starting [service] go.micro.service.greeter
2021-01-26 15:35:30  file=grpc/grpc.go:864 level=info Server [grpc] Listening on [::]:63499
2021-01-26 15:35:30  file=grpc/grpc.go:881 level=info Broker [http] Connected to 127.0.0.1:63500
2021-01-26 15:35:30  file=grpc/grpc.go:697 level=info Registry [etcd] Registering node: go.micro.service.greeter-753c8941-78a1-4452-bb7e-2439a3ef0657
2021-01-26 15:35:30  file=grpc/grpc.go:730 level=info Subscribing to topic: go.micro.service.greeter

查看我们的注册服务的结果列表:

D:\code\go\Mi_Onse>micro --registry etcd --registry_address 192.168.219.130:2379 list services
go.micro.service.greeter
micro.http.broker

错误的示例

D:\code\go\Mi_Onse>micro --registry etcd list services
{"level":"warn","ts":"2021-01-26T15:38:55.880+0800","caller":"clientv3/retry_interceptor.go:61","msg":"retrying of unary invoker failed","target":"endpoint://client-3cfc1566-5f6e-40e7-a040-16459b1f4ca1/127.0.0.1:2379","attempt":0,"e
rror":"rpc error: code = DeadlineExceeded desc = latest balancer error: all SubConns are in TransientFailure, latest connection error: connection error: desc = \"transport: Error while dialing dial tcp 127.0.0.1:2379: connectex: No
connection could be made because the target machine actively refused it.\""}
context deadline exceeded

2.使用代码的形式把我们的服务注册到我们的ECTD上:

修改注册中心代码:

使用的是:"github.com/micro/go-micro/v2/registry/etcd"

package main

import (

    "github.com/micro/go-micro/v2"
    log "github.com/micro/go-micro/v2/logger"
    "github.com/micro/go-micro/v2/registry"
    "github.com/micro/go-micro/v2/registry/etcd"

    "greeter/handler"
    "greeter/subscriber"
    _ "github.com/micro/go-plugins/registry/consul/v2"
    greeter "greeter/proto/greeter"
)

func main() {

    reg := etcd.NewRegistry(registry.Addrs("192.168.219.130:2379"))


    // New Service
    service := micro.NewService(
        micro.Name("go.micro.service.greeter"),
        micro.Version("latest"),
        micro.Registry(reg),
    )

    // Initialise service
    service.Init()

    // Register Handler
    _ = greeter.RegisterGreeterHandler(service.Server(), new(handler.Greeter))

    // Register Struct as Subscriber
    _ =micro.RegisterSubscriber("go.micro.service.greeter", service.Server(), new(subscriber.Greeter))

    // Run service
    if err := service.Run(); err != nil {
        log.Fatal(err)
    }
}

然后运行起来我们的服务:

D:\code\go\Mi_Onse\greeter>go run main_ectd.go
2021-01-26 15:54:07  file=v2@v2.9.1/service.go:200 level=info Starting [service] go.micro.service.greeter
2021-01-26 15:54:07  file=grpc/grpc.go:864 level=info Server [grpc] Listening on [::]:65403
2021-01-26 15:54:07  file=grpc/grpc.go:881 level=info Broker [http] Connected to 127.0.0.1:65404
2021-01-26 15:54:07  file=grpc/grpc.go:697 level=info Registry [etcd] Registering node: go.micro.service.greeter-218b0dd0-811c-43e2-8402-b73430bb66b4
2021-01-26 15:54:07  file=grpc/grpc.go:730 level=info Subscribing to topic: go.micro.service.greeter

再查看我们的服务,一样的可以看得到我们注册成功的服务列表信息:

D:\code\go\Mi_Onse>micro --registry etcd --registry_address 192.168.219.130:2379 list services
go.micro.service.greeter
micro.http.broker

D:\code\go\Mi_Onse>

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,826评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,968评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,234评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,562评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,611评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,482评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,271评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,166评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,608评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,814评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,926评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,644评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,249评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,866评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,991评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,063评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,871评论 2 354

推荐阅读更多精彩内容