59 lines
1.2 KiB
Go
Raw Normal View History

2025-02-16 17:30:04 +08:00
package main
import (
"context"
2025-02-16 18:13:10 +08:00
"fmt"
"io"
2025-02-16 17:30:04 +08:00
"net"
"gitlab.com/go-course-project/go17/skills/grpc/service"
"google.golang.org/grpc"
)
2025-02-16 18:13:10 +08:00
type HelloServiceServer struct {
2025-02-16 17:30:04 +08:00
service.UnimplementedHelloServiceServer
}
2025-02-16 18:13:10 +08:00
func (HelloServiceServer) Hello(ctx context.Context, req *service.HelloRequest) (*service.HelloResponse, error) {
2025-02-16 17:30:04 +08:00
return &service.HelloResponse{
Message: "hello, " + req.MyName,
}, nil
}
2025-02-16 18:13:10 +08:00
func (HelloServiceServer) Chat(stream grpc.BidiStreamingServer[service.ChatRequest, service.ChatResponse]) error {
// 1. 获取用户的请求,然后处理, 处理完成后通过stream 返回给客户端
for {
// 接收一个请求
req, err := stream.Recv()
if err != nil {
// 如果遇到io.EOF表示客户端流被关闭
if err == io.EOF {
return nil
}
return err
}
// 2. 处理请求
fmt.Println(req.Message)
stream.Send(&service.ChatResponse{
Id: req.Id,
IsSuccess: true,
})
}
}
2025-02-16 17:30:04 +08:00
func main() {
// 1. 示例化一个grpc server对象
server := grpc.NewServer()
2025-02-16 18:13:10 +08:00
service.RegisterHelloServiceServer(server, &HelloServiceServer{})
2025-02-16 17:30:04 +08:00
// 2. 启动grpc服务
lis, err := net.Listen("tcp", ":1234")
if err != nil {
panic(err)
}
if err := server.Serve(lis); err != nil {
panic(err)
}
}