From 9d2fed5d70eb85bff8b676718a0357a4cb7d9703 Mon Sep 17 00:00:00 2001 From: Aron Kaufmann <100943793+AronKa-SAG@users.noreply.github.com> Date: Fri, 14 Jun 2024 08:26:44 +0200 Subject: [PATCH] Add Kibana extraContainers (#89) * add kibana extraContainers * added if surrounding the toYaml * added servicemonitor only including 1 service * * added servicemonitor only including 1 service * addded service-name labels to default services * comment CRD ServiceMonitor values * * upped chart version * updated readme * fix type --------- Co-authored-by: thr --- apigateway/helm/Chart.yaml | 2 +- apigateway/helm/README.md | 9 ++++++--- apigateway/helm/README.md.gotmpl | 1 + apigateway/helm/templates/_helper.tpl | 7 +++++++ apigateway/helm/templates/kibana.yaml | 5 ++++- apigateway/helm/templates/service.yaml | 3 +++ apigateway/helm/templates/servicemonitor.yaml | 1 + apigateway/helm/values.yaml | 11 ++++++++--- 8 files changed, 31 insertions(+), 8 deletions(-) diff --git a/apigateway/helm/Chart.yaml b/apigateway/helm/Chart.yaml index c25b8ab..fdbfccc 100644 --- a/apigateway/helm/Chart.yaml +++ b/apigateway/helm/Chart.yaml @@ -33,7 +33,7 @@ type: application # This is the chart version. This version number should be incremented each time you make changes # to the chart and its templates, including the app version. # Versions are expected to follow Semantic Versioning (https://semver.org/) -version: 1.2.3 +version: 1.2.4 # This is the version number of the application being deployed. This version number should be # incremented each time you make changes to the application. Versions are not expected to diff --git a/apigateway/helm/README.md b/apigateway/helm/README.md index a5bc314..1b72d46 100644 --- a/apigateway/helm/README.md +++ b/apigateway/helm/README.md @@ -164,6 +164,7 @@ Sub-folder `examples` contains some *values* examples for more use-cases. To use | `1.2.1` | Added Kibana configuration field 'status.allowAnonymous' set by Values.kibana.allowAnonymousStatus. This removes errors in API Gateway log indicating that Kibana is not available. | | `1.2.2` | Option in `values.yaml` to create a ServiceMonitor added. | | `1.2.3` | Job template added to create house keeping (cron) jobs. | +| `1.2.4` | Added Kibana extra container configuration, set by Values.kibana.extraContainers.
Added ServiceMonitor matchLabel for a specific service. The service is set by .Values.serviceMonitor.serviceName defaulting to API Gateways runtime service. | ## Values @@ -313,6 +314,7 @@ Sub-folder `examples` contains some *values* examples for more use-cases. To use | kibana.allowAnonymousStatus | bool | `true` | Enable anonymous access to /api/status. | | kibana.annotations | object | `{}` | Annotations for Kibana | | kibana.count | int | `1` | | +| kibana.extraContainers | list | `[]` | The definition of extra containers for kibana. | | kibana.extraInitContainers | list | `[]` | The definition of extra initContainers for kibana. | | kibana.extraLabels | object | `{}` | Additional labels to be added to kibana pod labels. | | kibana.image | string | `nil` | The image that should be used. By default ECK will use the official Elasticsearch images. Overwrite this to use an image from an internal registry or any custom images. Make sure that the image corresponds to the version field. | @@ -343,10 +345,10 @@ Sub-folder `examples` contains some *values* examples for more use-cases. To use | metering.logLevel | string | `nil` | The level of log messages that are logged on the console. Valid values are: *error - logs only ERROR messages. *warn (default) - logs ERROR and WARN messages. *info - logs ERROR, WARN, and INFO messages. *debug - logs ERROR, WARN, INFO, and DEBUG messages. Use as a Java system property or an environment variable to see the debug messages of the configuration initialization. | | metering.proxyAddress | string | `nil` | The proxy address in a : format that the metering client uses. Configure this property only if you use a metering proxy. | | metering.proxyPass | string | `nil` | The proxy password that the metering client uses. Configure this property only if you use a metering proxy with authentication. Depending on the method that you use to provide a password, ensure that you escape password characters that are specific for the selected method. Valid characters: *Letters: A-Z, a-z *Numbers: 0-9 *Special characters: !@#$%^&*()_+-=[]{}\/?,.<>; | -| metering.proxyType | string | `"DIRECT"` | Тhe type of the proxy that the metering client uses. Valid values are: *DIRECT (default). *HTTP *SOCKS Indicates that the metering client does not use a proxy. | +| metering.proxyType | string | `"DIRECT"` | The type of the proxy that the metering client uses. Valid values are: *DIRECT (default). *HTTP *SOCKS Indicates that the metering client does not use a proxy. | | metering.reportPeriod | string | `"3600"` | | | metering.runtimeAlias | string | `nil` | An alias of the webMethods product instance or a group of instances, for which usage data is measured. | -| metering.serverConnectTimeout | string | `"60000"` | Тhe time in milliseconds to establish the initial TCP connection when the metering client calls the server REST endpoint. This is also the time to start the request. | +| metering.serverConnectTimeout | string | `"60000"` | The time in milliseconds to establish the initial TCP connection when the metering client calls the server REST endpoint. This is also the time to start the request. | | metering.serverReadTimeout | string | `"300000"` | The maximum time in milliseconds without data transfer over the TCP connection to the server. This is also the time that it takes for the server to respond. When this time passes, the request fails. | | metering.serverUrl | string | `"https://metering.softwareag.cloud/api/measurements"` | The URL of the metering aggregator server REST API. | | metering.trustStoreFile | string | `nil` | The absolute path to the metering client truststore that is used for HTTPS connections. Add this value in any of the following cases: *If you use the Software AG Metering Server on premises (via HTTPS) and the certificates in the truststore do not match the certificates configured in Software AG Runtime (CTP). *If you use a metering proxy that terminates the SSL connection to the Metering Server in Software AG Cloud. | @@ -377,5 +379,6 @@ Sub-folder `examples` contains some *values* examples for more use-cases. To use | serviceAccount.create | bool | `true` | - apiVersion: rbac.authorization.k8s.io/v1 kind: Role metadata: name: {{ include "common.names.roleName" . }} rules: - apiGroups: - "" resources: - pods - endpoints verbs: - get - list - watch | | serviceAccount.name | string | `""` | The name of the service account to use. If not set and create is true, a name is generated using the fullname template | | serviceAccount.roleName | string | `""` | | -| serviceMonitor | object | `{"enabled":false}` | Create and enable ServiceMonitor. The default is `false`. | +| serviceMonitor.enabled | bool | `false` | Create and enable CRD ServiceMonitor. The default is `false`. | +| serviceMonitor.serviceName | string | `""` | Set the monitored service which is connected by ServiceMonitor. Default (if not set) is the `rt` runtime service. | | tolerations | list | `[]` | | diff --git a/apigateway/helm/README.md.gotmpl b/apigateway/helm/README.md.gotmpl index 87be0fd..553117c 100644 --- a/apigateway/helm/README.md.gotmpl +++ b/apigateway/helm/README.md.gotmpl @@ -165,5 +165,6 @@ Sub-folder `examples` contains some *values* examples for more use-cases. To use | `1.2.1` | Added Kibana configuration field 'status.allowAnonymous' set by Values.kibana.allowAnonymousStatus. This removes errors in API Gateway log indicating that Kibana is not available. | | `1.2.2` | Option in `values.yaml` to create a ServiceMonitor added. | | `1.2.3` | Job template added to create house keeping (cron) jobs. | +| `1.2.4` | Added Kibana extra container configuration, set by Values.kibana.extraContainers.
Added ServiceMonitor matchLabel for a specific service. The service is set by .Values.serviceMonitor.serviceName defaulting to API Gateways runtime service. | {{ template "chart.valuesSection" . }} diff --git a/apigateway/helm/templates/_helper.tpl b/apigateway/helm/templates/_helper.tpl index 9ab8056..bf26715 100644 --- a/apigateway/helm/templates/_helper.tpl +++ b/apigateway/helm/templates/_helper.tpl @@ -119,4 +119,11 @@ Renders the license config name or secret. If not specified, it will be the defa */}} {{- define "apigateway.licenseconfigname" -}} {{- default ( printf "%s-%s" (include "common.names.fullname" . ) "license") .Values.licenseConfigName }} +{{- end }} + +{{/* +Renders the service name for service monitoring. If not specified, it will be the default name. +*/}} +{{- define "apigateway.monitorServiceName" -}} + {{- default ( printf "%s-%s" (include "common.names.fullname" . ) "-rt") .Values.serviceMonitor.serviceName }} {{- end }} \ No newline at end of file diff --git a/apigateway/helm/templates/kibana.yaml b/apigateway/helm/templates/kibana.yaml index 5994cbe..9e6eabb 100644 --- a/apigateway/helm/templates/kibana.yaml +++ b/apigateway/helm/templates/kibana.yaml @@ -130,4 +130,7 @@ spec: mountPath: /usr/share/kibana/config/elasticsearch-certs/truststore.p12 subPath: truststore.p12 readOnly: true - {{- end }} \ No newline at end of file + {{- end }} + {{- if .Values.kibana.extraContainers }} + {{- toYaml .Values.kibana.extraContainers | nindent 8 }} + {{- end }} \ No newline at end of file diff --git a/apigateway/helm/templates/service.yaml b/apigateway/helm/templates/service.yaml index 7dd1235..ab8184e 100644 --- a/apigateway/helm/templates/service.yaml +++ b/apigateway/helm/templates/service.yaml @@ -26,6 +26,7 @@ metadata: {{- with .Values.extraLabels -}} {{ toYaml . | nindent 4 }} {{- end }} + service-name: {{ include "common.names.fullname" . }}-rt spec: type: {{ .Values.service.type }} ports: @@ -48,6 +49,7 @@ metadata: {{- with .Values.extraLabels -}} {{ toYaml . | nindent 4 }} {{- end }} + service-name: {{ include "common.names.fullname" . }}-admin spec: type: {{ .Values.service.type }} ports: @@ -70,6 +72,7 @@ metadata: {{- with .Values.extraLabels -}} {{ toYaml . | nindent 4 }} {{- end }} + service-name: {{ include "common.names.fullname" . }}-ui spec: type: {{ .Values.service.type }} sessionAffinity: ClientIP diff --git a/apigateway/helm/templates/servicemonitor.yaml b/apigateway/helm/templates/servicemonitor.yaml index 04ac32f..8b5192f 100644 --- a/apigateway/helm/templates/servicemonitor.yaml +++ b/apigateway/helm/templates/servicemonitor.yaml @@ -42,4 +42,5 @@ spec: selector: matchLabels: app.kubernetes.io/instance: {{ .Release.Name }} + service-name: {{ include "apigateway.monitorServiceName" . }} {{- end }} \ No newline at end of file diff --git a/apigateway/helm/values.yaml b/apigateway/helm/values.yaml index a6af954..2c3e7da 100644 --- a/apigateway/helm/values.yaml +++ b/apigateway/helm/values.yaml @@ -439,9 +439,11 @@ prometheus: ## -- Only used on ServiceMonitor scrapeTimeout: 10s -# -- Create and enable ServiceMonitor. The default is `false`. serviceMonitor: + # -- Create and enable CRD ServiceMonitor. The default is `false`. enabled: false + # -- Set the monitored service which is connected by ServiceMonitor. Default (if not set) is the `rt` runtime service. + serviceName: "" metering: @@ -449,7 +451,7 @@ metering: enabled: true # -- The URL of the metering aggregator server REST API. serverUrl: "https://metering.softwareag.cloud/api/measurements" - # -- Тhe type of the proxy that the metering client uses. + # -- The type of the proxy that the metering client uses. # Valid values are: # *DIRECT (default). # *HTTP @@ -467,7 +469,7 @@ metering: # *Numbers: 0-9 # *Special characters: !@#$%^&*()_+-=[]{}\/?,.<>; proxyPass: - # -- Тhe time in milliseconds to establish the initial TCP connection when the metering client calls the server REST endpoint. This is also the time to start the request. + # -- The time in milliseconds to establish the initial TCP connection when the metering client calls the server REST endpoint. This is also the time to start the request. serverConnectTimeout: "60000" # -- The maximum time in milliseconds without data transfer over the TCP connection to the server. This is also the time that it takes for the server to respond. When this time passes, the request fails. serverReadTimeout: "300000" @@ -633,6 +635,9 @@ kibana: # -- The securityContext for kibana container. securityContext: {} + # -- The definition of extra containers for kibana. + extraContainers: [] + # -- The definition of extra initContainers for kibana. extraInitContainers: []