Go to file
2020-09-20 15:11:09 +03:00
proto v3 refactor (#1868) 2020-09-20 15:11:09 +03:00
codec.go embed grpc server stream and client so they can be accessed (#1916) 2020-09-20 15:11:09 +03:00
context.go v3 refactor (#1868) 2020-09-20 15:11:09 +03:00
error.go v3 refactor (#1868) 2020-09-20 15:11:09 +03:00
extractor_test.go v3 refactor (#1868) 2020-09-20 15:11:09 +03:00
extractor.go v3 refactor (#1868) 2020-09-20 15:11:09 +03:00
grpc_test.go v3 refactor (#1868) 2020-09-20 15:11:09 +03:00
grpc.go remove print statement 2020-09-20 15:11:09 +03:00
handler.go v3 refactor (#1868) 2020-09-20 15:11:09 +03:00
options.go ensure register ttl and interval are set 2020-09-20 15:11:09 +03:00
README.md Further consolidate the libraries 2020-09-20 15:11:08 +03:00
request.go v3 refactor (#1868) 2020-09-20 15:11:09 +03:00
response.go v3 refactor (#1868) 2020-09-20 15:11:09 +03:00
server.go v3 refactor (#1868) 2020-09-20 15:11:09 +03:00
stream.go embed grpc server stream and client so they can be accessed (#1916) 2020-09-20 15:11:09 +03:00
subscriber.go Add subscriber naem 2020-09-20 15:11:09 +03:00
util.go grpc client/server fixes (#1355) 2020-09-20 15:11:09 +03:00

GRPC Server

The grpc server is a micro.Server compatible server.

Overview

The server makes use of the google.golang.org/grpc framework for the underlying server but continues to use micro handler signatures and protoc-gen-micro generated code.

Usage

Specify the server to your micro service

import (
        "github.com/micro/go-micro"
        "github.com/micro/go-plugins/server/grpc"
)

func main() {
        service := micro.NewService(
                // This needs to be first as it replaces the underlying server
                // which causes any configuration set before it
                // to be discarded
                micro.Server(grpc.NewServer()),
                micro.Name("greeter"),
        )
}

NOTE: Setting the gRPC server and/or client causes the underlying the server/client to be replaced which causes any previous configuration set on that server/client to be discarded. It is therefore recommended to set gRPC server/client before any other configuration