metrics-deployer.yaml 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. #!/bin/bash
  2. #
  3. # Copyright 2014-2015 Red Hat, Inc. and/or its affiliates
  4. # and other contributors as indicated by the @author tags.
  5. #
  6. # Licensed under the Apache License, Version 2.0 (the "License");
  7. # you may not use this file except in compliance with the License.
  8. # You may obtain a copy of the License at
  9. #
  10. # http://www.apache.org/licenses/LICENSE-2.0
  11. #
  12. # Unless required by applicable law or agreed to in writing, software
  13. # distributed under the License is distributed on an "AS IS" BASIS,
  14. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  15. # See the License for the specific language governing permissions and
  16. # limitations under the License.
  17. #
  18. apiVersion: "v1"
  19. kind: "Template"
  20. metadata:
  21. name: metrics-deployer-template
  22. annotations:
  23. description: "Template for deploying the required Metrics integration. Requires cluster-admin 'metrics-deployer' service account and 'metrics-deployer' secret."
  24. tags: "infrastructure"
  25. labels:
  26. metrics-infra: deployer
  27. provider: openshift
  28. component: deployer
  29. objects:
  30. -
  31. apiVersion: v1
  32. kind: Pod
  33. metadata:
  34. generateName: metrics-deployer-
  35. spec:
  36. securityContext: {}
  37. containers:
  38. - image: ${IMAGE_PREFIX}metrics-deployer:${IMAGE_VERSION}
  39. name: deployer
  40. securityContext: {}
  41. volumeMounts:
  42. - name: secret
  43. mountPath: /secret
  44. readOnly: true
  45. - name: empty
  46. mountPath: /etc/deploy
  47. env:
  48. - name: PROJECT
  49. valueFrom:
  50. fieldRef:
  51. fieldPath: metadata.namespace
  52. - name: POD_NAME
  53. valueFrom:
  54. fieldRef:
  55. fieldPath: metadata.name
  56. - name: IMAGE_PREFIX
  57. value: ${IMAGE_PREFIX}
  58. - name: IMAGE_VERSION
  59. value: ${IMAGE_VERSION}
  60. - name: MASTER_URL
  61. value: ${MASTER_URL}
  62. - name: MODE
  63. value: ${MODE}
  64. - name: CONTINUE_ON_ERROR
  65. value: ${CONTINUE_ON_ERROR}
  66. - name: REDEPLOY
  67. value: ${REDEPLOY}
  68. - name: IGNORE_PREFLIGHT
  69. value: ${IGNORE_PREFLIGHT}
  70. - name: USE_PERSISTENT_STORAGE
  71. value: ${USE_PERSISTENT_STORAGE}
  72. - name: DYNAMICALLY_PROVISION_STORAGE
  73. value: ${DYNAMICALLY_PROVISION_STORAGE}
  74. - name: HAWKULAR_METRICS_HOSTNAME
  75. value: ${HAWKULAR_METRICS_HOSTNAME}
  76. - name: CASSANDRA_NODES
  77. value: ${CASSANDRA_NODES}
  78. - name: CASSANDRA_PV_SIZE
  79. value: ${CASSANDRA_PV_SIZE}
  80. - name: METRIC_DURATION
  81. value: ${METRIC_DURATION}
  82. - name: USER_WRITE_ACCESS
  83. value: ${USER_WRITE_ACCESS}
  84. - name: HEAPSTER_NODE_ID
  85. value: ${HEAPSTER_NODE_ID}
  86. - name: METRIC_RESOLUTION
  87. value: ${METRIC_RESOLUTION}
  88. dnsPolicy: ClusterFirst
  89. restartPolicy: Never
  90. serviceAccount: metrics-deployer
  91. volumes:
  92. - name: empty
  93. emptyDir: {}
  94. - name: secret
  95. secret:
  96. secretName: metrics-deployer
  97. parameters:
  98. -
  99. description: 'Specify prefix for metrics components; e.g. for "openshift/origin-metrics-deployer:latest", set prefix "openshift/origin-"'
  100. name: IMAGE_PREFIX
  101. value: "openshift/origin-"
  102. -
  103. description: 'Specify version for metrics components; e.g. for "openshift/origin-metrics-deployer:latest", set version "latest"'
  104. name: IMAGE_VERSION
  105. value: "latest"
  106. -
  107. description: "Internal URL for the master, for authentication retrieval"
  108. name: MASTER_URL
  109. value: "https://kubernetes.default.svc:443"
  110. -
  111. description: "External hostname where clients will reach Hawkular Metrics"
  112. name: HAWKULAR_METRICS_HOSTNAME
  113. required: true
  114. -
  115. description: "Can be set to: 'preflight' to perform validation before a deployment; 'deploy' to perform an initial deployment; 'refresh' to delete and redeploy all components but to keep persisted data and routes; 'redeploy' to delete and redeploy everything (losing all data in the process); 'validate' to re-run validations after a deployment"
  116. name: MODE
  117. value: "deploy"
  118. -
  119. description: "Set to true to continue even if the deployer runs into an error."
  120. name: CONTINUE_ON_ERROR
  121. value: "false"
  122. -
  123. description: "(Deprecated) Turns 'deploy' mode into 'redeploy' mode, deleting and redeploying everything (losing all data in the process)"
  124. name: REDEPLOY
  125. value: "false"
  126. -
  127. description: "If preflight validation is blocking deployment and you're sure you don't care about it, this will ignore the results and proceed to deploy."
  128. name: IGNORE_PREFLIGHT
  129. value: "false"
  130. -
  131. description: "Set to true for persistent storage, set to false to use non persistent storage"
  132. name: USE_PERSISTENT_STORAGE
  133. value: "true"
  134. -
  135. description: "Set to true to dynamically provision storage, set to false to use use pre-created persistent volumes"
  136. name: DYNAMICALLY_PROVISION_STORAGE
  137. value: "false"
  138. -
  139. description: "The number of Cassandra Nodes to deploy for the initial cluster"
  140. name: CASSANDRA_NODES
  141. value: "1"
  142. -
  143. description: "The persistent volume size for each of the Cassandra nodes"
  144. name: CASSANDRA_PV_SIZE
  145. value: "10Gi"
  146. -
  147. description: "How many days metrics should be stored for."
  148. name: METRIC_DURATION
  149. value: "7"
  150. -
  151. description: "If a user accounts should be allowed to write metrics."
  152. name: USER_WRITE_ACCESS
  153. value: "false"
  154. -
  155. description: "The identifier used when generating metric ids in Hawkular"
  156. name: HEAPSTER_NODE_ID
  157. value: "nodename"
  158. -
  159. description: "How often metrics should be gathered. Defaults value of '15s' for 15 seconds"
  160. name: METRIC_RESOLUTION
  161. value: "15s"