-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathflags.go
94 lines (88 loc) · 3.62 KB
/
flags.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
package main
import (
"code.cloudfoundry.org/bytefmt"
"fmt"
"github.com/juju/gnuflag"
"log"
"os"
"time"
)
func route() params {
params := params{}
var showversion bool
const version = 1.3
gnuflag.DurationVar(¶ms.duration, "duration", 30*time.Second,
"Time limit for each test in seconds")
gnuflag.DurationVar(¶ms.duration, "d", 30*time.Second,
"Time limit for each test in seconds")
gnuflag.StringVar(¶ms.bs, "blockSize", "4K",
"Block size in format KB = K = KiB = 1024 MB = M = MiB = 1024 * K GB = G = GiB = 1024 * M TB = T = TiB = 1024 * G")
gnuflag.StringVar(¶ms.bs, "s", "4K",
"Block size in format KB = K = KiB = 1024 MB = M = MiB = 1024 * K GB = G = GiB = 1024 * M TB = T = TiB = 1024 * G")
gnuflag.StringVar(¶ms.os, "objectSize", "4M",
"Object size in format KB = K = KiB = 1024 MB = M = MiB = 1024 * K GB = G = GiB = 1024 * M TB = T = TiB = 1024 * G")
gnuflag.StringVar(¶ms.os, "o", "4M",
"Object size in format KB = K = KiB = 1024 MB = M = MiB = 1024 * K GB = G = GiB = 1024 * M TB = T = TiB = 1024 * G")
gnuflag.StringVar(¶ms.user, "user", "admin",
"Ceph user (cephx)")
gnuflag.StringVar(¶ms.user, "u", "client.admin",
"Ceph user (cephx)")
gnuflag.StringVar(¶ms.cluster, "cluster", "ceph",
"Ceph cluster name")
gnuflag.StringVar(¶ms.cluster, "n", "ceph",
"Ceph cluster name")
gnuflag.StringVar(¶ms.keyring, "keyring", "/etc/ceph/ceph.client.admin.keyring",
"Ceph user keyring")
gnuflag.StringVar(¶ms.keyring, "k", "/etc/ceph/ceph.client.admin.keyring",
"Ceph user keyring")
gnuflag.StringVar(¶ms.config, "config", "/etc/ceph/ceph.conf",
"Ceph config")
gnuflag.StringVar(¶ms.config, "c", "/etc/ceph/ceph.conf",
"Ceph config")
gnuflag.StringVar(¶ms.pool, "pool", "bench",
"Ceph pool")
gnuflag.StringVar(¶ms.pool, "p", "bench",
"Ceph pool")
gnuflag.StringVar(¶ms.define, "define", "",
"Define specifically osd or host. Example: osd.X, ceph-host-X")
gnuflag.StringVar(¶ms.rdefine, "rdefine", "",
"Rdefine specifically osd or host in Posix Regex (replaces define). Example: osd.X, ceph-host-X, osd.[0-9]1?$, ceph-host-[1-2]~hdd")
gnuflag.Uint64Var(¶ms.threadsCount, "threads", 1,
"Threads count")
gnuflag.Uint64Var(¶ms.threadsCount, "t", 1,
"Threads count on each osd")
gnuflag.BoolVar(¶ms.parallel, "parallel", false,
"Do test all osd in parallel mode")
gnuflag.BoolVar(¶ms.disableCheck, "disablepoolsizecheck", false,
"Do test all osd in parallel mode")
gnuflag.StringVar(¶ms.cpuprofile, "cpuprofile", "",
"Name of cpuprofile")
gnuflag.StringVar(¶ms.memprofile, "memprofile", "",
"Name of memprofile")
gnuflag.BoolVar(&showversion, "version", false, "Show sversion")
gnuflag.BoolVar(&showversion, "v", false, "Show version")
gnuflag.Parse(true)
if showversion {
fmt.Printf("go-bench version v%v\n", version)
os.Exit(0)
}
blocksize, err := bytefmt.ToBytes(params.bs)
params.blockSize = blocksize
if err != nil {
log.Println("Can't convert defined block size. 4K block size will be used")
params.blockSize = 4096
}
objsize, err := bytefmt.ToBytes(params.os)
params.objectSize = objsize
if err != nil {
log.Println("Can't convert defined block size. 4K block size will be used")
params.objectSize = 4194304
}
if params.blockSize > params.objectSize {
log.Fatalf("Current block size: %v\nCurrent object size: %v\nObject must be bigger or equal than block size", params.blockSize, params.objectSize)
}
if params.objectSize/params.blockSize < 2 {
log.Printf("Current block size: %v\nCurrent object size: %v\nOffset always will be 0", params.blockSize, params.objectSize)
}
return params
}