မင်္ဂလာပါလူတိုင်းအတွက်!
ဤဆောင်းပါးတွင် Jenkins ကို အလိုအလျောက်စနစ်အဖြစ် အသုံးပြု၍ OpenShift တွင် JMeter စွမ်းဆောင်ရည်စမ်းသပ်မှုများကို လုပ်ဆောင်ရန် နည်းလမ်းများထဲမှ တစ်ခုကို မျှဝေလိုပါသည်။ ပထမဦးစွာကျွန်ုပ်တို့သည်လိုအပ်သောအဆင့်များအားလုံးကိုလုပ်ဆောင်ပါမည် (ဖန်တီးခြင်း။ ImageStreams
, BuildConfig
, Job
etc.) manual mode တွင်။ ပြီးရင် Jenkins Pipeline ကိုရေးကြည့်ရအောင်။
အစမှတ်အဖြစ် ကျွန်ုပ်တို့ရှိသင့်သည်-
- OpenShift (v3.11) အစုအဝေးကို လုပ်ဆောင်နေသည်။
- OpenShift တွင်အလုပ်လုပ်ရန် configured အထောက်အထားများနှင့်အတူ Jenkins ဆာဗာ
- ဖိုင်
apache-jmeter-5.2.tgz
စမ်းသပ်မှုတွေအရ ရိုးရှင်းပါလိမ့်မယ်။ HTTP Request
အပေါ် ya.ru
စမ်းချောင်းတစ်ခုတွင်။
OpenShift တွင် ပရောဂျက်တစ်ခုကို ဖန်တီးခြင်း။
ပတ်ဝန်းကျင်အသစ် ဖန်တီးခြင်းဖြင့် စတင်ကြပါစို့။ ဖန်တီးကြရအောင် perftest
အဖွဲ့တစ်ဖွဲ့ဖြင့် ဝန်းရံထားသည်။
$ oc new-project perftest --display-name="Performance Tests" --description="Performance Tests - JMeter"
ကျွန်ုပ်တို့သည် အသစ်ဖန်တီးထားသော ပတ်ဝန်းကျင်သို့ အလိုအလျောက် ပြောင်းရွှေ့သွားပါမည်။ perftest
ဤကဲ့သို့ဖြစ်သည်ကို စစ်ဆေးကြည့်ကြပါစို့။
$ oc project
Using project "perftest" on server "https://127.0.0.1:8443".
သိုလှောင်မှုဖန်တီးခြင်း။
စမ်းသပ်မှုအစီရင်ခံစာများကို ဝဘ်ဆာဗာနှင့် တူညီစွာ သိမ်းဆည်းထားမည်ဖြစ်သည်။ jmeter-meter
'နေရာ- /jmeter/reports
.
POD များကို ၎င်းတို့နှင့် ချိတ်ဆက်ထားသောကြောင့် ယခု Storajs ကို ဖန်တီးခြင်းသည် ပိုကောင်းပါသည်။ jmeter-web
и jmeter-master
.
တရားဝင်စာရွက်စာတမ်းများတွင် သိုလှောင်မှုဆိုင်ရာ အသေးစိတ်အချက်အလက်များကို သင်တွေ့လိမ့်မည်။
yaml ဖိုင်တွေကို ဖန်တီးကြရအောင် PV
и PVC
.
pv.yaml
$ tee pv.yaml<<EOF
apiVersion: v1
kind: PersistentVolume
metadata:
name: jmeter-reports
spec:
capacity:
storage: 10Gi
accessModes:
- ReadWriteMany
glusterfs:
endpoints: glusterfs-cluster
path: /jmeter/reports
readOnly: false
persistentVolumeReclaimPolicy: Retain
EOF
pvc.yaml
$ tee pvc.yaml<<EOF
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: jmeter-reports
spec:
accessModes:
- ReadWriteMany
resources:
requests:
storage: 10Gi
EOF
ဖန်တီးကြရအောင် PV
и PVC
OpenShift ဖြင့်ဝိုင်းရံထားသည်-
$ oc create -f pv.yaml -n perftest
$ oc create -f pvc.yaml -n perftest
အခြေအနေကို စစ်ဆေးနေသည်။ PVC
:
$ oc get pvc -n perftest
NAME STATUS VOLUME CAPACITY ACCESS MODES STORAGECLASS AGE
jmeter-reports Bound pvc-b0e5f152-db4b-11ea-a497-566f75280024 10Gi RWX glusterfs-storage 8m
ဤသည်မှာ GUI တွင်မည်သို့မည်ပုံဖြစ်သည်-
JMeter Base Image ဖန်တီးခြင်း။
ဖန်တီးမှုဆီသို့ ဆက်သွားကြပါစို့ ImageStream
и BuildConfig
.
လိုအပ်သော အချက်အလက်အားလုံးကို စာရွက်စာတမ်းများတွင် ရှာဖွေနိုင်သည်-
ပုံသဏ္ဍာန်တည်ဆောက်နည်းဗျူဟာသည် Docker
ဒေသခံအရင်းအမြစ်တစ်ခုမှ။
အခြေခံပုံတစ်ခု ဖန်တီးကြည့်ရအောင် jmeter-base
မည်သည့်အတွက် အခြေခံဖြစ်မည်နည်း။ jmeter-master
.
dockerfile
FROM openjdk:8u212-jdk
ARG JMETER_VER="5.2"
ENV JMETER_HOME /jmeter/apache-jmeter-$JMETER_VER
ENV PATH $JMETER_HOME/bin:$PATH
RUN mkdir -p /jmeter/results
&& mkdir /jmeter/tests
WORKDIR /jmeter
COPY apache-jmeter-$JMETER_VER.tgz .
RUN tar -xzf $JMETER_HOME.tgz
&& rm $JMETER_HOME.tgz
&& ls -la
RUN sed -i s/#server.rmi.ssl.disable=false/server.rmi.ssl.disable=true/ $JMETER_HOME/bin/jmeter.properties
EXPOSE 60000
is.yaml
$ tee is.yaml<<EOF
apiVersion: v1
kind: ImageStream
metadata:
labels:
build: jmeter-base
name: jmeter-base
EOF
bc.yaml
$ tee bc.yaml<<EOF
apiVersion: v1
kind: BuildConfig
metadata:
name: jmeter-base
spec:
failedBuildsHistoryLimit: 5
nodeSelector: null
output:
to:
kind: ImageStreamTag
name: 'jmeter-base:latest'
postCommit: {}
resources: {}
runPolicy: Serial
source:
binary: {}
type: Binary
strategy:
dockerStrategy:
from:
kind: ImageStreamTag
name: 'openjdk:8u212-jdk'
type: Docker
successfulBuildsHistoryLimit: 5
EOF
အရာဝတ္ထုများကိုဖန်တီးကြပါစို့ IS
и BC
:
$ oc create -f is.yaml -n perftest
$ oc create -f bc.yaml -n perftest
အခု အခြေခံပုံကို စုစည်းလိုက်ရအောင် jmeter-base
:
$ oc start-build jmeter-base -n perftest --from-dir=. --follow
JMeter ဝဘ်
jmeter-web
၎င်းသည် Apache ဝဘ်ဆာဗာတစ်ခုဖြစ်သည်။ ၎င်း၏တာဝန်မှာ ကြည့်ရှုရန်အတွက် စမ်းသပ်မှုရလဒ်များပါရှိသော လမ်းညွှန်တစ်ခုကို ပေးဆောင်ရန်ဖြစ်သည်။
ပြင်ဆင်ထားတယ်။ Dockerfile
နှင့် configuration ဖိုင် httpd.conf
. ညွှန်ကြားချက်အတွက် DocumentRoot
တန်ဖိုးသတ်မှတ်ထားသည်။ /jmeter/reports
, i.e. စမ်းသပ်မှုရလဒ်များကို သိမ်းဆည်းထားသည့် လမ်းညွှန်။
dockerfile
$ tee Dockerfile<<EOF
FROM httpd:2.4
COPY httpd.conf /usr/local/apache2/conf/httpd.conf
RUN chmod -R 777 /usr/local/apache2/logs
EXPOSE 8080
CMD ["httpd", "-D", "FOREGROUND"]
EOF
is.yaml
$ tee is.yaml<<EOF
apiVersion: v1
kind: ImageStream
metadata:
generation: 1
labels:
build: jmeter-web
name: jmeter-web
EOF
bc.yaml
$ tee bc.yaml<<EOF
apiVersion: v1
kind: BuildConfig
metadata:
name: jmeter-web
spec:
failedBuildsHistoryLimit: 5
nodeSelector: null
output:
to:
kind: ImageStreamTag
name: 'jmeter-web:latest'
runPolicy: Serial
source:
binary: {}
type: Binary
strategy:
dockerStrategy:
from:
kind: ImageStreamTag
name: 'httpd:2.4'
type: Docker
successfulBuildsHistoryLimit: 5
EOF
ဖန်တီးကြရအောင် ImageStream
и BuildConfig
အရာဝတ္ထုများ-
$ oc create -f is.yaml -n perftest
$ oc create -f bc.yaml -n perftest
ပုံတစ်ပုံကို စုဆောင်းခြင်း။ Dockerfile
:
$ oc start-build jmeter-web -n perftest --from-dir=. --follow
dc.yaml
$ tee dc.yaml<<EOF
apiVersion: apps.openshift.io/v1
kind: DeploymentConfig
metadata:
name: jmeter-web
spec:
replicas: 1
template:
metadata:
labels:
name: jmeter-web
spec:
containers:
- image: 172.30.1.1:5000/perftest/jmeter-web
name: jmeter-web
volumeMounts:
- mountPath: /jmeter/reports
name: jmeter-reports
ports:
- containerPort: 80
protocol: TCP
- containerPort: 8080
protocol: TCP
volumes:
- name: jmeter-reports
persistentVolumeClaim:
claimName: jmeter-reports
EOF
sc.yaml
$ tee sc.yaml<<EOF
apiVersion: v1
kind: Service
metadata:
labels:
app: jmeter-web
name: jmeter-web
spec:
ports:
- name: 8080-tcp
port: 8080
protocol: TCP
targetPort: 8080
selector:
deploymentconfig: jmeter-web
sessionAffinity: None
type: ClusterIP
EOF
အရာဝတ္ထုများကိုဖန်တီးကြပါစို့ Service
и DeploymentConfig
:
$ oc create -f sc.yaml -n perftest
$ oc create -f dc.yaml -n perftest
Jmeter-မာစတာ
Apache ဝဘ်ဆာဗာကို စတင်အသုံးပြုကြပါစို့။
ဒါက Dockerfile ပါ။ jmeter-master
'a, ပေါ်တွင်အခြေခံသည်။ jmeter-base
စမ်းသပ်မှုများ လုပ်ဆောင်ပြီး ရလဒ်များကို သိုလှောင်မှုတွင် သိမ်းဆည်းမည်ဖြစ်သည်။
dockerfile
Dockerfile
အတွက် jmeter-master
, ပေါ်အခြေခံကာ jmeter-base
.
FROM jmeter-base
ARG JMETER_VER="5.2"
ENV JMETER_HOME /jmeter/apache-jmeter-$JMETER_VER
ENV PATH $JMETER_HOME/bin:$PATH
WORKDIR /jmeter
COPY run.sh /jmeter/
COPY tests/*.jmx /jmeter/tests/
RUN chmod +x /jmeter/run.sh
ENTRYPOINT ["/bin/bash"]
CMD ["/jmeter/run.sh"]
run.sh
run.sh
၎င်းသည် JMeter ကိုလည်ပတ်ပြီးရလဒ်များကိုလမ်းညွှန်တစ်ခုတွင်သိမ်းဆည်းသည့် script တစ်ခုဖြစ်သည်။ files
.
ဇာတ်ညွှန်းကို စတင်လိုက်တိုင်း၊ ၎င်းသည် ယခင်စမ်းသပ်မှုများကို ဖျက်လိုက်သောကြောင့် သင်သည် နောက်ဆုံးဒေတာဖြင့်သာ လုပ်ဆောင်နိုင်သည်။ ဒါပေမယ့် ဒါက ပြဿနာမဟုတ်ပါဘူး၊ ဘာကြောင့်လဲဆိုတော့ မင်းရဲ့လိုအပ်ချက်နဲ့ကိုက်ညီအောင် ပြောင်းလဲလို့ရတယ်။
#!/bin/bash
set -e
if [ -d "/jmeter/reports/files" ]
then
echo "Directory /jmeter/reports/files exist - OK"
else
echo "Creating /jmeter/reports/files directory"
mkdir /jmeter/reports/files
fi
if [ -d "/jmeter/reports/dashboards" ]
then
echo "Directory /jmeter/reports/dashboards exist"
else
echo "Creating /jmeter/reports/dashboards directory"
mkdir /jmeter/reports/dashboards
fi
echo "*** JMeter START Tests ***"
for item in $(ls -1 /jmeter/tests | grep jmx)
do
echo "*** Removing dashboard directory for $item"
rm -rdf /jmeter/reports/dashboards/${item}*
echo "*** Removing tests directory for $item"
rm -rdf /jmeter/reports/files/${item}*
echo "*** Testing a $item file ***"
jmeter -n -t /jmeter/tests/${item} -l /jmeter/reports/files/${item}-report.jtl -e -o /jmeter/reports/dashboards/${item}-dash
done
is.yaml
$ tee is.yaml<<EOF
apiVersion: image.openshift.io/v1
kind: ImageStream
metadata:
generation: 1
labels:
build: jmeter-master
name: jmeter-master
EOF
bc.yaml
$ tee bc.yaml<<EOF
apiVersion: build.openshift.io/v1
kind: BuildConfig
metadata:
name: jmeter-master
spec:
failedBuildsHistoryLimit: 5
nodeSelector: null
output:
to:
kind: ImageStreamTag
name: 'jmeter-master:latest'
runPolicy: Serial
source:
binary: {}
type: Binary
strategy:
dockerStrategy:
from:
kind: ImageStreamTag
name: 'jmeter-base:latest'
type: Docker
successfulBuildsHistoryLimit: 5
EOF
ဖန်တီးကြရအောင် IS
и BC
အရာဝတ္ထုများ-
$ oc create -f is.yaml -n perftest
$ oc create -f bc.yaml -n perftest
ချပြီး jmeter-master
ပုံ-
$ oc start-build jmeter-master -n perftest --from-dir=. --follow
အလုပ်
Job
တွင်အသုံးပြုကြသည်။ OpenShift
တစ်ခု သို့မဟုတ် တစ်ခုထက်ပို၍ လုပ်ဆောင်ရန် POD
's နှင့် command/script ကို လုပ်ဆောင်ပြီးနောက် ၎င်းတို့၏ အောင်မြင်စွာ ပြီးမြောက်ကြောင်း အာမခံပါသည်။
$ tee job.yaml<<EOF
apiVersion: batch/v1
kind: Job
metadata:
name: jmeter-master
labels:
jobName: jmeter-master
spec:
completions: 1
parallelism: 1
template:
metadata:
name: jmeter-master
labels:
jobName: jmeter-master
spec:
containers:
- name: jmeter-master
image: 172.30.1.1:5000/perftest/jmeter-master:latest
volumeMounts:
- mountPath: /jmeter/reports
name: jmeter-reports
imagePullPolicy: Always
volumes:
- name: jmeter-reports
persistentVolumeClaim:
claimName: jmeter-reports
restartPolicy: Never
terminationGracePeriodSeconds: 30
EOF
အရာဝတ္ထုတစ်ခုဖန်တီးပါ။ Job
:
$ oc create -f job.yaml -n perftest
အလုပ်ရဲ့ အခြေအနေကို စစ်ဆေးကြည့်ရအောင်။
$ oc get jobs -n perftest
NAME DESIRED SUCCESSFUL AGE
jmeter-master 1 1 5m
ဖျက်ရန် Job
command ကိုသုံးရအောင်။
$ oc delete jobs/jmeter-master -n perftest --ignore-not-found=true
Jenkins ပိုက်လိုင်း
အခု automation ပေါ့။ အဆင့်တွေကို ထပ်ပြီးသွားကြည့်ရအောင်။
git clone
oc whoami -t
oc start-build ...
oc delete jobs/jmeter-master
oc create -f job.yaml -n perftest
အောက်တွင် သိုလှောင်မှုပုံတူပွားခြင်း၊ ဖျက်ခြင်းနှင့် OpenShift ဖန်တီးခြင်းတို့ကို လုပ်ဆောင်သည့် ပိုက်လိုင်းတစ်ခုဖြစ်သည်။ Job
၎။
#!groovy
pipeline {
agent any
stages {
stage('Start Notifications') {
steps {
echo "Sending Email Notification"
}
post {
always {
echo "STARTED - Performance Tests"
mail(to: '[email protected]', from: "[email protected]", subject: "START - Performance Tests",mimeType: "text/html", body: "<strong>START - Performance Tests</strong><br /><br />Project: Name of Project<br />Environment: PerfTest<br />Build number: ${env.BUILD_NUMBER}<br />Build URL: ${env.BUILD_URL}"
}
}
}
stage('Git checkout') {
steps {
...
}
}
stage('Perf Tests') {
steps {
script {
sh '''
OC_CMD1="oc login -u=username -p=PASS -n=perftest
--server=https://...:8443"
$OC_CMD1
OC_TOKEN=`oc whoami -t`
OC_CMD2="oc --token=$OC_TOKEN --server=https://...:8443
start-build jmeter-master -n=perftest --from-dir=./master
--follow=true"
OC_CMD3="oc --token=$OC_TOKEN --server=https://...:8443
delete jobs/jmeter-master -n=perftest --ignore-not-found=true"
OC_CMD4="oc--token=$OC_TOKEN --server=https://...:8443
create -f ./master/job.yaml -n=perftest"
$OC_CMD2
$OC_CMD3
$OC_CMD4
'''
}
}
}
post {
failure {
echo "FAILED - Performance Tests"
mail(to: '[email protected]', from: "[email protected]", subject: "FAILED - Performance Tests",mimeType: "text/html", body: "<strong>FAILED - Performance Tests</strong><br /><br />Project: Name of Project<br />Environment: PerfTest<br />Build number: ${env.BUILD_NUMBER}<br />Build URL: ${env.BUILD_URL}"
}
success {
echo "SUCCESSED - Performance Tests"
mail(to: '[email protected]', from: "[email protected]", subject: "SUCCESSED - Performance Tests",mimeType: "text/html", body: "<strong>SUCCESSED - Performance Tests</strong><br /><br />Project: Name of Project<br />Environment: PerfTest<br />Build number: ${env.BUILD_NUMBER}<br />Build URL: ${env.BUILD_URL}"
}
}
}
}
ပိုက်လိုင်းသည် ၎င်း၏လုပ်ငန်းလည်ပတ်မှု ပြီးဆုံးပြီးနောက်၊ ကျွန်ုပ်တို့ထံ အီးမေးလ်ဖြင့် အကြောင်းကြားချက်တစ်ခု လက်ခံရရှိပါမည်။ '[email protected]
от [email protected]
.
လင့်ကိုနှိပ်ပါ။ files
စမ်းသပ်အစီရင်ခံစာများကို သိမ်းဆည်းထားသည့်၊
ဖိုင်အကြောင်းအရာများ ya.HTTP.Request.jmx-report.jtk
:
timeStamp,elapsed,label,responseCode,responseMessage,threadName,dataType,success,failureMessage,bytes,sentBytes,grpThreads,allThreads,URL,Latency,IdleTime,Connect
1597311456443,569,Yandex - HTTP Request,200,Ok,Thread Group 1-1,text,true,,59449,220,1,1,https://ya.ru/,145,0,57
1597311456443,147,Yandex - HTTP Request-0,302,Found,Thread Group 1-1,,true,,478,110,1,1,http://ya.ru/,145,0,57
1597311456592,420,Yandex - HTTP Request-1,200,Ok,Thread Group 1-1,text,true,,58971,110,1,1,https://ya.ru/,370,0,259
ကောက်ချက်
ဤဆောင်းပါးသည် OpenShift ပတ်ဝန်းကျင်တွင် JMeter စမ်းသပ်မှုများကို လုပ်ဆောင်ရန် ရွေးချယ်စရာများထဲမှ တစ်ခုကို သရုပ်ပြထားသည်။ ကျွန်ုပ်တို့သည် အဆင့်များအားလုံးကို ကိုယ်တိုင်လုပ်ဆောင်ပြီးနောက် စမ်းသပ်လုပ်ဆောင်ခြင်းလုပ်ငန်းစဉ်ကို အလိုအလျောက်လုပ်ဆောင်ရန် Jenkins Pipeline ကို ဖန်တီးခဲ့သည်။
အရင်းအမြစ်များနှင့်စာရွက်စာတမ်းများ
JMeter - Docker ကို အသုံးပြု၍ ဖြန့်ဝေထားသော Load စမ်းသပ်ခြင်း။ Jenkins ပိုက်လိုင်းမှ OpenShift တွင် JMeter စမ်းသပ်မှုများကို လုပ်ဆောင်ခြင်း။ ပွင့်လင်းpersistent သိုလှောင်မှု တည်ဆောက်ခြင်းနှင့် ရုပ်ပုံစီးကြောင်းများ
source: www.habr.com