-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathpxc-data.sh
executable file
·122 lines (111 loc) · 3.16 KB
/
pxc-data.sh
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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
#!/usr/bin/env bash
usage() {
echo "Usage: $(basename "$0") --namespace <ns> --cluster <cluster> --insert/--rw --database <db>"
exit 1
}
main() {
local cluster=""
local namespace=""
local username="root"
local password=""
local endpoint=""
local database="sbtest"
local command=""
local time="120"
local sysbench_opts="--rand-type=pareto --report-interval=1 --tables=4 --table_size=500000 --threads=4"
while [[ $# -gt 0 ]]; do
key="$1"
case "${key}" in
-h | --help)
usage
exit 0
;;
-c | --cluster)
cluster="$2"
shift
shift
;;
-n | --namespace)
namespace="$2"
shift
shift
;;
-u | --user)
username="$2"
shift
shift
;;
-p | --password)
password="$2"
shift
shift
;;
-e | --endpoint)
endpoint="$2"
shift
shift
;;
-d | --database)
database="$2"
shift
shift
;;
-i | --insert)
command="insert"
shift
;;
-w | --rw)
command="rw"
shift
;;
-t | --time)
time="$2"
shift
shift
;;
*)
echo "unknown flag or option ${key}"
usage
exit 1
;;
esac
done
if [[ -z ${command} ]]; then
echo "Please specify either --insert or --rw parameter!"
exit 1
fi
if [[ -z ${namespace} ]]; then
namespace=$(kubectl config view --minify --output 'jsonpath={..namespace}')
fi
if [[ -z ${cluster} ]]; then
cluster=$(kubectl get pxc --output name ${namespace:+--namespace $namespace} 2>/dev/null | sed 's:^perconaxtradbcluster.pxc.percona.com/::')
if [ "$(echo "${cluster}" | wc -l)" -gt 1 ]; then
echo "There's more than one cluster, please specify --cluster <cluster> !"
exit 1
elif [ -z "${cluster}" ]; then
echo "No cluster available in the namespace!"
exit 1
fi
fi
if [[ -z ${endpoint} ]]; then
endpoint=$(kubectl get pxc "${cluster}" -ojsonpath='{.status.host}')
fi
if [[ -z ${password} ]]; then
secrets_name=$(kubectl get pxc "${cluster}" -ojsonpath='{.spec.secretsName}')
if [[ -z ${secrets_name} ]]; then
secrets_name="${cluster}-secrets"
fi
password=$(kubectl get secrets ${secrets_name} -otemplate='{{.data.'"${username}"' | base64decode}}')
fi
if [[ ${command} == "insert" ]]; then
echo -e "### Running ${command} workload on database: ${database} ###"
echo -e "MySQL endpoint: ${endpoint}\n"
kubectl run -it --rm percona-client-${RANDOM} --image=percona:8.0 --restart=Never -- mysql -h"${endpoint}" -u"${username}" -p"${password}" -e "create database ${database};"
kubectl run -it --rm sysbench-client-${RANDOM} --image=perconalab/sysbench:latest --restart=Never -- sysbench oltp_read_write --mysql-host="${endpoint}" --mysql-user="${username}" --mysql-password="${password}" --mysql-db="${database}" ${sysbench_opts} prepare
elif [[ ${command} == "rw" ]]; then
echo -e "### Running ${command} workload on database: ${database} ###"
echo -e "MySQL endpoint: ${endpoint}\n"
kubectl run -it --rm sysbench-client-${RANDOM} --image=perconalab/sysbench:latest --restart=Never -- sysbench oltp_read_write --mysql-host="${endpoint}" --mysql-user="${username}" --mysql-password="${password}" --mysql-db="${database}" --time="${time}" ${sysbench_opts} run
fi
}
main "$@" || exit 1