เชœเซ‡เชจเช•เชฟเชจเซเชธ เชชเชพเช‡เชชเชฒเชพเช‡เชจเชจเซ‹ เช‰เชชเชฏเซ‹เช— เช•เชฐเซ€เชจเซ‡ เช“เชชเชจเชถเชฟเชซเซเชŸเชฎเชพเช‚ JMeter เชชเชฐเซ€เช•เซเชทเชฃเซ‹ เชšเชฒเชพเชตเชตเซเช‚

เชนเซ‡เชฒเซ‹ เชฆเชฐเซ‡เช•!

เช† เชฒเซ‡เช–เชฎเชพเช‚ เชนเซเช‚ เชœเซ‡เชจเช•เชฟเชจเซเชธเชจเซ‹ เช“เชŸเซ‹เชฎเซ‡เชถเชจ เชคเชฐเซ€เช•เซ‡ เช‰เชชเชฏเซ‹เช— เช•เชฐเซ€เชจเซ‡ OpenShift เชฎเชพเช‚ JMeter เชชเซเชฐเชฆเชฐเซเชถเชจ เชชเชฐเซ€เช•เซเชทเชฃเซ‹ เชšเชฒเชพเชตเชตเชพเชจเซ€ เชเช• เชฐเซ€เชค เชถเซ‡เชฐ เช•เชฐเชตเชพ เชฎเชพเช‚เช—เซ เช›เซเช‚. เชชเซเชฐเชฅเชฎ เช†เชชเชฃเซ‡ เชฌเชงเชพ เชœเชฐเซ‚เชฐเซ€ เชชเช—เชฒเชพเช‚เช“ เช•เชฐเซ€เชถเซเช‚ (เชฌเชจเชพเชตเชตเซ€ ImageStreams, BuildConfig, Job เชตเช—เซ‡เชฐเซ‡) เชฎเซ‡เชจเซเชฏเซเช…เชฒ เชฎเซ‹เชกเชฎเชพเช‚. เชคเซ‡ เชชเช›เซ€, เชšเชพเชฒเซ‹ เชœเซ‡เชจเช•เชฟเชจเซเชธ เชชเชพเช‡เชชเชฒเชพเช‡เชจ เชฒเช–เซ€เช.

เชชเซเชฐเชพเชฐเช‚เชญเชฟเช• เชฌเชฟเช‚เชฆเซ เชคเชฐเซ€เช•เซ‡ เช…เชฎเชพเชฐเซ€ เชชเชพเชธเซ‡ เชนเซ‹เชตเซเช‚ เชœเซ‹เชˆเช:

  1. OpenShift (v3.11) เช•เซเชฒเชธเซเชŸเชฐ เชšเชฒเชพเชตเซ€ เชฐเชนเซเชฏเซเช‚ เช›เซ‡
  2. OpenShift เชฎเชพเช‚ เช•เชพเชฎ เช•เชฐเชตเชพ เชฎเชพเชŸเซ‡ เชฐเซ‚เชชเชฐเซ‡เช–เชพเช‚เช•เชฟเชค เช“เชณเช–เชชเชคเซเชฐเซ‹ เชธเชพเชฅเซ‡ เชœเซ‡เชจเช•เชฟเชจเซเชธ เชธเชฐเซเชตเชฐ
  3. เชซเชพเช‡เชฒ 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.

เชนเชตเซ‡ เชธเซเชŸเซ‹เชฐเซ‡เชœ เชฌเชจเชพเชตเชตเซเช‚ เชตเชงเซ เชธเชพเชฐเซเช‚ เช›เซ‡, เช•เชพเชฐเชฃ เช•เซ‡ เชชเซ€เช“เชกเซ€ เชคเซ‡เชฎเชจเซ€ เชธเชพเชฅเซ‡ เชœเซ‹เชกเชพเชฏเซ‡เชฒเชพ เชนเชถเซ‡ 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 เช“เชชเชจเชถเชฟเชซเซเชŸ เชฆเซเชตเชพเชฐเชพ เช˜เซ‡เชฐเชพเชฏเซ‡เชฒเซเช‚:

$ 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 เชชเชฐเซ€เช•เซเชทเชฃเซ‹ เชšเชฒเชพเชตเชตเซเช‚

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

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 WEB

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

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

เชœเซ‡เชฎเซ€เชŸเชฐ-เชฎเชพเชธเซเชŸเชฐ

เชšเชพเชฒเซ‹ Apache เชตเซ‡เชฌ เชธเชฐเซเชตเชฐเชจเซ‡ เชœเชฎเชพเชตเชตเชพเชจเซเช‚ เชถเชฐเซ‚ เช•เชฐเซ€เช.

เช† เชกเซ‹เช•เชฐเชซเชพเช‡เชฒ เช›เซ‡ jmeter-master'เช, เชชเชฐ เช†เชงเชพเชฐเชฟเชค เช›เซ‡ 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 เช† เชเช• เชธเซเช•เซเชฐเชฟเชชเซเชŸ เช›เซ‡ เชœเซ‡ 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

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เชจเซ€ เช…เชจเซ‡ เช†เชฆเซ‡เชถ/เชธเซเช•เซเชฐเซ€เชชเซเชŸเชจเซ‡ เชเช•เซเชเชฟเช•เซเชฏเซเชŸ เช•เชฐเซเชฏเชพ เชชเช›เซ€ เชคเซ‡เชฎเชจเซ€ เชธเชซเชณเชคเชพเชชเซ‚เชฐเซเชตเช• เชชเซ‚เชฐเซเชฃ เชฅเชตเชพเชจเซ€ เช–เชพเชคเชฐเซ€ เช†เชชเซ‡ เช›เซ‡.

