Compare commits
18 Commits
main
...
production
| Author | SHA1 | Date |
|---|---|---|
|
|
ee4eb4e82f | |
|
|
f283a97be9 | |
|
|
56f33c01d9 | |
|
|
df5941eeea | |
|
|
d76c86c72a | |
|
|
f7255a5ba5 | |
|
|
3f465879aa | |
|
|
3f1e2c874d | |
|
|
e67b195a37 | |
|
|
e7b5c8be72 | |
|
|
729e2ba9bf | |
|
|
f154259939 | |
|
|
dd27bcd6a1 | |
|
|
7a4f28d819 | |
|
|
bd49cfe6d7 | |
|
|
2aafc949a8 | |
|
|
7da97fadaa | |
|
|
0ecd2c2d87 |
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:56.552225682 +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:54.119940294 +0000 UTC
|
||||
|
|
@ -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