logging-deployer.yaml 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345
  1. apiVersion: "v1"
  2. kind: "List"
  3. items:
  4. -
  5. apiVersion: "v1"
  6. kind: "Template"
  7. metadata:
  8. name: logging-deployer-account-template
  9. annotations:
  10. description: "Template for creating the deployer account and roles needed for the aggregated logging deployer. Create as cluster-admin."
  11. tags: "infrastructure"
  12. objects:
  13. -
  14. apiVersion: v1
  15. kind: ServiceAccount
  16. name: logging-deployer
  17. metadata:
  18. name: logging-deployer
  19. labels:
  20. logging-infra: deployer
  21. provider: openshift
  22. component: deployer
  23. -
  24. apiVersion: v1
  25. kind: ServiceAccount
  26. metadata:
  27. name: aggregated-logging-kibana
  28. -
  29. apiVersion: v1
  30. kind: ServiceAccount
  31. metadata:
  32. name: aggregated-logging-elasticsearch
  33. -
  34. apiVersion: v1
  35. kind: ServiceAccount
  36. metadata:
  37. name: aggregated-logging-fluentd
  38. -
  39. apiVersion: v1
  40. kind: ServiceAccount
  41. metadata:
  42. name: aggregated-logging-curator
  43. - apiVersion: v1
  44. kind: ClusterRole
  45. metadata:
  46. name: oauth-editor
  47. rules:
  48. - resources:
  49. - oauthclients
  50. verbs:
  51. - create
  52. - delete
  53. - apiVersion: v1
  54. kind: ClusterRole
  55. metadata:
  56. name: daemonset-admin
  57. rules:
  58. - resources:
  59. - daemonsets
  60. apiGroups:
  61. - extensions
  62. verbs:
  63. - create
  64. - get
  65. - list
  66. - watch
  67. - delete
  68. - update
  69. - apiVersion: v1
  70. kind: ClusterRole
  71. metadata:
  72. name: rolebinding-reader
  73. rules:
  74. - resources:
  75. - clusterrolebindings
  76. verbs:
  77. - get
  78. -
  79. apiVersion: v1
  80. kind: RoleBinding
  81. metadata:
  82. name: logging-deployer-edit-role
  83. roleRef:
  84. kind: ClusterRole
  85. name: edit
  86. subjects:
  87. - kind: ServiceAccount
  88. name: logging-deployer
  89. -
  90. apiVersion: v1
  91. kind: RoleBinding
  92. metadata:
  93. name: logging-deployer-dsadmin-role
  94. roleRef:
  95. kind: ClusterRole
  96. name: daemonset-admin
  97. subjects:
  98. - kind: ServiceAccount
  99. name: logging-deployer
  100. -
  101. apiVersion: v1
  102. kind: RoleBinding
  103. metadata:
  104. name: logging-elasticsearch-view-role
  105. roleRef:
  106. kind: ClusterRole
  107. name: view
  108. subjects:
  109. - kind: ServiceAccount
  110. name: aggregated-logging-elasticsearch
  111. -
  112. apiVersion: "v1"
  113. kind: "Template"
  114. metadata:
  115. name: logging-deployer-template
  116. annotations:
  117. description: "Template for running the aggregated logging deployer in a pod. Requires empowered 'logging-deployer' service account."
  118. tags: "infrastructure"
  119. labels:
  120. logging-infra: deployer
  121. provider: openshift
  122. objects:
  123. -
  124. apiVersion: v1
  125. kind: Pod
  126. metadata:
  127. generateName: logging-deployer-
  128. spec:
  129. containers:
  130. - image: ${IMAGE_PREFIX}logging-deployment:${IMAGE_VERSION}
  131. imagePullPolicy: Always
  132. name: deployer
  133. volumeMounts:
  134. - name: empty
  135. mountPath: /etc/deploy
  136. env:
  137. - name: PROJECT
  138. valueFrom:
  139. fieldRef:
  140. fieldPath: metadata.namespace
  141. - name: IMAGE_PREFIX
  142. value: ${IMAGE_PREFIX}
  143. - name: IMAGE_VERSION
  144. value: ${IMAGE_VERSION}
  145. - name: IMAGE_PULL_SECRET
  146. value: ${IMAGE_PULL_SECRET}
  147. - name: INSECURE_REGISTRY
  148. value: ${INSECURE_REGISTRY}
  149. - name: ENABLE_OPS_CLUSTER
  150. value: ${ENABLE_OPS_CLUSTER}
  151. - name: KIBANA_HOSTNAME
  152. value: ${KIBANA_HOSTNAME}
  153. - name: KIBANA_OPS_HOSTNAME
  154. value: ${KIBANA_OPS_HOSTNAME}
  155. - name: PUBLIC_MASTER_URL
  156. value: ${PUBLIC_MASTER_URL}
  157. - name: MASTER_URL
  158. value: ${MASTER_URL}
  159. - name: ES_INSTANCE_RAM
  160. value: ${ES_INSTANCE_RAM}
  161. - name: ES_PVC_SIZE
  162. value: ${ES_PVC_SIZE}
  163. - name: ES_PVC_PREFIX
  164. value: ${ES_PVC_PREFIX}
  165. - name: ES_PVC_DYNAMIC
  166. value: ${ES_PVC_DYNAMIC}
  167. - name: ES_CLUSTER_SIZE
  168. value: ${ES_CLUSTER_SIZE}
  169. - name: ES_NODE_QUORUM
  170. value: ${ES_NODE_QUORUM}
  171. - name: ES_RECOVER_AFTER_NODES
  172. value: ${ES_RECOVER_AFTER_NODES}
  173. - name: ES_RECOVER_EXPECTED_NODES
  174. value: ${ES_RECOVER_EXPECTED_NODES}
  175. - name: ES_RECOVER_AFTER_TIME
  176. value: ${ES_RECOVER_AFTER_TIME}
  177. - name: ES_OPS_INSTANCE_RAM
  178. value: ${ES_OPS_INSTANCE_RAM}
  179. - name: ES_OPS_PVC_SIZE
  180. value: ${ES_OPS_PVC_SIZE}
  181. - name: ES_OPS_PVC_PREFIX
  182. value: ${ES_OPS_PVC_PREFIX}
  183. - name: ES_OPS_PVC_DYNAMIC
  184. value: ${ES_OPS_PVC_DYNAMIC}
  185. - name: ES_OPS_CLUSTER_SIZE
  186. value: ${ES_OPS_CLUSTER_SIZE}
  187. - name: ES_OPS_NODE_QUORUM
  188. value: ${ES_OPS_NODE_QUORUM}
  189. - name: ES_OPS_RECOVER_AFTER_NODES
  190. value: ${ES_OPS_RECOVER_AFTER_NODES}
  191. - name: ES_OPS_RECOVER_EXPECTED_NODES
  192. value: ${ES_OPS_RECOVER_EXPECTED_NODES}
  193. - name: ES_OPS_RECOVER_AFTER_TIME
  194. value: ${ES_OPS_RECOVER_AFTER_TIME}
  195. - name: FLUENTD_NODESELECTOR
  196. value: ${FLUENTD_NODESELECTOR}
  197. - name: ES_NODESELECTOR
  198. value: ${ES_NODESELECTOR}
  199. - name: ES_OPS_NODESELECTOR
  200. value: ${ES_OPS_NODESELECTOR}
  201. - name: KIBANA_NODESELECTOR
  202. value: ${KIBANA_NODESELECTOR}
  203. - name: KIBANA_OPS_NODESELECTOR
  204. value: ${KIBANA_OPS_NODESELECTOR}
  205. - name: CURATOR_NODESELECTOR
  206. value: ${CURATOR_NODESELECTOR}
  207. - name: CURATOR_OPS_NODESELECTOR
  208. value: ${CURATOR_OPS_NODESELECTOR}
  209. - name: MODE
  210. value: ${MODE}
  211. dnsPolicy: ClusterFirst
  212. restartPolicy: Never
  213. serviceAccount: logging-deployer
  214. volumes:
  215. - name: empty
  216. emptyDir: {}
  217. parameters:
  218. -
  219. description: "The mode that the deployer runs in."
  220. name: MODE
  221. value: "install"
  222. -
  223. description: 'Specify prefix for logging components; e.g. for "openshift/origin-logging-deployer:v1.1", set prefix "openshift/origin-"'
  224. name: IMAGE_PREFIX
  225. value: "docker.io/openshift/origin-"
  226. -
  227. description: 'Specify version for logging components; e.g. for "openshift/origin-logging-deployer:v1.1", set version "v1.1"'
  228. name: IMAGE_VERSION
  229. value: "latest"
  230. -
  231. description: "(Deprecated) Specify the name of an existing pull secret to be used for pulling component images from an authenticated registry."
  232. name: IMAGE_PULL_SECRET
  233. -
  234. description: "(Deprecated) Allow the registry for logging component images to be non-secure (not secured with a certificate signed by a known CA)"
  235. name: INSECURE_REGISTRY
  236. value: "false"
  237. -
  238. description: "(Deprecated) If true, set up to use a second ES cluster for ops logs."
  239. name: ENABLE_OPS_CLUSTER
  240. value: "false"
  241. -
  242. description: "(Deprecated) External hostname where clients will reach kibana"
  243. name: KIBANA_HOSTNAME
  244. value: "kibana.example.com"
  245. -
  246. description: "(Deprecated) External hostname at which admins will visit the ops Kibana."
  247. name: KIBANA_OPS_HOSTNAME
  248. value: kibana-ops.example.com
  249. -
  250. description: "(Deprecated) External URL for the master, for OAuth purposes"
  251. name: PUBLIC_MASTER_URL
  252. value: "https://localhost:8443"
  253. -
  254. description: "(Deprecated) Internal URL for the master, for authentication retrieval"
  255. name: MASTER_URL
  256. value: "https://kubernetes.default.svc.cluster.local"
  257. -
  258. description: "(Deprecated) How many instances of ElasticSearch to deploy."
  259. name: ES_CLUSTER_SIZE
  260. value: "1"
  261. -
  262. description: "(Deprecated) Amount of RAM to reserve per ElasticSearch instance."
  263. name: ES_INSTANCE_RAM
  264. value: "8G"
  265. -
  266. description: "(Deprecated) Size of the PersistentVolumeClaim to create per ElasticSearch instance, e.g. 100G. If empty, no PVCs will be created and emptyDir volumes are used instead."
  267. name: ES_PVC_SIZE
  268. -
  269. description: "(Deprecated) Prefix for the names of PersistentVolumeClaims to be created; a number will be appended per instance. If they don't already exist, they will be created with size ES_PVC_SIZE."
  270. name: ES_PVC_PREFIX
  271. value: "logging-es-"
  272. -
  273. description: '(Deprecated) Set to "true" to request dynamic provisioning (if enabled for your cluster) of a PersistentVolume for the ES PVC. '
  274. name: ES_PVC_DYNAMIC
  275. -
  276. description: "(Deprecated) Number of nodes required to elect a master (ES minimum_master_nodes). By default, derived from ES_CLUSTER_SIZE / 2 + 1."
  277. name: ES_NODE_QUORUM
  278. -
  279. description: "(Deprecated) Number of nodes required to be present before the cluster will recover from a full restart. By default, one fewer than ES_CLUSTER_SIZE."
  280. name: ES_RECOVER_AFTER_NODES
  281. -
  282. description: "(Deprecated) Number of nodes desired to be present before the cluster will recover from a full restart. By default, ES_CLUSTER_SIZE."
  283. name: ES_RECOVER_EXPECTED_NODES
  284. -
  285. description: "(Deprecated) Timeout for *expected* nodes to be present when cluster is recovering from a full restart."
  286. name: ES_RECOVER_AFTER_TIME
  287. value: "5m"
  288. -
  289. description: "(Deprecated) How many ops instances of ElasticSearch to deploy. By default, ES_CLUSTER_SIZE."
  290. name: ES_OPS_CLUSTER_SIZE
  291. -
  292. description: "(Deprecated) Amount of RAM to reserve per ops ElasticSearch instance."
  293. name: ES_OPS_INSTANCE_RAM
  294. value: "8G"
  295. -
  296. description: "(Deprecated) Size of the PersistentVolumeClaim to create per ElasticSearch ops instance, e.g. 100G. If empty, no PVCs will be created and emptyDir volumes are used instead."
  297. name: ES_OPS_PVC_SIZE
  298. -
  299. description: "(Deprecated) Prefix for the names of PersistentVolumeClaims to be created; a number will be appended per instance. If they don't already exist, they will be created with size ES_OPS_PVC_SIZE."
  300. name: ES_OPS_PVC_PREFIX
  301. value: "logging-es-ops-"
  302. -
  303. description: '(Deprecated) Set to "true" to request dynamic provisioning (if enabled for your cluster) of a PersistentVolume for the ES ops PVC. '
  304. name: ES_OPS_PVC_DYNAMIC
  305. -
  306. description: "(Deprecated) Number of ops nodes required to elect a master (ES minimum_master_nodes). By default, derived from ES_CLUSTER_SIZE / 2 + 1."
  307. name: ES_OPS_NODE_QUORUM
  308. -
  309. description: "(Deprecated) Number of ops nodes required to be present before the cluster will recover from a full restart. By default, one fewer than ES_OPS_CLUSTER_SIZE."
  310. name: ES_OPS_RECOVER_AFTER_NODES
  311. -
  312. description: "(Deprecated) Number of ops nodes desired to be present before the cluster will recover from a full restart. By default, ES_OPS_CLUSTER_SIZE."
  313. name: ES_OPS_RECOVER_EXPECTED_NODES
  314. -
  315. description: "(Deprecated) Timeout for *expected* ops nodes to be present when cluster is recovering from a full restart."
  316. name: ES_OPS_RECOVER_AFTER_TIME
  317. value: "5m"
  318. -
  319. description: "(Deprecated) The nodeSelector used for the Fluentd DaemonSet."
  320. name: FLUENTD_NODESELECTOR
  321. value: "logging-infra-fluentd=true"
  322. -
  323. description: "(Deprecated) Node selector Elasticsearch cluster (label=value)."
  324. name: ES_NODESELECTOR
  325. value: ""
  326. -
  327. description: "(Deprecated) Node selector Elasticsearch operations cluster (label=value)."
  328. name: ES_OPS_NODESELECTOR
  329. value: ""
  330. -
  331. description: "(Deprecated) Node selector Kibana cluster (label=value)."
  332. name: KIBANA_NODESELECTOR
  333. value: ""
  334. -
  335. description: "(Deprecated) Node selector Kibana operations cluster (label=value)."
  336. name: KIBANA_OPS_NODESELECTOR
  337. value: ""
  338. -
  339. description: "(Deprecated) Node selector Curator (label=value)."
  340. name: CURATOR_NODESELECTOR
  341. value: ""
  342. -
  343. description: "(Deprecated) Node selector operations Curator (label=value)."
  344. name: CURATOR_OPS_NODESELECTOR
  345. value: ""