Go-Micro构建学生rpc服务并注册到consul
简介Go-Micro构建学生rpc服务并注册到consul
1、目录结构
micro-student:项目目录
service:服务目录
controller:实现目录
model:proto生成的目录
proto:proto定义目录
main.go:入口
make_proto.bat:生成proto
runAll.bat:运行多个服务
2、新建proto文件
文件名:models.proto,内容如下
syntax = "proto3";
package services;
//公共的模型
message StudentModel {
int32 id = 1; //学生ID
string name = 2; //学生名称
string sex = 3; //性别
}
文件名:student_service.proto,内容如下
syntax = "proto3";
package services;
import "models.proto";
//学生列表请求
message StudentListRequest {
int32 num = 1; //请求数量
}
//学生列表返回
message StudentListResponse {
int32 status = 1; //状态
repeated StudentModel data = 2; //学生模型数据
}
//学生列表请求方法
service StudentListService {
rpc GetStudentListService (StudentListRequest) returns (StudentListResponse);
}
3、编写生成proto的批处理文件(make_proto.bat)
cd service/proto
protoc --go_out=../model models.proto
protoc --micro_out=../model --go_out=../model student_service.proto
cd ../../
执行批处理后,model目录下会生成对应的文件
4、编写服务的业务实现逻辑(controller目录下新建student_service.go文件)
package controller
import (
"context"
services "micro-api/service/model"
"strconv"
)
type StudentService struct {
}
//业务实现
func (c *StudentService) GetStudentListService(ctx context.Context, req *services.StudentListRequest, rsp *services.StudentListResponse) error {
var data []*services.StudentModel
for i := 1; i <= int(req.Num); i++ {
data = append(data, &services.StudentModel{
Id: int32(i),
Name: "name_" + strconv.Itoa(i),
Sex: "男",
})
}
rsp.Status = 200
rsp.Data = data
return nil
}
5、编写main.go
package main
import (
"github.com/micro/go-micro"
"github.com/micro/go-micro/registry"
"github.com/micro/go-plugins/registry/consul"
"micro-api/service/controller"
services "micro-api/service/model"
)
func main() {
register := consul.NewRegistry(func(options *registry.Options) {
options.Addrs = []string{
"192.168.1.171:8500",
"192.168.1.177:8500",
"192.168.1.178:8500",
}
})
service := micro.NewService(
micro.Name("student-service"),
micro.Registry(register),
)
if err := services.RegisterStudentListServiceHandler(service.Server(), new(controller.StudentService)); err != nil {
}
service.Init()
service.Run()
}
6、批量文件文件(runAll.bat)
@echo off
start cmd /k "cd/d E:\go\micro-student &&go run main.go --server_address=:50001"
start cmd /k "cd/d E:\go\micro-student &&go run main.go --server_address=:50002"
start cmd /k "cd/d E:\go\micro-student &&go run main.go --server_address=:50003"
对齐布局组件Align是将其下子组件按照指定对齐方式布局,并根据子组件的带下调整自己的大小。
partprobe命令用于在硬盘分区发生变化是,更新Linux内核中的硬盘分区表数据。有时在使fdisk、part命令对硬盘进行分区后,会发现找不到新分区,此时需要重启系统才能使修改生效,但是partprobe可以不重启系统就让修改的分区表生效。
普通的队列是一种先进先出的数据结构,元素在队列尾追加,而从队列头删除。在优先队列中,元素被赋予优先级。当访问元素时,具有最高优先级的元素最先删除。优先队列具有最高级先出 (first in, largest out)的行为特征。通常采用堆数据结构来实现。
OpenOffice.org 是一套跨平台的办公室软件套件,能在Windows、Linux、MacOS X (X11)和 Solaris 等操作系统上执行。它与各个主要的办公室软件套件兼容。OpenOffice.org 是免费软件,任何人都可以免费下载、使用及推广它。
开闭原则(Open Closed Principle,OCP)由勃兰特·梅耶(Bertrand Meyer)提出,他在 1988 年的著作《面向对象软件构造》(Object Oriented Software Construction)中提出:软件实体应当对扩展开放,对修改关闭(Software entities should be open for extension,but closed for modification),这就是开闭原则的经典定义。
快速生成表格
Electron页面跳转、浏览器打开链接和打开新窗口
在使用Git的过程中,不想每次都输入用户名和密码去拉取代码,所以就需要保存这些信息,那么既然有保存了,就必须有清除功能。
在Mac电脑中,如何对Git的用户名和密码进行修改呢?起初不懂Mac,所以整了很久,本文将记录如何对这个进行操作,以便后期使用。
Docker编译镜像出现:fetch http://dl-cdn.alpinelinux.org/alpine/v3.12/main/x86_64/APKINDEX.tar.gz
ERROR: http://dl-cdn.alpinelinux.org/alpine/v3.12/main: temporary error (try again later)
WARNING: Ignoring APKINDEX.2c4ac24e.tar.gz: No such file or directory问题