fluentd.j2 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. apiVersion: extensions/v1beta1
  2. kind: "DaemonSet"
  3. metadata:
  4. name: "{{daemonset_name}}"
  5. labels:
  6. provider: openshift
  7. component: "{{daemonset_component}}"
  8. logging-infra: "{{daemonset_component}}"
  9. spec:
  10. selector:
  11. matchLabels:
  12. provider: openshift
  13. component: "{{daemonset_component}}"
  14. updateStrategy:
  15. type: RollingUpdate
  16. rollingUpdate:
  17. minReadySeconds: 600
  18. template:
  19. metadata:
  20. name: "{{daemonset_container_name}}"
  21. labels:
  22. logging-infra: "{{daemonset_component}}"
  23. provider: openshift
  24. component: "{{daemonset_component}}"
  25. spec:
  26. serviceAccountName: "{{daemonset_serviceAccount}}"
  27. nodeSelector:
  28. {{fluentd_nodeselector_key}}: "{{fluentd_nodeselector_value}}"
  29. containers:
  30. - name: "{{daemonset_container_name}}"
  31. image: "{{openshift_logging_image_prefix}}{{daemonset_name}}:{{openshift_logging_image_version}}"
  32. imagePullPolicy: Always
  33. securityContext:
  34. privileged: true
  35. resources:
  36. limits:
  37. cpu: {{openshift_logging_fluentd_cpu_limit}}
  38. memory: {{openshift_logging_fluentd_memory_limit}}
  39. volumeMounts:
  40. - name: runlogjournal
  41. mountPath: /run/log/journal
  42. - name: varlog
  43. mountPath: /var/log
  44. - name: varlibdockercontainers
  45. mountPath: /var/lib/docker/containers
  46. readOnly: true
  47. - name: config
  48. mountPath: /etc/fluent/configs.d/user
  49. readOnly: true
  50. - name: certs
  51. mountPath: /etc/fluent/keys
  52. readOnly: true
  53. - name: dockerhostname
  54. mountPath: /etc/docker-hostname
  55. readOnly: true
  56. - name: localtime
  57. mountPath: /etc/localtime
  58. readOnly: true
  59. - name: dockercfg
  60. mountPath: /etc/sysconfig/docker
  61. readOnly: true
  62. - name: dockerdaemoncfg
  63. mountPath: /etc/docker
  64. readOnly: true
  65. {% if openshift_logging_use_mux_client | bool %}
  66. - name: muxcerts
  67. mountPath: /etc/fluent/muxkeys
  68. readOnly: true
  69. {% endif %}
  70. env:
  71. - name: "K8S_HOST_URL"
  72. value: "{{openshift_logging_master_url}}"
  73. - name: "ES_HOST"
  74. value: "{{openshift_logging_es_host}}"
  75. - name: "ES_PORT"
  76. value: "{{openshift_logging_es_port}}"
  77. - name: "ES_CLIENT_CERT"
  78. value: "{{openshift_logging_es_client_cert}}"
  79. - name: "ES_CLIENT_KEY"
  80. value: "{{openshift_logging_es_client_key}}"
  81. - name: "ES_CA"
  82. value: "{{openshift_logging_es_ca}}"
  83. - name: "OPS_HOST"
  84. value: "{{ops_host}}"
  85. - name: "OPS_PORT"
  86. value: "{{ops_port}}"
  87. - name: "OPS_CLIENT_CERT"
  88. value: "{{openshift_logging_es_ops_client_cert}}"
  89. - name: "OPS_CLIENT_KEY"
  90. value: "{{openshift_logging_es_ops_client_key}}"
  91. - name: "OPS_CA"
  92. value: "{{openshift_logging_es_ops_ca}}"
  93. - name: "ES_COPY"
  94. value: "{{openshift_logging_fluentd_es_copy|lower}}"
  95. - name: "ES_COPY_HOST"
  96. value: "{{es_copy_host | default('')}}"
  97. - name: "ES_COPY_PORT"
  98. value: "{{es_copy_port | default('')}}"
  99. - name: "ES_COPY_SCHEME"
  100. value: "{{es_copy_scheme | default('https')}}"
  101. - name: "ES_COPY_CLIENT_CERT"
  102. value: "{{es_copy_client_cert | default('')}}"
  103. - name: "ES_COPY_CLIENT_KEY"
  104. value: "{{es_copy_client_key | default('')}}"
  105. - name: "ES_COPY_CA"
  106. value: "{{es_copy_ca | default('')}}"
  107. - name: "ES_COPY_USERNAME"
  108. value: "{{es_copy_username | default('')}}"
  109. - name: "ES_COPY_PASSWORD"
  110. value: "{{es_copy_password | default('')}}"
  111. - name: "OPS_COPY_HOST"
  112. value: "{{ops_copy_host | default('')}}"
  113. - name: "OPS_COPY_PORT"
  114. value: "{{ops_copy_port | default('')}}"
  115. - name: "OPS_COPY_SCHEME"
  116. value: "{{ops_copy_scheme | default('https')}}"
  117. - name: "OPS_COPY_CLIENT_CERT"
  118. value: "{{ops_copy_client_cert | default('')}}"
  119. - name: "OPS_COPY_CLIENT_KEY"
  120. value: "{{ops_copy_client_key | default('')}}"
  121. - name: "OPS_COPY_CA"
  122. value: "{{ops_copy_ca | default('')}}"
  123. - name: "OPS_COPY_USERNAME"
  124. value: "{{ops_copy_username | default('')}}"
  125. - name: "OPS_COPY_PASSWORD"
  126. value: "{{ops_copy_password | default('')}}"
  127. - name: "USE_JOURNAL"
  128. value: "{{openshift_logging_fluentd_use_journal|lower}}"
  129. - name: "JOURNAL_SOURCE"
  130. value: "{{openshift_logging_fluentd_journal_source | default('')}}"
  131. - name: "JOURNAL_READ_FROM_HEAD"
  132. value: "{{openshift_logging_fluentd_journal_read_from_head|lower}}"
  133. - name: "USE_MUX_CLIENT"
  134. value: "{{openshift_logging_use_mux_client| default('false')}}"
  135. volumes:
  136. - name: runlogjournal
  137. hostPath:
  138. path: /run/log/journal
  139. - name: varlog
  140. hostPath:
  141. path: /var/log
  142. - name: varlibdockercontainers
  143. hostPath:
  144. path: /var/lib/docker/containers
  145. - name: config
  146. configMap:
  147. name: logging-fluentd
  148. - name: certs
  149. secret:
  150. secretName: logging-fluentd
  151. - name: dockerhostname
  152. hostPath:
  153. path: /etc/hostname
  154. - name: localtime
  155. hostPath:
  156. path: /etc/localtime
  157. - name: dockercfg
  158. hostPath:
  159. path: /etc/sysconfig/docker
  160. - name: dockerdaemoncfg
  161. hostPath:
  162. path: /etc/docker
  163. {% if openshift_logging_use_mux_client | bool %}
  164. - name: muxcerts
  165. secret:
  166. secretName: logging-mux
  167. {% endif %}