记一次性能测试过程

由于公司项目做了巨大改动,需要重新测试性能,下面记录本次测试的过程:

1.准备环境

测试需要公司开阿里云机器测试花钱的,所以先在本地把数据准备好

  1. 测试数据
    • 生成账户数据,使用jar包生成
    • 再使用jar 生成payment 和insert 的签名数据
  2. jmeter工具
    打包Jmeter 镜像,先在本地创建一个目录jmeter_docker ,里面放jmeter文件夹,如下图:


    jmeter_docker.png

    创建一个Dockerfile文件,Dockerfile脚本如下:

FROM java:8
# 基础java版本
MAINTAINER cctester
# 作者
ENV http_proxy ""
ENV https_proxy ""
RUN mkdir /test && \
  chmod -R 777 /test
# 创建/test目录,用于存放jmx脚本、jtl结果文件、html测试报告文件
ENV JMETER_VERSION=5.2.1
ENV JMETER_HOME=/usr/local/apache-jmeter-${JMETER_VERSION}
ENV JMETER_PATH=${JMETER_HOME}/bin:${PATH}
ENV PATH=${JMETER_HOME}/bin:${PATH}
# 设置JMeter环境变量
ADD apache-jmeter-${JMETER_VERSION}.tgz /usr/local
# 添加JMeter
RUN ln -snf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && \
  echo "Asia/Shanghai" > /etc/timezone

再制作Jmeter镜像

执行命令  docker build -t jmeter .    
注意不要忽略最后点

打完查看镜像,执行 docker images 

再将JMeter 镜像保存本地
docker save -o  jmeter.tar  jmeter:latest

把 Jmeter.tar 复制到压测机器上,执行导入镜像
docker load  -i jmeter.tar 即可

  1. 监控工具

本次性能测试采用node_exporter+promethus+granfan监控节点机器
使用jmeter+influxdb+granfan显示jmeter数据,都采用docker-compose方式来安装

docker_compose文件如下:

version: '2'
  
services:
    prometheus:
        image: prom/prometheus
        container_name: prometheus
        hostname: prometheus
        restart: always
        volumes:
            - ./prometheus.yml:/etc/prometheus/prometheus.yml:ro
            # - ./node_down.yml:/etc/prometheus/node_down.yml
        ports:
            - "9090:9090"
        networks:
            - kong_net
   grafana:
        image: grafana/grafana
        container_name: grafana
        hostname: grafana
        restart: always
        ports:
            - "3000:3000"
        networks:
            - kong_net
  influxdb:
        image: influxdb:1.8.4-alpine
        container_name: influxdb
        ports:
            - "8083:8083"
            - "8086:8086"
            - "8090:8090"

 networks:
    kong_net:

2.测试过程

  1. 先安装测试机上的Docker环境
进入机器上,先执行如下命令:

apt-get update
apt-get upgrade
apt install docker.io
安装docker后,执行docker -v可查看版本号

再安装docker-compose 一般执行
https://get.daocloud.io  
这个网址里面的命令就可以,但是测试的机器报443 不得已解决,直接将docker-compose 拷贝到节点机器的/usr/local/bin 目录下 

进入docker_compose 目录下,执行 docker_compose up -d 命令启动promethus+grafana+influxdb容器

  • 由于jmeter需要将数据写入influxdb中,需要先创建好数据库,如下步骤:
    进入influxdb 容器中,创建数据库myDB 以便于jmeter写入数据
influxdb容器.png
  • 再需要先下载一个jmeter influxdb的插件,放到jmeter目录下的lib/ext目录下


    influxdb lib.png
  • jmeter 需要添加一个后置监听器


    image.png
  • 节点所在机器上需要启动node_exporter容器,监控节点资源,docker_compose文件内容如下:
version: '2'
  
services:
    node-exporter:
        image: prom/node-exporter
        container_name: node-exporter
        hostname: node-exporter
        restart: always
        ports:
            - "9100:9100"
    mysql:
        image: mysql:5.7
        container_name: mysql
        environment:
            MYSQL_ROOT_PASSWORD: "root"
            MYSQL_USER: 'test'
            MYSQL_PASS: 'root'
        restart: always
        volumes:
            - "./db:/var/lib/mysql"
            - "./conf/my.cnf:/etc/my.cnf"
            - "./init:/docker-entrypoint-initdb.d/"
        ports:
            - "3306:3306"
       

配置promethus.yaml 文件

global:
  scrape_interval: 15s  
scrape_configs:
  - job_name: 'node'
    static_configs:
      - targets: ['8.130.12.208:9100']
      - targets: ['8.130.8.46:9100'] 
     

grafana 容器启动起来后,使用浏览器打开 http://127.0.0.1:3000 会显示grafana界面,默认用户名和密码是admin/admin 。

进入grafana 界面后,先配置promethus数据源


image.png

再配置influxdb的数据源


image.png

infulxdb 需要配置事先创建好的数据库


image.png

再添加显示的模块,进入https://grafana.com/grafana/dashboards 查找需要的模板
有2种方式可以导入模板

image.png

1是直接上传下载好的json文件,2是再模板详情页面有一个id复制这个id 进行导入

image.png
  • 如何在外部使用root连接这个mysql? 为了安全,首先需要设置root帐号的密码,先将当前库切到mysql
mysql> use mysql
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed

10. 设置root账户的密码为root


mysql> update user set authentication_string = password('root') where user = 'root';
Query OK, 4 rows affected (0.00 sec)
Rows matched: 4  Changed: 4  Warnings: 0

11. 给所有root用户赋权,外部的电脑也能够通过root访问Docker中的mysql数据库
mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;
Query OK, 0 rows affected (0.00 sec)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,293评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,604评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,958评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,729评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,719评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,630评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,000评论 3 397
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,665评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,909评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,646评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,726评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,400评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,986评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,959评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,996评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,481评论 2 342

推荐阅读更多精彩内容