From 69db7b9e2efd4669e7d1e60937b059d2df8c4243 Mon Sep 17 00:00:00 2001 From: Tom Kerkhove Date: Mon, 28 Sep 2020 10:23:15 +0200 Subject: [PATCH] Provide boilerplate for Resource Discovery Helm chart (#1294) --- build/azure-devops/agents-ci-discovery.yml | 13 +- build/azure-devops/agents-ci-scraper.yml | 49 ++----- .../templates/helm/lint-chart.yml | 2 +- .../templates/helm/package-preview-chart.yml | 4 +- .../stages/helm-chart-verification.yml | 48 +++++++ build/helm/Transform-Chart.ps1 | 24 ++-- .../.helmignore | 21 +++ .../Chart.yaml | 13 ++ .../promitor-agent-resource-discovery/LICENSE | 21 +++ .../README.md | 136 ++++++++++++++++++ .../templates/NOTES.txt | 18 +++ .../templates/_helpers.tpl | 54 +++++++ .../templates/configmap.yaml | 73 ++++++++++ .../templates/deployment.yaml | 79 ++++++++++ .../templates/podsecuritypolicy.yaml | 39 +++++ .../templates/role.yaml | 20 +++ .../templates/rolebinding.yaml | 18 +++ .../templates/secret.yaml | 18 +++ .../templates/service.yaml | 31 ++++ .../templates/serviceaccount.yaml | 14 ++ .../values.yaml | 117 +++++++++++++++ 21 files changed, 758 insertions(+), 54 deletions(-) create mode 100644 build/azure-devops/templates/stages/helm-chart-verification.yml create mode 100644 charts/promitor-agent-resource-discovery/.helmignore create mode 100644 charts/promitor-agent-resource-discovery/Chart.yaml create mode 100644 charts/promitor-agent-resource-discovery/LICENSE create mode 100644 charts/promitor-agent-resource-discovery/README.md create mode 100644 charts/promitor-agent-resource-discovery/templates/NOTES.txt create mode 100644 charts/promitor-agent-resource-discovery/templates/_helpers.tpl create mode 100644 charts/promitor-agent-resource-discovery/templates/configmap.yaml create mode 100644 charts/promitor-agent-resource-discovery/templates/deployment.yaml create mode 100644 charts/promitor-agent-resource-discovery/templates/podsecuritypolicy.yaml create mode 100644 charts/promitor-agent-resource-discovery/templates/role.yaml create mode 100644 charts/promitor-agent-resource-discovery/templates/rolebinding.yaml create mode 100644 charts/promitor-agent-resource-discovery/templates/secret.yaml create mode 100644 charts/promitor-agent-resource-discovery/templates/service.yaml create mode 100644 charts/promitor-agent-resource-discovery/templates/serviceaccount.yaml create mode 100644 charts/promitor-agent-resource-discovery/values.yaml diff --git a/build/azure-devops/agents-ci-discovery.yml b/build/azure-devops/agents-ci-discovery.yml index a7ea1946e..084752b40 100644 --- a/build/azure-devops/agents-ci-discovery.yml +++ b/build/azure-devops/agents-ci-discovery.yml @@ -21,6 +21,10 @@ variables: value: 'promitor-discovery-agent' - name: App.Version value: '0.0.0-$(Image.Tag)' + - name: Helm.Chart.Version + value: '0.0.0-$(App.Version)' + - name: Helm.Chart.CI.Name + value: 'promitor-agent-resource-discovery' stages: - stage: Init displayName: Prepare Build @@ -209,4 +213,11 @@ stages: - ${{ if eq(variables['Build.Reason'], 'PullRequest') }}: - template: templates/docker/push-image.yml parameters: - imageName: '$(Image.TaggedName)' \ No newline at end of file + imageName: '$(Image.TaggedName)' +- template: templates/stages/helm-chart-verification.yml + parameters: + chartName: '$(Helm.Chart.CI.Name)' + chartVersion: '$(Helm.Chart.Version)' + appVersion: '$(App.Version)' + imageName: '$(Image.Name)' + dependsOn: 'Docker' \ No newline at end of file diff --git a/build/azure-devops/agents-ci-scraper.yml b/build/azure-devops/agents-ci-scraper.yml index 87971d4e5..8dd3b5119 100644 --- a/build/azure-devops/agents-ci-scraper.yml +++ b/build/azure-devops/agents-ci-scraper.yml @@ -23,8 +23,8 @@ variables: value: '0.0.0-$(Image.Tag)' - name: Helm.Chart.Version value: '0.0.0-$(App.Version)' - - name: Helm.Chart.CI.Name - value: 'promitor-agent-scraper-ci' + - name: Helm.Chart.Name + value: 'promitor-agent-scraper' stages: - stage: Init displayName: Prepare Build @@ -286,41 +286,10 @@ stages: parameters: helmVersion: '$(Helm.Version)' chartName: '$(Chart.Scraper.Name)' -- stage: Helm3 - displayName: Helm Chart (3.x) - dependsOn: Docker - variables: - Helm.Version: '3.0.0' - jobs: - - job: Helm3_x - displayName: Helm 3.x - Lint, Package & Push Chart - condition: succeeded() - pool: - vmImage: ubuntu-16.04 - steps: - - download: current - artifact: variables - - template: templates/utils/read-variable-on-linux.yml - parameters: - variableName: 'Image.Tag' - - template: templates/helm/lint-chart.yml - parameters: - helmVersion: '$(Helm.Version)' - chartName: '$(Chart.Scraper.Name)' - - template: templates/helm/package-preview-chart.yml - parameters: - chartName: '$(Helm.Chart.CI.Name)' - chartVersion: '$(Helm.Chart.Version)' - appVersion: '$(App.Version)' - imageName: '$(Image.Name)' - - ${{ if eq(variables['Build.Reason'], 'PullRequest') }}: - - template: templates/helm/push-chart.yml - parameters: - chartName: '$(Helm.Chart.CI.Name)' - chartVersion: '$(Helm.Chart.Version)' - - ${{ if eq(variables['Build.Reason'], 'PullRequest') }}: - - task: PublishBuildArtifacts@1 - displayName: 'Publish Helm Chart' - inputs: - PathtoPublish: charts/output/$(Helm.Chart.CI.Name)-$(Helm.Chart.Version).tgz - ArtifactName: helm +- template: templates/stages/helm-chart-verification.yml + parameters: + chartName: '$(Helm.Chart.Name)' + chartVersion: '$(Helm.Chart.Version)' + appVersion: '$(App.Version)' + imageName: '$(Image.Name)' + dependsOn: 'Docker' \ No newline at end of file diff --git a/build/azure-devops/templates/helm/lint-chart.yml b/build/azure-devops/templates/helm/lint-chart.yml index 16ac325ef..24a7c6499 100644 --- a/build/azure-devops/templates/helm/lint-chart.yml +++ b/build/azure-devops/templates/helm/lint-chart.yml @@ -7,7 +7,7 @@ parameters: steps: - task: HelmInstaller@1 - displayName: 'Install Helm (${{ parameters.helmVersion }}' + displayName: 'Install Helm (${{ parameters.helmVersion }})' inputs: helmVersionToInstall: '${{ parameters.helmVersion }}' - powershell: | diff --git a/build/azure-devops/templates/helm/package-preview-chart.yml b/build/azure-devops/templates/helm/package-preview-chart.yml index d47b180cb..013651470 100644 --- a/build/azure-devops/templates/helm/package-preview-chart.yml +++ b/build/azure-devops/templates/helm/package-preview-chart.yml @@ -4,6 +4,8 @@ parameters: default: '$(Helm.Version)' - name: chartName type: string +- name: transformedChartName + type: string - name: chartVersion type: string - name: appVersion @@ -21,7 +23,7 @@ steps: inputs: targetType: filePath filePath: ./build/helm/Transform-Chart.ps1 - arguments: '-chartName "${{ parameters.chartName }}" -imageName "${{ parameters.imageName }}" -imageTag "${{ parameters.appVersion }}"' + arguments: '-chartName "${{ parameters.chartName }}" -transformedChartName "${{ parameters.transformedChartName }}" -imageName "${{ parameters.imageName }}" -imageTag "${{ parameters.appVersion }}"' workingDirectory: 'charts' - template: package-official-chart.yml parameters: diff --git a/build/azure-devops/templates/stages/helm-chart-verification.yml b/build/azure-devops/templates/stages/helm-chart-verification.yml new file mode 100644 index 000000000..556c244f2 --- /dev/null +++ b/build/azure-devops/templates/stages/helm-chart-verification.yml @@ -0,0 +1,48 @@ +parameters: + chartName: '' + chartVersion: '' + appVersion: '' + imageName: '' + dependsOn: '' + +stages: +- stage: Helm3 + displayName: Helm Chart (3.x) + dependsOn: ${{ parameters.dependsOn }} + variables: + Helm.Version: '3.0.0' + jobs: + - job: Helm3_x + displayName: Helm 3.x - Lint, Package & Push Chart + condition: succeeded() + pool: + vmImage: ubuntu-16.04 + steps: + - download: current + artifact: variables + # TODO: Move this to step to pass as "pre-run step" + - template: ./../../utils/read-variable-on-linux.yml + parameters: + variableName: 'Image.Tag' + - template: ./../../helm/lint-chart.yml + parameters: + helmVersion: '$(Helm.Version)' + chartName: '${{ parameters.chartName }}' + - template: ./../../helm/package-preview-chart.yml + parameters: + chartName: '${{ parameters.chartName }}' + chartVersion: '${{ parameters.chartVersion }}' + appVersion: '${{ parameters.appVersion }}' + imageName: '${{ parameters.imageName }}' + transformedChartName: '${{ parameters.chartName }}-ci' + - ${{ if eq(variables['Build.Reason'], 'PullRequest') }}: + - template: ./../../helm/push-chart.yml + parameters: + chartName: '${{ parameters.chartName }}' + chartVersion: '${{ parameters.chartVersion }}' + - ${{ if eq(variables['Build.Reason'], 'PullRequest') }}: + - task: PublishBuildArtifacts@1 + displayName: 'Publish Helm Chart' + inputs: + PathtoPublish: charts/output/${{ parameters.chartName }}-${{ parameters.chartVersion }}.tgz + ArtifactName: helm diff --git a/build/helm/Transform-Chart.ps1 b/build/helm/Transform-Chart.ps1 index d74b96119..72cd2ea9e 100644 --- a/build/helm/Transform-Chart.ps1 +++ b/build/helm/Transform-Chart.ps1 @@ -2,34 +2,36 @@ Param( [String] [Parameter(Mandatory = $true)] $chartName = $(throw "Chart name is required"), [String] + [Parameter(Mandatory = $true)] $transformedChartName = $(throw "Chart name of the transformed output is required"), + [String] [Parameter(Mandatory = $true)] $imageName = $(throw "Image name is required"), [String] [Parameter(Mandatory = $true)] $imageTag = $(throw "Image tag is required") ) echo "Copying Chart folder" -cp promitor-agent-scraper/ $chartName/ -r +cp $chartName/ $transformedChartName/ -r echo "Determining image version" $imageVersion = "$imageTag".ToLower() echo "Image version is $imageVersion" -echo "Changing name of chart to $chartName" -((Get-Content -path $chartName/Chart.yaml -Raw) -replace 'promitor-agent-scraper', $chartName) | Set-Content -Path $chartName/Chart.yaml +echo "Changing name of chart to $transformedChartName" +((Get-Content -path $transformedChartName/Chart.yaml -Raw) -replace 'promitor-agent-scraper', $transformedChartName) | Set-Content -Path $transformedChartName/Chart.yaml echo "Changing image tag to $imageVersion" -((Get-Content -path $chartName/values.yaml -Raw) -replace 'latest', $imageVersion) | Set-Content -Path $chartName/values.yaml +((Get-Content -path $transformedChartName/values.yaml -Raw) -replace 'latest', $imageVersion) | Set-Content -Path $transformedChartName/values.yaml echo "Changing repo name to $imageName" -((Get-Content -path $chartName/values.yaml -Raw) -replace 'tomkerkhove/promitor-agent-scraper', $imageName) | Set-Content -Path $chartName/values.yaml +((Get-Content -path $transformedChartName/values.yaml -Raw) -replace 'tomkerkhove/promitor-agent-scraper', $imageName) | Set-Content -Path $transformedChartName/values.yaml -echo "Change name of chart in README to $chartName" -((Get-Content -path $chartName/README.md -Raw) -replace 'promitor-agent-scraper', $chartName) | Set-Content -Path $chartName/README.md +echo "Change name of chart in README to $transformedChartName" +((Get-Content -path $transformedChartName/README.md -Raw) -replace 'promitor-agent-scraper', $transformedChartName) | Set-Content -Path $transformedChartName/README.md echo "Change version of image in README to $imageVersion" -((Get-Content -path $chartName/README.md -Raw) -replace 'latest', $imageVersion) | Set-Content -Path $chartName/README.md +((Get-Content -path $transformedChartName/README.md -Raw) -replace 'latest', $imageVersion) | Set-Content -Path $transformedChartName/README.md echo "Outputting transformed content" -Get-Content -path $chartName/Chart.yaml -Raw -Get-Content -path $chartName/values.yaml -Raw -Get-Content -path $chartName/README.md -Raw \ No newline at end of file +Get-Content -path $transformedChartName/Chart.yaml -Raw +Get-Content -path $transformedChartName/values.yaml -Raw +Get-Content -path $transformedChartName/README.md -Raw \ No newline at end of file diff --git a/charts/promitor-agent-resource-discovery/.helmignore b/charts/promitor-agent-resource-discovery/.helmignore new file mode 100644 index 000000000..f0c131944 --- /dev/null +++ b/charts/promitor-agent-resource-discovery/.helmignore @@ -0,0 +1,21 @@ +# Patterns to ignore when building packages. +# This supports shell glob matching, relative path matching, and +# negation (prefixed with !). Only one pattern per line. +.DS_Store +# Common VCS dirs +.git/ +.gitignore +.bzr/ +.bzrignore +.hg/ +.hgignore +.svn/ +# Common backup files +*.swp +*.bak +*.tmp +*~ +# Various IDEs +.project +.idea/ +*.tmproj diff --git a/charts/promitor-agent-resource-discovery/Chart.yaml b/charts/promitor-agent-resource-discovery/Chart.yaml new file mode 100644 index 000000000..f9c2b77cd --- /dev/null +++ b/charts/promitor-agent-resource-discovery/Chart.yaml @@ -0,0 +1,13 @@ +apiVersion: v2 +version: 0.2.0 +appVersion: 1.0.0 +type: application +name: promitor-agent-resource-discovery +description: Promitor, bringing Azure Monitor metrics where you need them. +home: https://promitor.io +sources: + - https://github.com/tomkerkhove/promitor +maintainers: + - name: Tom Kerkhove + url: https://github.com/tomkerkhove +icon: https://raw.githubusercontent.com/tomkerkhove/promitor/master/docs/media/logos/promitor.png \ No newline at end of file diff --git a/charts/promitor-agent-resource-discovery/LICENSE b/charts/promitor-agent-resource-discovery/LICENSE new file mode 100644 index 000000000..782e6b8ab --- /dev/null +++ b/charts/promitor-agent-resource-discovery/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2018 Tom Kerkhove + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/charts/promitor-agent-resource-discovery/README.md b/charts/promitor-agent-resource-discovery/README.md new file mode 100644 index 000000000..415c5bb2e --- /dev/null +++ b/charts/promitor-agent-resource-discovery/README.md @@ -0,0 +1,136 @@ +# Promitor + +[Promitor](https://promitor.io/) is an Azure Monitor scraper which makes + the metrics available for metric systems such as Atlassian Statuspage, + Prometheus and StatsD. + +## TL;DR + +```console +helm repo add promitor https://promitor.azurecr.io/helm/v1/repo +helm repo update +helm install promitor-agent-resource-discovery promitor/promitor-agent-resource-discovery +``` + +## Introduction + +This chart bootstraps a **Promitor Scraper Agent** deployment on a Kubernetes cluster +using the Helm package manager. It will provide the scraper agent with a Kubernetes +Service so that other Pods can consume it. + +## Prerequisites + +- Kubernetes v1.9 or above +- Azure Subscription +- Azure AD Application to authenticate with ([docs](https://promitor.io/configuration/#authentication-with-azure-monitor)) + +## Installing the Chart + +To install the chart with the release name `promitor-agent-resource-discovery`: + +```console +$ helm install promitor-agent-resource-discovery promitor/promitor-agent-resource-discovery \ + --set azureAuthentication.appId='' \ + --set azureAuthentication.appKey='' \ + --values /path/to/metric-declaration.yaml +``` + +The command deploys Prometheus on the Kubernetes cluster with the specified metrics +declaration, for more information see [our documentation](https://promitor.io/deployment/#using-our-helm-chart). + +## Uninstalling the Chart + +To uninstall/delete the `promitor-agent-resource-discovery` deployment: + +```console +helm uninstall promitor-agent-resource-discovery +``` + +The command removes all the Kubernetes components associated with the chart and +deletes the release. + +## Configuration + +The following table lists the configurable parameters of the Promitor chart and +their default values. + +| Parameter | Description | Default | +|:---------------------------|:-------------------------|:---------------------| +| `image.repository` | Repository which provides the image | `tomkerkhove/promitor-agent-resource-discovery` | +| `image.tag` | Tag of image to use | None, chart app version is used by default | +| `image.pullPolicy` | Policy to pull image | `Always` | +| `azureAuthentication.appId` | Id of the Azure AD entity to authenticate with | | +| `azureAuthentication.appKey` | Secret of the Azure AD entity to authenticate with | | +| `resourceDiscovery.enabled` | Indication whether or not resource discovery is required | `false` | +| `resourceDiscovery.host` | DNS name or IP address of the Promitor Resource Discovery agent | | +| `resourceDiscovery.port` | Port (UDP) address of the Promitor Resource Discovery agent | `80` | +| `metricSinks.atlassianStatuspage.enabled` | Indication whether or not metrics should be emitted to a StatsD server | `false`| +| `metricSinks.atlassianStatuspage.pageId` | Id of Atlassian Statuspage page | | +| `metricSinks.atlassianStatuspage.apiKey` | API key of Atlassian Statuspage page | | +| `metricSinks.atlassianStatuspage.systemMetricMapping` | Mapping of the Atlassian Statuspage system metrics and Promitor metrics. Learn how to configure it [below](#atlassian-statuspage).| None | +| `metricSinks.prometheusScrapingEndpoint.enabled` | Indication whether or not metrics should be exposed as a Prometheus scraping endpoint | `true`| +| `metricSinks.prometheusScrapingEndpoint.baseUriPath` | Path where the scraping endpoint for Prometheus is being exposed | `/metrics` | +| `metricSinks.prometheusScrapingEndpoint.enableMetricTimestamps` | Indication whether or not to include timestamp | `true` | +| `metricSinks.prometheusScrapingEndpoint.metricUnavailableValue` | Value to report in Prometheus when no metric was found whether or not to include timestamp | `NaN` | +| `metricSinks.prometheusScrapingEndpoint.enableServiceDiscovery` | Indication whether or not service discovery with annotations should be enabled ([docs](https://github.com/helm/charts/tree/master/stable/prometheus#scraping-pod-metrics-via-annotations)) | `true` | +| `metricSinks.statsd.enabled` | Indication whether or not metrics should be emitted to a StatsD server | `false`| +| `metricSinks.statsd.host` | DNS name or IP address of StatsD server | | +| `metricSinks.statsd.port` | Port (UDP) address of StatsD server | `8125` | +| `metricSinks.statsd.metricPrefix` | Prefix that will be added to every metric defined in the metric declaration | | +| `telemetry.applicationInsights.enabled` | Indication whether or not to send telemetry to Azure Application Insights | `false` | +| `telemetry.applicationInsights.logLevel` | Minimum level of logging for Azure Application Insights | | +| `telemetry.applicationInsights.key` | Application Insights instrumentation key | | +| `telemetry.containerLogs.enabled` | Indication whether or not to send telemetry to container logs | `true` | +| `telemetry.containerLogs.logLevel` | Minimum level of logging for container logs | | +| `telemetry.defaultLogLevel` | Minimum level of logging for all telemetry sinks, unless specified otherwise | `Error` | +| `azureMetadata.tenantId` | Id of Azure tenant | | +| `azureMetadata.subscriptionId` | Id of Azure subscription | | +| `azureMetadata.resourceGroupName` | Name of resource group | `promitor` | +| `metricDefaults.aggregation.interval` | Default interval which defines over what period measurements of a metric should be aggregated | `00:05:00` | +| `metricDefaults.scraping.schedule` | Cron expression that controls the fequency in which all the configured metrics will be scraped from Azure Monitor | `*/5 * * * *` | +| `metrics` | List of metrics to scrape configured following the [metric declaration docs](https://promitor.io/configuration/metrics/) | | +| `rbac.create` | If true, create & use RBAC resources | `true` | +| `rbac.podSecurityPolicyEnabled` | Create pod security policy resources | `false` | +| `rbac.serviceAccount.create` | Create service account resource | `true` | +| `rbac.serviceAccount.name` | Service account name to use if create is false. If create is true, a name is generated using the fullname template | `default` | +| `rbac.serviceAccount.annotations` | Service account annotations| `{}` | +| `resources` | Pod resource requests & limits | `{}` | +| `secrets.createSecret` | Indication if you want to bring your own secret level of logging | `true` | +| `secrets.appIdSecret` | Name of the secret for Azure AD identity id | `azure-app-id` | +| `secrets.appKeySecret` | Name of the secret for Azure AD identity secret | `azure-app-key` | +| `service.exposeExternally` | Indication whether or not to expose service externally | `false` | +| `service.port` | Port on service for other pods to talk to | `8888` | +| `service.targetPort` | Port on container to serve traffic | `88` | +| `service.labelType` | Label to assign to your service | `infrastructure` | +| `service.selectorType` | Selector type to use for the service | `runtime` | + +Specify each parameter using the `--set key=value[,key=value]` argument to +`helm install`. For example: + +```console +$ helm install promitor-agent-resource-discovery promitor/promitor-agent-resource-discovery \ + --set azureAuthentication.appId='' \ + --set azureAuthentication.appKey='' \ + --set azureMetadata.tenantId='' \ + --set azureMetadata.subscriptionId='' \ + --values C:\Promitor\metric-declaration.yaml +``` + +Alternatively, a YAML file that specifies the values for the above parameters can +be provided while installing the chart. For example, + +```console +helm install promitor-agent-resource-discovery promitor/promitor-agent-resource-discovery -f values.yaml +``` + +### Atlassian Statuspage + +You can easily provide system metric mapping between Atlassian Statuspage system metrics and Promitor metrics. + +```yaml +systemMetricMapping: [] +- id: + promitorMetricName: +``` + +This defines which Promitor metric should be reported as a given Atlassian Statuspage system metrics. diff --git a/charts/promitor-agent-resource-discovery/templates/NOTES.txt b/charts/promitor-agent-resource-discovery/templates/NOTES.txt new file mode 100644 index 000000000..3c039f3d6 --- /dev/null +++ b/charts/promitor-agent-resource-discovery/templates/NOTES.txt @@ -0,0 +1,18 @@ +1. Forward the application port by running these commands: + +export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app={{ include "promitor-agent-resource-discovery.name" . }},release={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}") +kubectl port-forward --namespace {{ .Release.Namespace }} $POD_NAME 8080:{{ .Values.service.targetPort }} + +2. Check the scraping output at http://0.0.0.0:8080{{ .Values.metricSinks.prometheusScrapingEndpoint.baseUriPath }} + +3. To set up Prometheus in your cluster & pull in metrics from Promitor's scraping output, run: + +cat > promitor-scrape-config.yaml < + # promitorMetricName: + prometheusScrapingEndpoint: + enabled: true + baseUriPath: /metrics + enableMetricTimestamps: true + metricUnavailableValue: NaN + enableServiceDiscovery: true + statsd: + enabled: false + host: "" + port: 8125 + metricPrefix: "" +resourceDiscovery: + enabled: false + host: "" + port: 80 +telemetry: + defaultLogLevel: "Error" + applicationInsights: + enabled: false + key: "" + logLevel: "" + containerLogs: + enabled: true + logLevel: "" + +## Metric Declaration YAML +azureMetadata: + tenantId: "" + subscriptionId: "" + resourceGroupName: promitor +metricDefaults: + aggregation: + interval: 00:05:00 + scraping: + schedule: "*/5 * * * *" +metrics: [] +# Sample metric configuration below +# - name: demo_queue_size +# description: "Amount of active messages of the 'myqueue' queue (determined with ServiceBusQueue provider)" +# resourceType: ServiceBusQueue +# azureMetricConfiguration: +# metricName: ActiveMessages +# aggregation: +# type: Total +# interval: 00:15:00 +# resources: +# - namespace: promitor-messaging +# queueName: orders + +secrets: + # To use your own secret, set createSecret to false and define the name/keys that your secret uses + createSecret: true + secretName: "" + appIdSecret: azure-app-id + appKeySecret: azure-app-key + appInsightsSecret: azure-appinsights-key + atlassianStatuspageApiKey: atlassian-statuspage-apikey + +service: + exposeExternally: False + port: 8888 + targetPort: 88 + labelType: infrastructure + selectorType: runtime + +resources: {} + # limits: + # cpu: 100m + # memory: 128Mi + # requests: + # cpu: 100m + # memory: 128Mi + +## Role-based access control +## https://kubernetes.io/docs/reference/access-authn-authz/rbac/ +rbac: + ## If true, create & use RBAC resources + create: true + + ## If true, create & use Pod Security Policy resources + ## ref: https://kubernetes.io/docs/concepts/policy/pod-security-policy/ + podSecurityPolicyEnabled: false + + ## Service Account for pods + ## ref: https://kubernetes.io/docs/tasks/configure-pod-container/configure-service-account/ + serviceAccount: + ## Specifies whether a service account should be created + create: true + + ## The name of the service account to use if create is false + ## If create is true, a name is generated using the fullname template + name: default + annotations: {}