-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgrpc.go
37 lines (33 loc) · 1.09 KB
/
grpc.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
// Komunikacija po protokolu gRPC
//
// strežnik ustvari in vzdržuje shrambo nalog TodoStorage
// odjemalec nad shrambo izvaja operacije CRUD
// datoteka protobufStorage/protobufStorage.proto podaja strukturo sporočil gRPC
// prevajalnik protoc iz datoteke *.proto ustvari strukture in metode, ki jih uporabljamo pri klicanju oddaljenih metod
// navodila za prevajanje so v datoteki *.proto
//
// zaženemo strežnik
// go run *.go
// zaženemo enega ali več odjemalcev
// go run *.go -s [ime strežnika] -p [vrata]
// za [ime strežnika] in [vrata] vpišemo vrednosti, ki jih izpiše strežnik ob zagonu
//
// pri uporabi SLURMa lahko s stikalom --nodelist=[vozlišče] določimo vozlišče, kjer naj se program zažene
package main
import (
"flag"
"fmt"
)
func main() {
// preberemo argumente iz ukazne vrstice
sPtr := flag.String("s", "", "server URL")
pPtr := flag.Int("p", 9876, "port number")
flag.Parse()
// zaženemo strežnik ali odjemalca
url := fmt.Sprintf("%v:%v", *sPtr, *pPtr)
if *sPtr == "" {
Server(url)
} else {
Client(url)
}
}