-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmaster.go
61 lines (52 loc) · 1.02 KB
/
master.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
package main
import (
"net"
"net/http"
"net/rpc"
"net/url"
"example/therpc"
"time"
"sync"
)
func TestTask(s *therpc.Server) {
url1 := &url.URL{
Scheme: "https",
Host: "baidu.com",
}
url2 := &url.URL{
Scheme: "https",
Host: "sina.com",
}
api1 := therpc.Api{
Method: "get",
Url: url1,
}
api2 := therpc.Api{
Method: "get",
Url: url2,
}
task := therpc.Task{
Api: []therpc.Api{api1, api2},
C: 100,
Uid: therpc.GenerateUUID(),
}
tick := time.Tick(time.Second * 20)
for {
select {
case <-tick:
s.Requests(&task)
}
}
}
func main() {
s := &therpc.Server{
HeartBeat: make(map[string]time.Time),
TaskQueue: make([]therpc.Task, 0),
Mutex: sync.Mutex{},
}
go TestTask(s)
rpc.Register(s)
rpc.HandleHTTP()
lis, _ := net.Listen("tcp", ":8973")
http.Serve(lis, nil)
}