go-mciro系列(二) 手写第一个微服务_go-micro 4 proto3 怎么写(1)

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

本文先手写一个proto文件,初步感受一下micro微服务。

创建目录

创建项目目录microdemo,目录结构如下:

microdemo
    proto
        user.proto
main.go
client.go

go mod初始化目录

go mod init microdemo

编写user.proto

proto3基础语法不做单独介绍,不清楚的话自己行百度一下。下面以一个简单user服务提供一个注册方法为例

syntax = "proto3";

option go_package = "./;proto";

service User {
  rpc Register(RegisterRequest) returns (RegisterResponse) {}
}

message RegisterRequest {
  string username = 1;
  string password = 2;
  string nickname = 3;
}

message RegisterResponse {
  string username = 1;
  string token = 2;
  string nickname = 3;
}

生成rpc文件

注意以下命令是在项目的根目录执行的,如果你在其它目录记得修改--go_out--micro_out目录,--go_out--micro_out的目录都是相对于执行命令所在的目录的

protoc --go_out=./proto --micro_out=./proto ./proto/user.proto

编写main.go

package main

import (
	"context"
	"github.com/micro/go-micro/v2"
	"log"
	"microdemo/proto"
)

type Service struct {
}

func (s \*Service) Register(ctx context.Context, req \*proto.RegisterRequest, res \*proto.RegisterResponse) error {
	res.Username = req.Username
	res.Token = "13123412"
	res.Nickname = req.Nickname
	return nil
}

func main() {
	// 实例化
	srv := micro.NewService(micro.Name("user"), micro.Address("127.0.0.1:8001"))
	// 初始化
	srv.Init()
	// 注册服务
	err := proto.RegisterUserHandler(srv.Server(), new(Service))
	if err != nil {
		log.Fatalln("注册服务失败", err)
	}
	// 运行服务
	err = srv.Run()
	if err != nil {
		log.Fatalln("启动服务失败", err)
	}
}


这里没有配置注册中心,因此使用的是micro默认的mdns作为注册中心,后面会讲使用其他注册中心。

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以戳这里获取

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以戳这里获取

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值