-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmain.go
More file actions
86 lines (69 loc) · 1.64 KB
/
main.go
File metadata and controls
86 lines (69 loc) · 1.64 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
package main
import (
"flag"
"fmt"
"net"
"os"
"os/signal"
"syscall"
"golang.org/x/net/context"
"google.golang.org/grpc"
pb "github.com/vems/pb/add"
"github.com/go-kit/kit/endpoint"
"github.com/go-kit/kit/log"
)
func main() {
var (
grpcAddr = flag.String("addr", ":8080", "gRPC (HTTP) listen address")
)
flag.Parse()
// Logging domain.
var logger log.Logger
{
logger = log.NewLogfmtLogger(os.Stdout)
logger = log.NewContext(logger).With("ts", log.DefaultTimestampUTC)
logger = log.NewContext(logger).With("caller", log.DefaultCaller)
}
logger.Log("msg", "Service Started")
defer logger.Log("msg", "Service Quit")
// Business domain.
var service Service
{
service = NewBasicService()
service = ServiceLoggingMiddleware(logger)(service)
}
// Endpoint domain.
var sumEndpoint endpoint.Endpoint
{
sumLogger := log.NewContext(logger).With("method", "Sum")
sumEndpoint = MakeSumEndpoint(service)
sumEndpoint = EndpointLoggingMiddleware(sumLogger)(sumEndpoint)
}
endpoints := Endpoints{
SumEndpoint: sumEndpoint,
}
// Mechanical domain.
errc := make(chan error)
ctx := context.Background()
// Interrupt handler.
go func() {
c := make(chan os.Signal, 1)
signal.Notify(c, syscall.SIGINT, syscall.SIGTERM)
errc <- fmt.Errorf("%s", <-c)
}()
// gRPC transport.
go func() {
logger := log.NewContext(logger).With("transport", "gRPC")
ln, err := net.Listen("tcp", *grpcAddr)
if err != nil {
errc <- err
return
}
srv := MakeGRPCServer(ctx, endpoints, logger)
s := grpc.NewServer()
pb.RegisterAddServer(s, srv)
logger.Log("addr", *grpcAddr)
errc <- s.Serve(ln)
}()
logger.Log("exit", <-errc)
}