-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy path0design.txt
47 lines (36 loc) · 860 Bytes
/
0design.txt
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
Parallelism design.
var numParallel = 20
var tokens = make(chan struct{}, numParallel)
var results = make(chan *ResponseInfo)
var wg sync.WaitGroup
go func() {
for query := loopOverFile(BatchFile) {
wg.Add(1)
tokens <- struct{}{} // acquire token
go func(query string) {
defer wg.Done()
results <- runQuery(query)
<- tokens // release token
}(query)
}
wg.Wait()
close(results)
}()
for r := range(results) {
printResponse(r)
}
#############
fun runQuery() {
responses := make(chan *ResponseInfo)
for _, server := range serverList {
r := &ResponseInfo()
go sendDNSquery(server, responses)
}
for i := 0; i < len(serverList); i++ {
r1 = <-responses
if responseOK(r1) {
break
}
}
return r1
}