diff --git a/docs-new/blog/posts/analyzing-application-performance.md b/docs-new/blog/posts/analyzing-application-performance.md index 23c3fa30d34..da9e44be835 100644 --- a/docs-new/blog/posts/analyzing-application-performance.md +++ b/docs-new/blog/posts/analyzing-application-performance.md @@ -46,7 +46,9 @@ Everything in Keptn is configured via Kubernetes Custom Resources. We notify Keptn about our monitoring data sources by adding two KeptnMetricsProvider resources to our Kubernetes cluster - one for our Prometheus instance, the other one for our Dynatrace tenant. +```yaml {% include "./analyzing-application-performance/metric-providers.yaml" %} +``` ## Defining SLIs @@ -71,11 +73,15 @@ that has been executed after the deployment of a new version. In our case, we will create two `AnalysisValueTemplates` resources. The first one measures the error rate of our workload, using data from Prometheus: +```yaml {% include "./analyzing-application-performance/error-rate.yaml" %} +``` As a second metric, we measure the memory usage of our application using the following `AnalysisValueTemplate`: +```yaml {% include "./analyzing-application-performance/memory-usage.yaml" %} +``` As can be seen in the `spec.query` field of the resource above, `AnalysisValueTemplate` resources support the [Go templating syntax](https://pkg.go.dev/text/template). @@ -93,7 +99,9 @@ The next step is to set up our expectations towards our SLOs, i.e. the goals we would like them to meet. This is done via an `AnalysisDefinition` resource like the following: +```yaml {% include "./analyzing-application-performance/analysis-definition.yaml" %} +``` This `AnalysisDefinition` resource has two objectives, which both refer to the `AnalysisValueTemplate` resources we created previously. @@ -115,7 +123,9 @@ and the metrics-operator determines where to retrieve the data based on the info Now, it is time to trigger an Analysis. This is done by applying an Analysis resource which looks as follows: +```yaml {% include "./analyzing-application-performance/analysis.yaml" %} +``` Applying this resource causes Keptn to: @@ -174,7 +184,9 @@ kubectl get analysis service-analysis -n simple-go –oyaml This command gives us the complete YAML representation of the `Analysis`: +```yaml {% include "./analyzing-application-performance/analysis-status.yaml" %} +``` As you can see, this already gives us a lot more information, with the meatiest piece being the status.raw field. @@ -187,7 +199,9 @@ kubectl get analyses service-analysis -n simple-go -o=jsonpath='{.status.raw}' | Giving us the following as a result: +```json {% include "./analyzing-application-performance/analysis-breakdown.json" %} +``` In the JSON object, we see: