repositorypackage
2.1.1+incompatible
Repository: https://github.com/eleniums/gohost.git
Documentation: pkg.go.dev
# README
gohost
A tool for hosting a Go service with gRPC and HTTP endpoints.
Installation
go get -u github.com/eleniums/gohost
Prerequisites
- Requires Go 1.9 or later
- Uses dep for dependencies
- Uses grpc-go for gRPC endpoints
- Uses grpc-gateway for HTTP endpoints
- See the full list of imported packages here
Example
Sample service implementation:
// Service contains the implementation for the gRPC service.
type Service struct{}
// NewService creates a new instance of Service.
func NewService() *Service {
return &Service{}
}
// Hello will return a personalized greeting.
func (s *Service) Hello(ctx context.Context, in *pb.HelloRequest) (*pb.HelloResponse, error) {
// create greeting
greeting := "Hello!"
if in.Name != "" {
greeting = fmt.Sprintf("Hello %v!", in.Name)
}
log.Printf("Received request from: %v", in.Name)
// return response
return &pb.HelloResponse{
Greeting: greeting,
}, nil
}
Use the Hoster struct to serve up gRPC and HTTP endpoints:
// create the service
service := hello.NewService()
// create the hoster
hoster := gohost.NewHoster()
hoster.GRPCAddr = *grpcAddr
hoster.HTTPAddr = *httpAddr
hoster.DebugAddr = *debugAddr
hoster.EnableDebug = *enableDebug
hoster.CertFile = *certFile
hoster.KeyFile = *keyFile
hoster.InsecureSkipVerify = *insecureSkipVerify
hoster.MaxSendMsgSize = *maxSendMsgSize
hoster.MaxRecvMsgSize = *maxRecvMsgSize
hoster.RegisterGRPCServer(func(s *grpc.Server) {
pb.RegisterHelloServiceServer(s, service)
})
hoster.RegisterHTTPGateway(pb.RegisterHelloServiceHandlerFromEndpoint)
// start the server
err := hoster.ListenAndServe()
if err != nil {
log.Fatalf("Unable to start the server: %v", err)
}
See the full example here.