You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
75 lines
1.7 KiB
75 lines
1.7 KiB
package main
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"os"
|
|
|
|
pb "github.com/go-kratos/examples/helloworld/helloworld"
|
|
"github.com/go-kratos/kratos/v2"
|
|
"github.com/go-kratos/kratos/v2/errors"
|
|
"github.com/go-kratos/kratos/v2/log"
|
|
"github.com/go-kratos/kratos/v2/middleware"
|
|
"github.com/go-kratos/kratos/v2/middleware/logging"
|
|
"github.com/go-kratos/kratos/v2/middleware/recovery"
|
|
"github.com/go-kratos/kratos/v2/middleware/status"
|
|
"github.com/go-kratos/kratos/v2/transport/grpc"
|
|
"github.com/go-kratos/kratos/v2/transport/http"
|
|
)
|
|
|
|
// server is used to implement helloworld.GreeterServer.
|
|
type server struct {
|
|
pb.UnimplementedGreeterServer
|
|
}
|
|
|
|
// SayHello implements helloworld.GreeterServer
|
|
func (s *server) SayHello(ctx context.Context, in *pb.HelloRequest) (*pb.HelloReply, error) {
|
|
if in.Name == "error" {
|
|
return nil, errors.InvalidArgument("BadRequest", "invalid argument %s", in.Name)
|
|
}
|
|
if in.Name == "panic" {
|
|
panic("grpc panic")
|
|
}
|
|
return &pb.HelloReply{Message: fmt.Sprintf("Hello %+v", in.Name)}, nil
|
|
}
|
|
|
|
func main() {
|
|
logger := log.NewStdLogger(os.Stdout)
|
|
|
|
log := log.NewHelper("main", logger)
|
|
|
|
grpcSrv := grpc.NewServer(
|
|
grpc.Address(":9000"),
|
|
grpc.Middleware(
|
|
middleware.Chain(
|
|
logging.Server(logging.WithLogger(logger)),
|
|
status.Server(),
|
|
recovery.Recovery(),
|
|
),
|
|
))
|
|
|
|
s := &server{}
|
|
pb.RegisterGreeterServer(grpcSrv, s)
|
|
|
|
httpSrv := http.NewServer(http.Address(":8000"))
|
|
httpSrv.HandlePrefix("/", pb.NewGreeterHandler(s,
|
|
http.Middleware(
|
|
middleware.Chain(
|
|
logging.Server(logging.WithLogger(logger)),
|
|
recovery.Recovery(),
|
|
),
|
|
)),
|
|
)
|
|
|
|
app := kratos.New(
|
|
kratos.Name("helloworld"),
|
|
kratos.Server(
|
|
httpSrv,
|
|
grpcSrv,
|
|
),
|
|
)
|
|
|
|
if err := app.Run(); err != nil {
|
|
log.Error(err)
|
|
}
|
|
}
|
|
|