1. 初识golang微服务-gRPC

单体架构

在这里插入图片描述


微服务架构

RPC架构(远程过程调用)

服务端实例代码:

go 复制代码
package main

import (
	"fmt"
	"net"
	"net/rpc"
	"time"
)

type Hello struct {
}

func (h Hello) SayHello(req string, res *string) error {
	*res = "你好," + req
	fmt.Println(*res)
	time.Sleep(10*time.Second)
	return nil
}

func main() {
	// 1. 注册RPC服务
	err := rpc.RegisterName("hello", new(Hello))
	if err!=nil{
		fmt.Println(err)
	}
	
	// 2. 监听端口
	listener, err := net.Listen("tcp", "127.0.0.1:8000")
	if err!=nil{
		fmt.Println(err)
	}

	// 3. 退出程序是关闭监听
	defer listener.Close()

	for{
		// 4. 建立连接
		conn, err := listener.Accept()
		if err!=nil{
			fmt.Println(err)
		}
		// 绑定服务
		go rpc.ServeConn(conn)
	}

}

客户端示例代码:

go 复制代码
package main

import (
	"fmt"
	"net/rpc"
)

func main() {
	// 1. 与RPC微服务建立连接
	conn, err := rpc.Dial("tcp", "127.0.0.1:8000")
	if err!=nil{
		fmt.Println(err)
	}
	
	// 2. 当程序退出时关闭连接
	defer conn.Close()

	// 3. 远程调用函数
	var res string
	err = conn.Call("hello.SayHello", "hahahha", &res)

	fmt.Println(res)
}

Protobuf

https://github.com/protocolbuffers/protobuf/releases/tag/v30.0

下载对应操作系统版本,然后解压缩,将bin文件夹的路径加入环境变量中

即为成功!

然后下载go对应的包

go get github.com/golang/protobuf/protoc-gen-go

使用样例

复制代码
syntax = "proto3";
option go_package="./";

message User{
    string name = 1;
    bool male = 2;
    repeated string hobby = 3;
}

// 执行:protoc --go_out=. *.proto
go 复制代码
package main

import (
	"fmt"
	"google.golang.org/protobuf/proto"
)

func main() {
	u := User{
		Name: "张三",
		Male: false,
	}
	data, _ := proto.Marshal(&u)
	fmt.Println(data)
	user := &User{}
	proto.Unmarshal(data, user)
	fmt.Println(user)
}

message嵌套

复制代码
message SearchResponse {
  message Result {
    string url = 1;
    string title = 2;
    repeated string snippets = 3;
  }
  repeated Result results = 1;
}

定义服务类型

复制代码
service SearchService {
  rpc Search (SearchRequest) returns (SearchResponse);
}
相关推荐
无敌最俊朗@1 小时前
解决 QML 中使用 Qt Charts 崩溃的三个关键步骤
开发语言·qt
会飞的小新1 小时前
C 标准库之 <errno.h> 详解与深度解析
c语言·开发语言
胡八一1 小时前
30 分钟上手 exp4j:在 Java 中安全、灵活地计算数学表达式
java·开发语言·安全
郝学胜-神的一滴2 小时前
Linux 进程控制块(PCB)解析:深入理解进程管理机制
linux·服务器·开发语言
后端小张2 小时前
【鸿蒙开发手册】重生之我要学习鸿蒙HarmonyOS开发
开发语言·学习·华为·架构·harmonyos·鸿蒙·鸿蒙系统
胖咕噜的稞达鸭2 小时前
AVL树手撕,超详细图文详解
c语言·开发语言·数据结构·c++·算法·visual studio
007php0072 小时前
百度面试题解析:synchronized、volatile、JMM内存模型、JVM运行时区域及堆和方法区(三)
java·开发语言·jvm·缓存·面试·golang·php
芒果量化3 小时前
Optuna - 自动调参利器&python实例
开发语言·python·算法·机器学习
foundbug9993 小时前
基于CSMA-CA协议的V2X通信MATLAB仿真
开发语言·网络·matlab
WangMing_X3 小时前
C#上位机软件:2.5 体验CLR实现多语言混合编程
java·开发语言·c#