Compare commits
19 Commits
| Author | SHA1 | Date |
|---|---|---|
|
|
39ef816ea8 | |
|
|
919fe580be | |
|
|
7eb7f3978b | |
|
|
54caa0648e | |
|
|
5ad293a3a8 | |
|
|
6c3f2f628b | |
|
|
49dbd40ee0 | |
|
|
e0c11c3a57 | |
|
|
e390050c3d | |
|
|
04f0d553b7 | |
|
|
97e085afdc | |
|
|
e4d4a40b05 | |
|
|
c47dc52202 | |
|
|
90a0d09b96 | |
|
|
7563c3f4e2 | |
|
|
a9a9b0eb9e | |
|
|
62e947bf60 | |
|
|
0c2c6bff8a | |
|
|
b16ffa4daa |
Binary file not shown.
|
|
@ -0,0 +1,66 @@
|
|||
apiVersion: v2
|
||||
actions:
|
||||
- name: "Deploy using helm"
|
||||
events:
|
||||
- name: "sh.keptn.event.deployment.triggered"
|
||||
tasks:
|
||||
- name: "Run helm"
|
||||
files:
|
||||
- /charts
|
||||
env:
|
||||
- name: IMAGE
|
||||
value: "$.data.configurationChange.values.image"
|
||||
valueFrom: event
|
||||
image: "alpine/helm:3.7.2"
|
||||
serviceAccount: "jes-deploy-using-helm"
|
||||
cmd: ["helm"]
|
||||
args: ["upgrade", "--force", "--create-namespace", "--install", "-n", "$(KEPTN_PROJECT)-$(KEPTN_STAGE)", "$(KEPTN_SERVICE)", "/keptn/charts/$(KEPTN_SERVICE).tgz", "--set", "image=$(IMAGE)", "--set", "keptn.service=$(KEPTN_SERVICE)", "--set", "keptn.deployment=$(KEPTN_STAGE)", "--set", "keptn.project=$(KEPTN_PROJECT)","--set", "keptn.stage=$(KEPTN_STAGE)", "--wait"]
|
||||
- name: "Uninstall"
|
||||
events:
|
||||
- name: "sh.keptn.event.uninstall.triggered"
|
||||
tasks:
|
||||
- name: "Run helm uninstall"
|
||||
serviceAccount: "jes-deploy-using-helm"
|
||||
image: "alpine/helm:3.7.2"
|
||||
cmd: ["helm"]
|
||||
args: ["uninstall", "-n", "$(KEPTN_PROJECT)-$(KEPTN_STAGE)", "$(KEPTN_SERVICE)", "--wait"]
|
||||
|
||||
# - name: "Rollback using helm"
|
||||
# events:
|
||||
# - name: "sh.keptn.event.rollback.triggered"
|
||||
# tasks:
|
||||
# - name: "Run helm"
|
||||
# serviceAccount: "jes-deploy-using-helm"
|
||||
# image: "alpine/helm:3.7.2"
|
||||
# cmd: ["helm"]
|
||||
# args: ["rollback", "-n", "$(KEPTN_PROJECT)-$(KEPTN_STAGE)", "$(KEPTN_SERVICE)", "--wait"]
|
||||
|
||||
# - name: "Scale using kubectl"
|
||||
# events:
|
||||
# - name: "sh.keptn.event.action.triggered"
|
||||
# jsonpath:
|
||||
# property: "$.data.action.action"
|
||||
# match: "scaling"
|
||||
# tasks:
|
||||
# - name: "Run kubectl"
|
||||
# serviceAccount: "jes-deploy-using-helm"
|
||||
# env:
|
||||
# - name: SCALING
|
||||
# value: $.data.action.value
|
||||
# valueFrom: event
|
||||
# image: "alpine/k8s:1.20.15"
|
||||
# cmd: ["sh"]
|
||||
# # Note: Hardcoded kubernetes namespace & KEPTN_SERVICE does most likely not match the deployment name
|
||||
# args: ["-c", "REPLICAS=$(kubectl -n ${KEPTN_PROJECT}-${KEPTN_STAGE} get deployment/${KEPTN_SERVICE} -o go-template='{{.spec.replicas}}');DESIRED=$((${SCALING}+${REPLICAS}));echo Scaling deployment to ${DESIRED} && kubectl -n ${KEPTN_PROJECT}-${KEPTN_STAGE} scale --replicas=${DESIRED} deployment/${KEPTN_SERVICE}"]
|
||||
|
||||
# - name: "Run tests using locust"
|
||||
# events:
|
||||
# - name: "sh.keptn.event.test.triggered"
|
||||
# tasks:
|
||||
# - name: "Run locust"
|
||||
# files:
|
||||
# - locust/basic.py
|
||||
# - locust/locust.conf
|
||||
# image: "locustio/locust:2.8.6"
|
||||
# cmd: ["locust"]
|
||||
# args: ["--config", "/keptn/locust/locust.conf", "-f", "/keptn/locust/basic.py", "--host", "http://$(KEPTN_SERVICE)-$(KEPTN_STAGE).nttdata-xlabs.com", "--only-summary"]
|
||||
|
|
@ -0,0 +1,2 @@
|
|||
servicename: carts-db
|
||||
creationtimestamp: 2025-01-21 14:08:55.781321133 +0000 UTC
|
||||
Binary file not shown.
|
|
@ -0,0 +1,2 @@
|
|||
spec_version: '0.1.0'
|
||||
dtCreds: dynatrace-service
|
||||
|
|
@ -0,0 +1,12 @@
|
|||
---
|
||||
spec_version: '1.0'
|
||||
indicators:
|
||||
throughput: "metricSelector=builtin:service.requestCount.total:merge(\"dt.entity.service\"):sum&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
error_rate: "metricSelector=builtin:service.errors.total.count:merge(\"dt.entity.service\"):avg&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
response_time_p50: "metricSelector=builtin:service.response.time:merge(\"dt.entity.service\"):percentile(50)&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
response_time_p90: "metricSelector=builtin:service.response.time:merge(\"dt.entity.service\"):percentile(90)&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
response_time_p95: "metricSelector=builtin:service.response.time:merge(\"dt.entity.service\"):percentile(95)&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
#rt_addToCart: "metricSelector=calc:service.itemscontroller.qg:filter(eq(url,addToCart)):merge(0):percentile(95)&entitySelector=tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE),type(SERVICE)"
|
||||
pg_heap_suspension: "metricSelector=builtin:tech.jvm.memory.gc.suspensionTime:merge(\"dt.entity.process_group_instance\"):max&entitySelector=tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE),type(PROCESS_GROUP_INSTANCE)"
|
||||
pg_cpu_usage: "metricSelector=builtin:tech.generic.cpu.usage:merge(\"dt.entity.process_group_instance\"):max&entitySelector=tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE),type(PROCESS_GROUP_INSTANCE)"
|
||||
response_time_avg: "metricSelector=builtin:service.response.time:merge(\"dt.entity.service\"):avg&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
|
|
@ -0,0 +1,77 @@
|
|||
apiVersion: v2
|
||||
actions:
|
||||
- name: "Deploy using helm"
|
||||
events:
|
||||
- name: "sh.keptn.event.deployment.triggered"
|
||||
tasks:
|
||||
# - name: "Create Namespace"
|
||||
# serviceAccount: "jes-deploy-using-helm"
|
||||
# # env:
|
||||
# # - name: SCALING
|
||||
# # value: $.data.action.value
|
||||
# # valueFrom: event
|
||||
# image: "alpine/k8s:1.20.15"
|
||||
# cmd: ["sh"]
|
||||
# # Note: Hardcoded kubernetes namespace & KEPTN_SERVICE does most likely not match the deployment name
|
||||
# args: ["-c", "REPLICAS=$(kubectl -n ${KEPTN_PROJECT}-${KEPTN_STAGE} get deployment/${KEPTN_SERVICE} -o go-template='{{.spec.replicas}}');DESIRED=$((${SCALING}+${REPLICAS}));echo Scaling deployment to ${DESIRED} && kubectl -n ${KEPTN_PROJECT}-${KEPTN_STAGE} scale --replicas=${DESIRED} deployment/${KEPTN_SERVICE}"]
|
||||
- name: "Run helm"
|
||||
files:
|
||||
- /charts
|
||||
env:
|
||||
- name: IMAGE
|
||||
value: "$.data.configurationChange.values.image"
|
||||
valueFrom: event
|
||||
image: "alpine/helm:3.7.2"
|
||||
serviceAccount: "jes-deploy-using-helm"
|
||||
cmd: ["helm"]
|
||||
#args: ["upgrade", "--force", "--create-namespace", "--install", "-n", "$(KEPTN_PROJECT)-$(KEPTN_STAGE)", "$(KEPTN_SERVICE)", "/keptn/charts/$(KEPTN_SERVICE).tgz", "--set", "image=$(IMAGE)", "--set", "keptn.service=$(KEPTN_SERVICE)", "--set", "keptn.deployment=$(KEPTN_STAGE)", "--set", "keptn.project=$(KEPTN_PROJECT)","--set", "keptn.stage=$(KEPTN_STAGE)", "--wait"]
|
||||
args: ["upgrade", "--force", "--install", "-n", "$(KEPTN_PROJECT)-$(KEPTN_STAGE)", "$(KEPTN_SERVICE)", "/keptn/charts/$(KEPTN_SERVICE).tgz", "--set", "image=$(IMAGE)", "--set", "keptn.service=$(KEPTN_SERVICE)", "--set", "keptn.deployment=$(KEPTN_STAGE)", "--set", "keptn.project=$(KEPTN_PROJECT)","--set", "keptn.stage=$(KEPTN_STAGE)", "--wait"]
|
||||
- name: "Uninstall"
|
||||
events:
|
||||
- name: "sh.keptn.event.uninstall.triggered"
|
||||
tasks:
|
||||
- name: "Run helm uninstall"
|
||||
serviceAccount: "jes-deploy-using-helm"
|
||||
image: "alpine/helm:3.7.2"
|
||||
cmd: ["helm"]
|
||||
args: ["uninstall", "-n", "$(KEPTN_PROJECT)-$(KEPTN_STAGE)", "$(KEPTN_SERVICE)", "--wait"]
|
||||
- name: "Rollback using helm"
|
||||
events:
|
||||
- name: "sh.keptn.event.rollback.triggered"
|
||||
tasks:
|
||||
- name: "Run helm"
|
||||
serviceAccount: "jes-deploy-using-helm"
|
||||
image: "alpine/helm:3.7.2"
|
||||
cmd: ["helm"]
|
||||
args: ["rollback", "-n", "$(KEPTN_PROJECT)-$(KEPTN_STAGE)", "$(KEPTN_SERVICE)", "--wait"]
|
||||
|
||||
- name: "Scale using kubectl"
|
||||
events:
|
||||
- name: "sh.keptn.event.action.triggered"
|
||||
jsonpath:
|
||||
property: "$.data.action.action"
|
||||
match: "scaling"
|
||||
tasks:
|
||||
- name: "Run kubectl"
|
||||
serviceAccount: "jes-deploy-using-helm"
|
||||
env:
|
||||
- name: SCALING
|
||||
value: $.data.action.value
|
||||
valueFrom: event
|
||||
image: "alpine/k8s:1.20.15"
|
||||
cmd: ["sh"]
|
||||
# Note: Hardcoded kubernetes namespace & KEPTN_SERVICE does most likely not match the deployment name
|
||||
args: ["-c", "REPLICAS=$(kubectl -n ${KEPTN_PROJECT}-${KEPTN_STAGE} get deployment/${KEPTN_SERVICE} -o go-template='{{.spec.replicas}}');DESIRED=$((${SCALING}+${REPLICAS}));echo Scaling deployment to ${DESIRED} && kubectl -n ${KEPTN_PROJECT}-${KEPTN_STAGE} scale --replicas=${DESIRED} deployment/${KEPTN_SERVICE}"]
|
||||
|
||||
- name: "Run tests using locust"
|
||||
events:
|
||||
- name: "sh.keptn.event.test.triggered"
|
||||
tasks:
|
||||
- name: "Run locust"
|
||||
files:
|
||||
- locust/basic.py
|
||||
- locust/locust.conf
|
||||
|
||||
image: "locustio/locust:2.8.6"
|
||||
cmd: ["locust"]
|
||||
args: ["--config", "/keptn/locust/locust.conf", "-f", "/keptn/locust/basic.py", "--host", "http://$(KEPTN_SERVICE)-$(KEPTN_STAGE).nttdata-xlabs.com", "--only-summary"]
|
||||
|
|
@ -0,0 +1,8 @@
|
|||
from locust import HttpUser, between, task
|
||||
|
||||
class WebsiteUser(HttpUser):
|
||||
#wait_time = between(5, 15)
|
||||
|
||||
@task
|
||||
def index(self):
|
||||
self.client.post("/carts/1/items", json= {"itemId":"03fef6ac-1896-4ce8-bd69-b798f85c6e0b","unitPrice":"99.99"}, headers={"x-dynatrace-test": "LSN=Test;"})
|
||||
|
|
@ -0,0 +1,5 @@
|
|||
locustfile = /locust/locust.py
|
||||
headless = true
|
||||
users = 5
|
||||
run-time = 1m
|
||||
exit-code-on-error=0
|
||||
|
|
@ -0,0 +1,2 @@
|
|||
servicename: carts
|
||||
creationtimestamp: 2025-01-21 14:08:53.496967972 +0000 UTC
|
||||
|
|
@ -0,0 +1,42 @@
|
|||
---
|
||||
spec_version: "0.1.1"
|
||||
comparison:
|
||||
aggregate_function: "avg"
|
||||
compare_with: "single_result"
|
||||
include_result_with_score: "pass"
|
||||
number_of_comparison_results: 1
|
||||
filter:
|
||||
objectives:
|
||||
- sli: "response_time_p95"
|
||||
key_sli: false
|
||||
pass: # pass if (relative change <= 10% AND absolute value is < 600ms)
|
||||
- criteria:
|
||||
- "<=+25%" # relative values require a prefixed sign (plus or minus)
|
||||
- "<600000" # absolute values only require a logical operator
|
||||
warning: # if the response time is below 800ms, the result should be a warning
|
||||
- criteria:
|
||||
- "<=800000"
|
||||
weight: 1
|
||||
# - sli: "rt_addToCart" # looking at a particular transaction
|
||||
# weight: 3 # business critical transaction
|
||||
# pass:
|
||||
# - criteria:
|
||||
# - "<=+20%" # Degradation-driven
|
||||
# - "<300000" # NFR-driven
|
||||
# warning:
|
||||
# - criteria:
|
||||
# - "<=+50%"
|
||||
# - "<=500000"
|
||||
- sli: "error_rate"
|
||||
pass:
|
||||
- criteria:
|
||||
- "<=+50%"
|
||||
- "<5"
|
||||
warning:
|
||||
- criteria:
|
||||
- "<10"
|
||||
- sli: "pg_heap_suspension"
|
||||
- sli: "pg_cpu_usage"
|
||||
total_score:
|
||||
pass: "90%"
|
||||
warning: "70%"
|
||||
|
|
@ -0,0 +1,2 @@
|
|||
spec_version: '0.1.0'
|
||||
dtCreds: dynatrace-service
|
||||
|
|
@ -0,0 +1,12 @@
|
|||
---
|
||||
spec_version: '1.0'
|
||||
indicators:
|
||||
throughput: "metricSelector=builtin:service.requestCount.total:merge(\"dt.entity.service\"):sum&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
error_rate: "metricSelector=builtin:service.errors.total.count:merge(\"dt.entity.service\"):avg&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
response_time_p50: "metricSelector=builtin:service.response.time:merge(\"dt.entity.service\"):percentile(50)&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
response_time_p90: "metricSelector=builtin:service.response.time:merge(\"dt.entity.service\"):percentile(90)&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
response_time_p95: "metricSelector=builtin:service.response.time:merge(\"dt.entity.service\"):percentile(95)&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
#rt_addToCart: "metricSelector=calc:service.itemscontroller.qg:filter(eq(url,addToCart)):merge(0):percentile(95)&entitySelector=tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE),type(SERVICE)"
|
||||
pg_heap_suspension: "metricSelector=builtin:tech.jvm.memory.gc.suspensionTime:merge(\"dt.entity.process_group_instance\"):max&entitySelector=tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE),type(PROCESS_GROUP_INSTANCE)"
|
||||
pg_cpu_usage: "metricSelector=builtin:tech.generic.cpu.usage:merge(\"dt.entity.process_group_instance\"):max&entitySelector=tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE),type(PROCESS_GROUP_INSTANCE)"
|
||||
response_time_avg: "metricSelector=builtin:service.response.time:merge(\"dt.entity.service\"):avg&entitySelector=type(SERVICE),tag(keptn_project:$PROJECT),tag(keptn_stage:$STAGE),tag(keptn_service:$SERVICE)"
|
||||
Loading…
Reference in New Issue