$ 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

เช•เชพ deleteเซ€ เชจเชพเช–เชตเชพ เชฎเชพเชŸเซ‡ Job เชšเชพเชฒเซ‹ เช†เชฆเซ‡เชถเชจเซ‹ เช‰เชชเชฏเซ‹เช— เช•เชฐเซ€เช:

$ oc delete jobs/jmeter-master -n perftest --ignore-not-found=true

เชœเซ‡เชจเช•เชฟเชจเซเชธ เชชเชพเช‡เชชเชฒเชพเช‡เชจ

เชนเชตเซ‡ เช“เชŸเซ‹เชฎเซ‡เชถเชจ. เชšเชพเชฒเซ‹ เชซเชฐเซ€เชฅเซ€ เชชเช—เชฒเชพเช‚เช“ เชชเชฐ เชœเชˆเช:

  1. git clone
  2. oc whoami -t
  3. oc start-build ...
  4. oc delete jobs/jmeter-master
  5. oc create -f job.yaml -n perftest

เชจเซ€เชšเซ‡ เชเช• เชชเชพเชˆเชชเชฒเชพเชˆเชจ เช›เซ‡ เชœเซ‡เชฎเชพเช‚ เชฐเซ€เชชเซ‹เชเซ€เชŸเชฐเซ€ เช•เซเชฒเซ‹เชจเชฟเช‚เช—, เชกเชฟเชฒเซ€เชถเชจ เช…เชจเซ‡ เช“เชชเชจเชถเชฟเชซเซเชŸ เช•เซเชฐเชฟเชเชถเชจ เช•เชฐเชตเชพเชฎเชพเช‚ เช†เชตเซ‡ เช›เซ‡ 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].

เชฒเชฟเช‚เช• เชชเชฐ เช•เซเชฒเชฟเช• เช•เชฐเซ€เชจเซ‡ http://jmeter-web.127.0.0.1.nip.io/ เช†เชชเชฃเซ‡ เชกเชฟเชฐเซ‡เช•เซเชŸเชฐเซ€ เชœเซ‹เชˆเชถเซเช‚ files, เชœเซ‡ เชชเชฐเซ€เช•เซเชทเชฃ เช…เชนเซ‡เชตเชพเชฒเซ‹ เชธเช‚เช—เซเชฐเชนเชฟเชค เช•เชฐเซ‡ เช›เซ‡:

เชœเซ‡เชจเช•เชฟเชจเซเชธ เชชเชพเช‡เชชเชฒเชพเช‡เชจเชจเซ‹ เช‰เชชเชฏเซ‹เช— เช•เชฐเซ€เชจเซ‡ เช“เชชเชจเชถเชฟเชซเซเชŸเชฎเชพเช‚ JMeter เชชเชฐเซ€เช•เซเชทเชฃเซ‹ เชšเชฒเชพเชตเชตเซเช‚

เชซเชพเช‡เชฒ เชธเชฎเชพเชตเชฟเชทเซเชŸเซ‹ 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 เชชเชฐเซ€เช•เซเชทเชฃเซ‹ เชšเชฒเชพเชตเชตเชพ เชฎเชพเชŸเซ‡เชจเชพ เชตเชฟเช•เชฒเซเชชเซ‹เชฎเชพเช‚เชฅเซ€ เชเช•เชจเซเช‚ เชจเชฟเชฆเชฐเซเชถเชจ เช•เชฐเซ‡ เช›เซ‡. เช…เชฎเซ‡ เชคเชฎเชพเชฎ เชชเช—เชฒเชพเช‚ เชœเชพเชคเซ‡ เชœ เชชเซ‚เชฐเซเชฃ เช•เชฐเซเชฏเชพ, เชคเซเชฏเชพเชฐ เชฌเชพเชฆ เช…เชฎเซ‡ เชœเซ‡เชจเช•เชฟเชจเซเชธ เชชเชพเชˆเชชเชฒเชพเชˆเชจ เชฌเชจเชพเชตเซ€ เชœเซ‡เชฅเซ€ เชชเชฐเซ€เช•เซเชทเชฃเซ‹ เชšเชฒเชพเชตเชตเชพเชจเซ€ เชชเซเชฐเช•เซเชฐเชฟเชฏเชพเชจเซ‡ เชธเซเชตเชšเชพเชฒเชฟเชค เช•เชฐเซ€ เชถเช•เชพเชฏ.

เชธเซเชคเซเชฐเซ‹เชคเซ‹ เช…เชจเซ‡ เชฆเชธเซเชคเชพเชตเซ‡เชœเซ€เช•เชฐเชฃ

เชธเซ‹เชฐเซเชธ: www.habr.com

เชเช• เชŸเชฟเชชเซเชชเชฃเซ€ เช‰เชฎเซ‡เชฐเซ‹