JMeterの負荷と均衡のTomcat + nginxのサーバー負荷の日記

JMeterマノメトリー

  1.Jmeter-5.1.1のダウンロード:http://mirror.bit.edu.cn/apache//jmeter/binaries/apache-jmeter-5.1.1.zip

  2.Jmeter-5.1.1-依存Java環境、(30K / s)を遅すぎるダウンロードするには、唯一のバージョンjava8の公式ウェブサイトをjava8以上をサポートするので、私はテンセントソフトウェアセンター(5M / s)をダウンロード

  3.java8解凍後、インストールするには、.exeファイルを実行して、環境変数の設定:CLASS_PATH後JAVA_HOME、PATHをして、cmdとjavacコマンドを実行し、エラーのセットアップは完了していません

  JMeterのは、/ binディレクトリにあるjmeter.bat、ファイル名を指定して実行]をクリックします。4.解凍は、ブラックボックスは、クライアントを起動するポップアップ表示します

            

 

  5.Jmeterのデフォルトの英語が、中国のサポート、[オプション設定]> [、言語を選択してください>中国

  起動時間(それはスレッドの最大数に達するまでにかかる時間)、(同時)スレッド数を設定し、テスト計画グループ内に新しいスレッド、準備ができて、サイクル数(複数の要求に長い時間を送信するために、各スレッドは、常に選択6それが発行されています)

 

  7.、スレッドグループ内のhttpリクエストを追加し、以下のように内容を記入

  

8.以下に示すように、リスナー、内圧測定の結果ウィンドウを見てと同等のものを選択し、添えものグラフィカルなレポートのすべての種類は、レポートを表示するための選択チャートの完了後、[実行]をクリックし、ストレステストを行うために、サーバーに始めました

 

Tomcatの+ nginxの負荷分散:

  1.出会うTomcatのサポートの唯一の正常な量のテストを行った後、200以上の同時は、もちろん、そのようなデフォルトのメモリ、同時デフォルトの額としてTomcatのデフォルト設定を変更することによって変更することができます。300のテストデータは、失敗した要求の20%を持っているので、Tomcatのクラスタリング効果に対処する方法を見てする必要がある場合には

  2.我搭建环境用的版本是:java8,Tomcat8.5.41解压版(下载:https://tomcat.apache.org/download-70.cgi),nginx-1.16.0(下载:http://nginx.org/en/download.html)

  3.首先保证java服务正常启动,解压tomcat,多复制几个,具体几个看需要;然后挨个该配置文件,第一步:打开/conf/server.xml配置文件修改其中的8005、8009、8080端口,这一步是保证多tomcat之前彼此不重复,第二步:打开/bin/shutdown.bat(停止tomcat)和/bin/startup.bat(运行tomcat),在第一行‘@echo off’下面新启一行,写入‘SET JAVA_HOME=C:\Program Files\Java\jdk1.8.0_191’,这一步是让tomcat能够找到Java环境,然后保存,第三步打开/bin/startup.bat以运行tomcat,打开浏览器测试tomcat是否运行成功。之后的tomcat都重复此操作。

  4.tomcat全部打开后,开始编辑nginx配置文件,打开/conf/nginx.conf,把配置文件改为如下内容,后保存。ip_hash表示Nginx会根据ip来给请求的用户分配tomcat,同一个用户将会被分配给同一个tomcat处理,解决了session保存问题,但是这样会导致请求分配不均匀。

  5.此时运行ngin.exe,就OK了。访问Nginx监听的端口,会发现请求安装配置文件正常的分配给各个tomcat,负载均衡就完成了

  6.当然nginx的功能远不止如此,此处只是单纯实现负载均衡,比如根据url用正则判断实现动静分离、其他的各项设置可以满足各种实际需求,nginx虽然小但功能还是挺强大的,贴一段配置文件详解:

运行用户
user nobody;
启动进程,通常设置成和cpu的数量相等
worker_processes 1;

全局错误日志及PID文件
error_log logs/error.log;
error_log logs/error.log notice;
error_log logs/error.log info;

pid logs/nginx.pid;
工作模式及连接数上限
events {
worker_connections 1024;#单个后台worker process进程的最大并发链接数
}
设定http服务器,利用它的反向代理功能提供负载均衡支持
http {
#设定mime类型,类型由mime.type文件定义
include mime.types;
default_type application/octet-stream;
#设定日志格式
#access_log logs/access.log main;
#sendfile 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件,对于普通应用,
#必须设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为 off,以平衡磁盘与网络I/O处理速度,降低系统的uptime.
sendfile on;
#tcp_nopush on;
#连接超时时间
#keepalive_timeout 0;
keepalive_timeout 65;
#服务器设置的最大上传文件大小
client_max_body_size 200m;
#开启gzip压缩
gzip on;
gzip_comp_level 2;
gzip_types text/css application/javascript application/json;
gzip_disable “MSIE [1-6].”;

#设定负载均衡的服务器列表
upstream collectionBackend {
#本机上的Squid开启7002端口
server 127.0.0.1:7002;
}

server {
#侦听80端口
listen 80;
#定义使用localhost访问
server_name localhost;

#默认值90s, nginx连接到后端服务器的连接超时时间
proxy_connect_timeout 90;

#设置了发送请求给upstream服务器的超时时间。超时设置不是为了整个发送期间,而是在两次write操作期间。如果超时后,upstream没有收到新的数据,nginx会关闭连接
proxy_send_timeout 90;

设置与代理服务器的读超时时间。它决定了nginx会等待多长时间来获得请求的响应。这个时间不是获得整个response的时间,而是两次reading操作的时间。
proxy_read_timeout 90;

nginx设置目录浏览及中文乱码问题解决方案:
#charset koi8-r;

#设定日志格式
#access_log logs/host.access.log main;

在这个location配置段中,如果URL请求“/public/logo.gif”,那么nginx将会在服务器上查找“F:/workspace/cloud/bv-frontend-dev/public/logo.gif”文件,即请求的URL中location后面的部分会被追加到alias指定的目录后面,而location后面的“/public”路径将会被自动丢弃。
location /public/ {
alias F:/workspace/cloud/bv-frontend-dev/public/;
}

location / {
#rewrite的主要功能是实现RUL地址的重定向
rewrite ‘^/simple/.*.(html)$’ /simple-index/simple.html last;

rewrite ‘^/simple/.*config.js$’ /simple-index/config.js last;

rewrite ‘^/simple/./custom/(.)’ /simple-index/custom/$1 last;

rewrite ‘^/simple/./api/(.)’ /api/$1 last;

rewrite ‘^/simple/custom/(.*)’ /simple-index/custom/$1 last;

rewrite ‘^/simple/api/(.*)’ /api/$1 last;

alias同上含义:
alias F:/workspace/bestvike/collection-handle/static/;
index index.html;
}

location /simple-index {
alias F:/workspace/bestvike/collection-handle/static/;
}

location /resources/ {
rewrite ‘^/resources/simple/(.*.html)$’ /simple-index/simple/$1 last;
alias F:/workspace/bestvike/collection-handle/static/simple/;
}

location /api/ {

proxy_set_header:允许重新定义或者添加发往后端服务器的请求头.该值可以包含文本、变量和它们的组合。在没有定义proxy_set_header时会继承之前定义的值。默认情况下,只有两个字段被重定义:proxy_set_header Host $proxy_host 和 proxy_set_header Connection close

proxy_set_header X-Real-IP $remote_addr;

proxy_set_header REMOTE-HOST $remote_addr;

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

proxy_pass URL,URL为要设置的被代理服务器的地址,包含传输协议、主机名称或IP地址加端口号、URI等要素。
proxy_pass http://collectionBackend/api/;
}

error_page:当发生错误的时候能够显示一个预定义的地址,实际上产生了一个内部跳转(internal redirect),当访问出现500、502、503、504的时候就能返回50x.html中的内容。同时我们也可以自己定义这种情况下的返回状态码。

error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}

   7.nginx常用的正则表达试

 

 

 

最后,今天因为一些原因没用给负载均衡测压,之后再补测

 

おすすめ

転載: www.cnblogs.com/bigdatadiary/p/10951313.html