அனைவருக்கும் வணக்கம்!
இந்தக் கட்டுரையில், Jenkins ஐ ஆட்டோமேஷனாகப் பயன்படுத்தி OpenShift இல் JMeter செயல்திறன் சோதனைகளை இயக்குவதற்கான வழிகளில் ஒன்றைப் பகிர விரும்புகிறேன். முதலில் தேவையான அனைத்து நடவடிக்கைகளையும் செய்வோம் (உருவாக்கம் ImageStreams
, BuildConfig
, Job
முதலியன) கையேடு முறையில். அதன் பிறகு, ஜென்கின்ஸ் பைப்லைன் எழுதுவோம்.
ஒரு தொடக்க புள்ளியாக நாம் இருக்க வேண்டும்:
- OpenShift (v3.11) கிளஸ்டரை இயக்குகிறது
- OpenShift இல் வேலை செய்ய உள்ளமைக்கப்பட்ட நற்சான்றிதழ்களுடன் ஜென்கின்ஸ் சர்வர்
- файл
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கள் இணைக்கப்படும் 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 அடிப்படை படத்தை உருவாக்குதல்
உருவாக்குவதற்கு செல்லலாம் ImageStream
и BuildConfig
.
ஆவணத்தில் தேவையான அனைத்து தகவல்களையும் நீங்கள் காணலாம் -
படத்தை உருவாக்குவதற்கான உத்தி Docker
உள்ளூர் மூலத்திலிருந்து.
ஒரு அடிப்படை படத்தை உருவாக்குவோம் jmeter-base
, இது அடிப்படையாக இருக்கும் jmeter-master
.
டோக்கர்ஃபைல்
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
என்பது.யாம்ல்
$ 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
இது அப்பாச்சி இணைய சேவையகம். பார்வைக்கு சோதனை முடிவுகளுடன் ஒரு கோப்பகத்தை வழங்குவதே இதன் பணி.
தயார் செய்யப்பட்டது Dockerfile
மற்றும் கட்டமைப்பு கோப்பு httpd.conf
. உத்தரவுக்காக DocumentRoot
மதிப்பு தொகுப்பு /jmeter/reports
, அதாவது சோதனை முடிவுகள் சேமிக்கப்படும் அடைவு.
டோக்கர்ஃபைல்
$ 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
என்பது.யாம்ல்
$ 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
ஜமீட்டர்-மாஸ்டர்
அப்பாச்சி இணைய சேவையகத்தை பயன்படுத்த ஆரம்பிக்கலாம்.
இது தான் Dockerfile jmeter-master
'a, அடிப்படையில் jmeter-base
, இது சோதனைகளை இயக்கி முடிவுகளை சேமிப்பகத்தில் சேமிக்கும்.
டோக்கர்ஃபைல்
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 ஐ இயக்கி முடிவுகளை ஒரு கோப்பகத்தில் சேமிக்கும் ஸ்கிரிப்ட் ஆகும் 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
என்பது.யாம்ல்
$ 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
கள் மற்றும் கட்டளை/ஸ்கிரிப்டை இயக்கிய பிறகு அவை வெற்றிகரமாக முடிவடையும்.
$ 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
கட்டளையைப் பயன்படுத்துவோம்:
$ oc delete jobs/jmeter-master -n perftest --ignore-not-found=true
ஜென்கின்ஸ் பைப்லைன்
இப்போது ஆட்டோமேஷன். மீண்டும் படிகளுக்கு செல்லலாம்:
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 சோதனைகளை இயக்குவதற்கான விருப்பங்களில் ஒன்றைக் காட்டியது. அனைத்து படிகளையும் கைமுறையாக முடித்தோம், அதன் பிறகு சோதனைகளை இயக்கும் செயல்முறையை தானியக்கமாக்க ஜென்கின்ஸ் பைப்லைனை உருவாக்கினோம்.
ஆதாரங்கள் மற்றும் ஆவணங்கள்
JMeter - டோக்கரைப் பயன்படுத்தி விநியோகிக்கப்பட்ட சுமை சோதனை ஜென்கின்ஸ் பைப்லைனில் இருந்து OpenShift இல் JMeter சோதனைகளை இயக்குதல் ஓப்பன்ஷிஃப்ட்தொடர்ச்சியான சேமிப்பு உருவாக்கங்கள் மற்றும் பட ஸ்ட்ரீம்கள்
ஆதாரம்: www.habr.com