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
|
package client
import (
"context"
"fmt"
"io/ioutil"
"log"
"net"
"strings"
)
func tcpClientRun(ctx context.Context, node string, ch <-chan []string) error {
conn, err := net.Dial("tcp", node)
if err != nil {
return err
}
defer conn.Close()
for {
votes, ok := <-ch
if !ok {
return fmt.Errorf("channel closed - breaking tcpClientRun loop")
}
message := strings.Join(votes, " ")
log.Println("tcpclient: sending", message, "to node", node)
_, err = conn.Write([]byte(message))
if err != nil {
return err
}
response, err := ioutil.ReadAll(conn)
if err != nil {
return err
}
log.Println("tcpclient: received", string(response), "from node", node)
}
}
|