为什么客户端总是从本地主机GO接收到“传输:接收到意外的内容类型”写GRPC服务

时间:2018-11-18 12:39:58

标签: go grpc go-micro

我刚刚从micro/go-grpc克隆了示例代码,并尝试在localhost中构建grpc服务器。

proto file 

syntax = "proto3";

package go.micro.srv.greeter;

service Say {
    rpc Hello(Request) returns (Response) {}
}

message Request {
    string name = 1;
}

message Response {
    string msg = 1;
}

server / main.go

package main

import (
    "context"
    "log"

    "github.com/micro/go-micro"
    "github.com/micro/go-grpc"
    hello "github.com/micro/go-grpc/examples/greeter/server/proto/hello"
)

type Say struct{}

func (s *Say) Hello(ctx context.Context, req *hello.Request, rsp 
*hello.Response) error {
    log.Print("Received Say.Hello request")
    rsp.Msg = "Hello " + req.Name
    return nil
}

func main() {
    service := grpc.NewService(
        micro.Name("go.micro.srv.greeter"),
    )

// optionally setup command line usage
service.Init()

// Register Handlers
hello.RegisterSayHandler(service.Server(), new(Say))

// Run server
if err := service.Run(); err != nil {
    log.Fatal(err)
    }
}

client / main.go

package main

import (
    "context"
    "fmt"

    "github.com/micro/cli"
    "github.com/micro/go-grpc"
    hello "github.com/micro/go-grpc/examples/greeter/server/proto/hello"
    "github.com/micro/go-micro"
)

var (
    // service to call
    serviceName string
)

func main() {
    service := grpc.NewService()

    service.Init(
        micro.Flags(cli.StringFlag{
            Name:        "service_name",
            Value:       "go.micro.srv.greeter",
            Destination: &serviceName,
        }),
    )

    cl := hello.NewSayService(serviceName, service.Client())

    rsp, err := cl.Hello(context.TODO(), &hello.Request{
        Name: "John",
    })
    if err != nil {
        fmt.Println(err)
        return
    }

    fmt.Println(rsp.Msg)
}

我的操作系统是MacOsX,go版本是1.11.1

当我运行服务器端示例代码时,一切看起来都很好:

$ go run ./main.go --server_address:localhost:9999
2018/11/18 20:08:05 Listening on 127.0.0.1:9999
2018/11/18 20:08:05 Broker Listening on [::]:62739
2018/11/18 20:08:05 Registering node: go.micro.srv.greeter-9b2818b0-eb2a-11e8-bfef-720008acb800

但是如果我运行客户端示例代码,总是会收到:

{"id":"","code":0,"detail":"transport: received the unexpected content-type "text/plain"","status":""}

我尝试删除--server_address,但还是一样。我试图添加mdns注册表,但都不起作用。我尝试使用$ micro health go.micro.srv.greeter,它返回了相同的结果。

想知道我的设置有什么问题吗?

1 个答案:

答案 0 :(得分:0)

我刚刚遇到了同样的错误,因为我指向了错误的端口。我确定我的设置与你的不同,这是一个不同的问题,但问题是我试图向 http 服务器发出 GRPC 请求,它返回了一个 404,内容类型为“text/plain” " 为 html。如果您在删除服务器地址时遇到同样的问题,可能是您没有正确读取参数,或者您设置的值仍然指向有 http 服务器而不是 GRPC 服务器的位置。