go+gin+grpc整合demo

go+gin+grpc整合demo
pb/hello.proto:

syntax = "proto3";

option go_package = "./;pb";

package pb;

service Greeter{
    rpc SayHello (HelloRequest) returns (HelloReply) {}
}

// 请求数据格式
message HelloRequest{
    string name = 1;
}

// 返回数据格式
message HelloReply{
    string name = 1;
}

grpc/main.go:

package main

import (
	"context"
	"fmt"
	pb "gin_gprc/pb"
	"log"
	"net"
	"google.golang.org/grpc"
	"google.golang.org/grpc/reflection"
)

const (
	port = ":50051"
)

// 服务对象
type server struct {
	pb.UnimplementedGreeterServer
}

// sayhello实现服务的接口 在proto中定义的所有服务都是接口
func (s *server) SayHello(ctx context.Context, in *pb.HelloRequest) (*pb.HelloReply, error) {
	fmt.Println("请求数据........")
	return &pb.HelloReply{Name: "Hello " + in.Name}, nil
}

func main() {
	lis, err := net.Listen("tcp", port)
	if err != nil {
		log.Fatalf("failed to listen: %v", err)
	}
	// 起一个服务
	s := grpc.NewServer()
	pb.RegisterGreeterServer(s, &server{})

	// 注册反射服务 这个服务是CLI使用的 跟服务本身没有关系
	fmt.Printf("\"开始提供服务\": %v\n", "开始提供服务")
	reflection.Register(s)
	if err := s.Serve(lis); err != nil {
		log.Fatalf("failed to serve %v", err)
	}
}

gin/main.go:

package main

import (
	"fmt"
	pb "gin_gprc/pb"
	"log"
	"net/http"

	"github.com/gin-gonic/gin"
	"google.golang.org/grpc"
)

func main() {
	// 建立grpc连接充当客户端
	conn, err := grpc.Dial("localhost:50051", grpc.WithInsecure())
	if err != nil {
		log.Fatalf("did not connect :%v",err)
	}
	defer conn.Close()
	client := pb.NewGreeterClient(conn)

	// http服务端
	r := gin.Default()
	r.GET("/rest/n/:name", func(c *gin.Context){
		name := c.Param("name")
		// 接收到参数后向grpc服务端请求数据
		req := &pb.HelloRequest{Name: name}
		res, err := client.SayHello(c, req)
		if err != nil{
			c.JSON(http.StatusInternalServerError,gin.H{
				"error":err.Error(),
			})
			return
		}

		c.JSON(http.StatusOK, gin.H{
			"result":fmt.Sprint(res.Name),
		})
	})

	if err := r.Run(":8052"); err != nil {
		log.Fatalf("could not run sercer :%v", err)
	}
}

然后启动grpc服务端,再启动http服务端,在浏览器请求:http://127.0.0.1:8052/rest/n/xiaobai

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Go微服务开发是利用Go语言进行微服务架构的开发方式。在这个问题中,使用了gingrpc和etcd进行重构grpc-todolist项目。 Gin是一个轻量级的Web框架,使用它可以快速构建高性能的Web应用程序。它具有简单易用、性能出色和灵活的特点。在微服务开发中,Gin可以作为HTTP服务器框架,处理和响应客户端的HTTP请求。 gRPC是一种高性能、开源的远程过程调用(RPC)框架。它支持多种编程语言,并使用带有协议缓冲区的Google Protocol Buffers进行数据交换。在微服务架构中,gRPC可以用于服务之间的通信,通过定义接口和消息格式,实现服务间的数据传输和调用。 Etcd是一个高可靠、分布式的键值存储系统。它使用Raft一致性算法来保证数据的可靠性和一致性。在微服务开发中,Etcd可以作为服务发现和配置管理的工具,用于注册和发现各个微服务的信息。 对于重构grpc-todolist项目来说,使用gin可以将原有的HTTP接口改写为更加高性能的接口,提高整个系统的性能。通过使用gRPC,可以将原有的接口定义为gRPC接口,实现服务间的高效通信,并且易于扩展和维护。同时,借助Etcd实现服务注册和发现,提高系统的可用性和灵活性。 总而言之,通过使用gingrpc和etcd对grpc-todolist项目进行重构,可以提高系统性能、扩展性和可维护性。这种微服务开发方式能够更好地适应大规模分布式系统的需求,使得系统更加稳定和可靠。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值