当前位置: 首页 > news >正文

快速了解Go+微服务(概念和一个例子)

更多个人笔记:(仅供参考,非盈利)
gitee: https

文章目录

    • 基本概念
    • grpc和简单demo

基本概念

特点:

  • 单一职责:一个服务用来解决一个业务问题
  • 面向服务:一个服务封装并对外提供服务,也可以调用别的服务

微服务治理

  • 微服务如何发现别的微服务:服务注册中心
  • 客户端或外部服务调用的处理:通过统一的网关进行验证授权
  • 此外还有熔断限流保证高可用,负载均衡,分布式事务等等方法概念

grpc和简单demo

grpc是什么:跨平台高性能的rpc框架,多语言互通,可以比如GO创建一个服务端然后PHP/android服务端调用

proto文件: (programmer.proto)

syntax = "proto3";
package proto; //通过 package 区分不同的命名空间
//proto.ProgramRequest和other.ProgramRequest是不同的命名空间下的相同消息名
option go_package = "./protooo"; //指定 Go 包路径(生成对应文件夹)service Program{rpc Getinfo(ProgramRequest) returns(ProgramResponse){} //定义服务端处理函数
}message ProgramRequest{string name = 1; //[修饰符]类型 字段名=标识号
}message ProgramResponse{  //定义服务端响应数据格式int32 uid = 1;string username = 2;string job = 3;  repeated string hobbies = 4; //repeated是修饰符,表示为可变数组
}

当前文件夹终端下执行protoc --go_out=. --go-grpc_out=. ./programmer.proto
前面的会根据option 的包路径放置,最后的是指定proto文件
会生成对应的两个pb.go 文件 (知道和protobuf有关就行,脚手架)

server部分代码 (go run server.go

package mainimport ("context""fmt""log""net"pb "practice/proto" //这里practice是我自己的go mod的名字"google.golang.org/grpc"
)type ProgramServer struct {pb.UnimplementedProgramServer //向前兼容性保护,如果添加了新的方法//这里是嵌入的结构体
}func (s *ProgramServer) Getinfo(ctx context.Context, req *pb.ProgramRequest) (*pb.ProgramResponse, error) {// 模拟业务逻辑if req.Name == "张三" {return &pb.ProgramResponse{Uid:      1001,Username: req.Name,Job:      "软件工程师",Hobbies:  []string{"编程", "读书", "运动"},}, nil}else{return &pb.ProgramResponse{Uid:      -1,Username: req.Name,Job:      "嘿嘿嘿,不知道",Hobbies:  []string{"没有东西"},}, nil}}func main() {// 监听端口lis, err := net.Listen("tcp", ":50051")if err != nil {log.Fatal("监听失败:", err)}// 创建 gRPC 服务器s := grpc.NewServer()// 注册服务pb.RegisterProgramServer(s, &ProgramServer{})fmt.Println("gRPC 服务器启动在 :50051")if err := s.Serve(lis); err != nil {log.Fatal("服务失败: ", err)}
}
  • 导入(pb)生成好的代码中的对应的结构体和返回变量名
  • 写方法
  • 监听窗口并创建RPC服务器,注册服务

客户端代码 (go run client.go)

package mainimport ("context""log""time"pb "practice/proto" //这里practice是我自己的go mod的名字"google.golang.org/grpc""google.golang.org/grpc/credentials/insecure"
)func main() {// 连接服务器conn, err := grpc.NewClient("localhost:50051", grpc.WithTransportCredentials(insecure.NewCredentials()))if err != nil {log.Fatalf("连接失败: %v", err)}defer conn.Close()// 创建客户端client := pb.NewProgramClient(conn)// 设置超时上下文,context 是必需的,用于调控grpc的生命周期ctx, cancel := context.WithTimeout(context.Background(), time.Second)defer cancel()// 调用远程方法resp, err := client.Getinfo(ctx, &pb.ProgramRequest{Name: "张三"})if err != nil {log.Fatal("调用失败", err)}log.Printf("响应: %+v", resp)
}
  • 也是导入pb包
  • 连接服务器并创建客户端
  • 设置上下文传递
  • 调用远程方法

这就是一个简答了解微服务的demo

http://www.xdnf.cn/news/208585.html

相关文章:

  • CA添加删除辅小区信令流程
  • 联邦学习与安全多方计算的结合是隐私保护机器学习领域
  • Android启动应用时屏蔽RecyclerView滑动,延时后再允许滑动,Kotlin
  • 华为云IoT平台与MicroPython实战:从MQTT协议到物联网设备开发
  • 4、RabbitMQ的七种工作模式介绍
  • CSS--图片链接水平居中展示的方法
  • Rust Ubuntu下编译生成环境win程序踩坑指南
  • 《Origin画百图》之带颜色映射的3维散点图
  • 局部和整体的关系
  • elementui里的el-tabs的内置样式修改失效?
  • Error: error:0308010C:digital envelope routines::unsupported 高版本node启动低版本项目运行报错
  • OpenCV 图形API(71)图像与通道拼接函数-----从图像(GMat)中裁剪出一个矩形区域的操作函数 crop()
  • 一文简单记录打通K8s+Kibana流程如何启动(Windows下的Docker版本)
  • 高翔《视觉SLAM十四讲》第七章视觉里程计3d-2d位姿估计代码详解与理论解析
  • AI图片跳舞生成视频,Uni Animate本地部署。
  • JVM调优实战(JVM Tuning Pactice)
  • 【Sqlalchemy Model转换成Pydantic Model示例】
  • GD32F407单片机开发入门(十七)内部RTC实时时钟及实战含源码
  • 蓝桥杯 5. 拼数
  • 共探蓝海赛道增长新方法 阿里国际站智能AI全球买家分析峰会在深落幕
  • 每天一道面试题@第四天(Java基础)
  • LangChain入门(四) 部署应用程序
  • 【学习笔记】计算机操作系统(二)—— 进程的描述与控制
  • 【力扣/代码随想录】哈希表
  • Mangodb基本概念和介绍,Mango三个重要的概念:数据库,集合,文档
  • 碰到的 MRCPv2 串线以及解决思路
  • 0-1背包难题哪家强:回溯法 VS 动态规划 VS 贪心算法
  • 认识Linux基本操作、命令
  • windows 使用 FFmpeg 放大视频原声
  • uniapp 小程序 安卓苹果 短视频解决方案