-
Notifications
You must be signed in to change notification settings - Fork 228
/
Copy pathmain.go
123 lines (97 loc) · 2.99 KB
/
main.go
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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
/*
Copyright 2021 The CloudEvents Authors
SPDX-License-Identifier: Apache-2.0
*/
package main
import (
"context"
"fmt"
"log"
"math/rand"
"net/http"
"time"
"contrib.go.opencensus.io/exporter/prometheus"
"go.opencensus.io/examples/exporter"
"go.opencensus.io/stats/view"
"go.opencensus.io/trace"
"go.opencensus.io/zpages"
obsclient "github.com/cloudevents/sdk-go/observability/opencensus/v2/client"
cloudevents "github.com/cloudevents/sdk-go/v2"
"github.com/cloudevents/sdk-go/v2/client"
cecontext "github.com/cloudevents/sdk-go/v2/context"
"github.com/cloudevents/sdk-go/v2/event"
)
func main() {
ctx := context.Background()
c, err := client.NewHTTP()
if err != nil {
log.Fatalf("failed to create client, %v", err)
}
go mainSender()
go mainMetrics()
log.Printf("will listen on :8080\n")
log.Fatalf("failed to start receiver: %s", c.StartReceiver(ctx, gotEvent))
}
// Example is the expected incoming event.
type Example struct {
Sequence int `json:"id"`
Message string `json:"message"`
}
func gotEvent(event event.Event) {
data := &Example{}
if err := event.DataAs(data); err != nil {
fmt.Printf("failed to get data as Example: %s\n", err.Error())
return
}
time.Sleep(time.Duration(rand.Intn(3000)) * time.Millisecond)
fmt.Printf("%s: %d - %q\n", event.Context.GetType(), data.Sequence, data.Message)
}
func mainSender() {
ctx := cecontext.WithTarget(context.Background(), "http://localhost:8181/")
c, err := obsclient.NewClientHTTP(nil, nil)
if err != nil {
log.Fatalf("failed to create client, %v", err)
}
for { //ever
for i := 0; i < 1000; i++ {
e := cloudevents.NewEvent()
e.SetType("com.cloudevents.sample.sent")
e.SetSource("https://github.com/cloudevents/sdk-go/v2/samples/sender")
_ = e.SetData(cloudevents.ApplicationJSON, &Example{
Sequence: i,
Message: "Hello, World!",
})
if resp, result := c.Request(ctx, e); cloudevents.IsUndelivered(result) {
log.Printf("failed to send: %v", result)
} else if resp != nil {
fmt.Printf("got back a response event of type %s", resp.Context.GetType())
}
time.Sleep(2000 * time.Millisecond)
}
}
}
func mainMetrics() {
printExporter := &exporter.PrintExporter{}
exp, err := prometheus.NewExporter(prometheus.Options{})
if err != nil {
log.Fatalf("Failed to create the Stackdriver stats exporter: %v", err)
}
h := http.NewServeMux()
h.Handle("/metrics", exp)
zpages.Handle(h, "/debug")
// Register the stats exporter
view.RegisterExporter(exp)
trace.RegisterExporter(printExporter)
// Always trace for this demo. In a production application, you should
// configure this to a trace.ProbabilitySampler set at the desired
// probability.
trace.ApplyConfig(trace.Config{DefaultSampler: trace.AlwaysSample()})
// Register the views
if err := view.Register(
obsclient.LatencyView,
); err != nil {
log.Fatalf("Failed to register views: %v", err)
}
view.SetReportingPeriod(2 * time.Second)
log.Fatal("failed metrics ListenAndServe ", http.ListenAndServe("localhost:9090", h))
}