-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcockroachdb_manifests.go
158 lines (149 loc) · 3.45 KB
/
cockroachdb_manifests.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
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
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
/*
Copyright 2018 The Rook Authors. All rights reserved.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package installer
import (
"strconv"
)
// CockroachDBManifests holds the funcs which return the CockroachDB manifests
type CockroachDBManifests struct {
}
// GetCockroachDBCRDs return the CockroachDB Cluster CRD
func (i *CockroachDBManifests) GetCockroachDBCRDs() string {
return `apiVersion: apiextensions.k8s.io/v1beta1
kind: CustomResourceDefinition
metadata:
name: clusters.cockroachdb.rook.io
spec:
group: cockroachdb.rook.io
names:
kind: Cluster
listKind: ClusterList
plural: clusters
singular: cluster
scope: Namespaced
version: v1alpha1
`
}
// GetCockroachDBOperator return the CockroachDB operator manifest
func (i *CockroachDBManifests) GetCockroachDBOperator(namespace string) string {
return `kind: Namespace
apiVersion: v1
metadata:
name: ` + namespace + `
---
apiVersion: rbac.authorization.k8s.io/v1beta1
kind: ClusterRole
metadata:
name: rook-cockroachdb-operator
rules:
- apiGroups:
- ""
resources:
- pods
verbs:
- get
- list
- apiGroups:
- ""
resources:
- services
verbs:
- create
- apiGroups:
- apps
resources:
- statefulsets
verbs:
- create
- apiGroups:
- policy
resources:
- poddisruptionbudgets
verbs:
- create
- apiGroups:
- cockroachdb.rook.io
resources:
- "*"
verbs:
- "*"
---
apiVersion: v1
kind: ServiceAccount
metadata:
name: rook-cockroachdb-operator
namespace: ` + namespace + `
---
kind: ClusterRoleBinding
apiVersion: rbac.authorization.k8s.io/v1beta1
metadata:
name: rook-cockroachdb-operator
namespace: ` + namespace + `
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: rook-cockroachdb-operator
subjects:
- kind: ServiceAccount
name: rook-cockroachdb-operator
namespace: ` + namespace + `
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: rook-cockroachdb-operator
namespace: ` + namespace + `
labels:
app: rook-cockroachdb-operator
spec:
selector:
matchLabels:
app: rook-cockroachdb-operator
replicas: 1
template:
metadata:
labels:
app: rook-cockroachdb-operator
spec:
serviceAccountName: rook-cockroachdb-operator
containers:
- name: rook-cockroachdb-operator
image: rook/cockroachdb:master
args: ["cockroachdb", "operator"]
env:
- name: POD_NAME
valueFrom:
fieldRef:
fieldPath: metadata.name
- name: POD_NAMESPACE
valueFrom:
fieldRef:
fieldPath: metadata.namespace
`
}
// GetCockroachDBCluster return a CockroacDB Cluster object
func (i *CockroachDBManifests) GetCockroachDBCluster(namespace string, count int) string {
return `apiVersion: cockroachdb.rook.io/v1alpha1
kind: Cluster
metadata:
name: ` + namespace + `
namespace: ` + namespace + `
spec:
scope:
nodeCount: ` + strconv.Itoa(count) + `
volumeClaimTemplates: []
secure: false
cachePercent: 25
maxSQLMemoryPercent: 25
`
}