jMeter-퀵 가이드
JMeter에 대해 자세히 알아보기 전에 먼저 모든 응용 프로그램 테스트와 관련된 몇 가지 전문 용어를 이해하겠습니다.
Performance Test−이 테스트는 주어진 인프라 구성에서 가능한 최상의 성능 기대치를 설정합니다. 또한 애플리케이션이 프로덕션에 들어가기 전에 변경해야하는 경우 테스트 프로세스 초기에 강조 표시됩니다.
Load Test −이 테스트는 기본적으로 작동하도록 설계된 최고 부하에서 시스템을 테스트하는 데 사용됩니다.
Stress Test −이 테스트는 리소스를 압도하여 시스템을 파괴하려는 시도입니다.
JMeter 란?
JMeter는 다양한 프로토콜 또는 기술에서 부하 테스트, 성능 지향 비즈니스 (기능) 테스트, 회귀 테스트 등을 수행 할 수있는 소프트웨어입니다.
Stefano MazzocchiApache Software Foundation의 JMeter의 최초 개발자였습니다. 그는 주로 Apache JServ (현재 Apache Tomcat 프로젝트라고 함)의 성능을 테스트하기 위해 작성했습니다. Apache는 나중에 GUI를 향상시키고 기능 테스트 기능을 추가하기 위해 JMeter를 재 설계했습니다.
JMeter는 Swing 그래픽 API를 사용하는 그래픽 인터페이스가있는 Java 데스크탑 애플리케이션입니다. 따라서 Java 가상 머신 (예 : Windows, Linux, Mac 등)을 허용하는 모든 환경 / 워크 스테이션에서 실행할 수 있습니다.
JMeter에서 지원하는 프로토콜은 다음과 같습니다.
웹-HTTP, HTTPS 사이트 '웹 1.0'웹 2.0 (ajax, flex 및 flex-ws-amf)
웹 서비스-SOAP / XML-RPC
JDBC 드라이버를 통한 데이터베이스
디렉토리-LDAP
JMS를 통한 메시징 지향 서비스
서비스-POP3, IMAP, SMTP
FTP 서비스
JMeter 기능
다음은 JMeter의 기능 중 일부입니다-
오픈 소스 소프트웨어이므로 자유롭게 사용할 수 있습니다.
간단하고 직관적 인 GUI가 있습니다.
JMeter는 웹-HTTP, HTTPS, SOAP, JDBC를 통한 데이터베이스, LDAP, JMS, 메일-POP3 등 다양한 서버 유형에 대한로드 및 성능 테스트를 수행 할 수 있습니다.
플랫폼에 독립적 인 도구입니다. Linux / Unix에서는 JMeter 쉘 스크립트를 클릭하여 JMeter를 호출 할 수 있습니다. Windows에서는 jmeter.bat 파일을 시작하여 호출 할 수 있습니다.
완전한 Swing 및 경량 구성 요소 지원이 있습니다 (미리 컴파일 된 JAR은 javax.swing. * 패키지를 사용함).
JMeter는 테스트 계획을 XML 형식으로 저장합니다. 즉, 텍스트 편집기를 사용하여 테스트 계획을 생성 할 수 있습니다.
전체 멀티 스레딩 프레임 워크를 사용하면 여러 스레드에서 동시 샘플링을 수행하고 별도의 스레드 그룹에서 여러 기능을 동시에 샘플링 할 수 있습니다.
확장 성이 뛰어납니다.
또한 응용 프로그램의 자동화 된 기능 테스트를 수행하는 데 사용할 수도 있습니다.
JMeter는 어떻게 작동합니까?
JMeter는 대상 서버에 요청을 보내는 사용자 그룹을 시뮬레이션하고 테이블, 그래프 등을 통해 대상 서버 / 애플리케이션의 성능 / 기능을 보여주는 통계를 반환합니다.
JMeter의 작동 방식을 설명하는 다음 그림을 살펴보십시오.
JMeter는 Java 용 프레임 워크이므로 첫 번째 요구 사항은 시스템에 JDK를 설치하는 것입니다.
시스템 요구 사항
JDK | 1.6 이상. |
---|---|
기억 | 최소 요구 사항이 없습니다. |
디스크 공간 | 최소 요구 사항이 없습니다. |
운영 체제 | 최소 요구 사항이 없습니다. |
1 단계 : Java 설치 확인
먼저 시스템에 Java가 설치되어 있는지 확인하십시오. 콘솔을 열고 다음 중 하나를 실행하십시오.java 작업중인 운영 체제에 기반한 명령.
OS | 직무 | 명령 |
---|---|---|
윈도우 | 명령 콘솔 열기 | c : \> 자바 버전 |
리눅스 | 명령 터미널 열기 | $ 자바 버전 |
맥 | 터미널 열기 | 컴퓨터 : ~ joseph $ java -version |
시스템에 Java가 설치되어있는 경우 작업중인 OS에 따라 적절한 출력을 얻을 수 있습니다.
OS | 산출 |
---|---|
윈도우 | 자바 버전 "1.7.0_25" Java (TM) SE 런타임 환경 (빌드 1.7.0_25-b15) Java HotSpot (TM) 64 비트 서버 VM (빌드 23.25-b01, 혼합 모드) |
리눅스 | 자바 버전 "1.7.0_25" Java (TM) SE 런타임 환경 (빌드 1.7.0_25-b15) Java HotSpot (TM) 64 비트 서버 VM (빌드 23.25-b01, 혼합 모드) |
맥 | 자바 버전 "1.7.0_25" Java (TM) SE 런타임 환경 (빌드 1.7.0_25-b15) Java HotSpot (TM) 64 비트 서버 VM (빌드 23.25-b01, 혼합 모드) |
Java가 설치되어 있지 않은 경우 www.oracle.com/technetwork/java/javase/downloads/index.html 에서 Java SDK (소프트웨어 개발 키트)를 설치하십시오 . 이 자습서에서는 Java 1.7.0_25를 설치 버전으로 가정합니다.
2 단계 : Java 환경 설정
설정 JAVA_HOME환경 변수를 사용하여 시스템에 Java가 설치된 기본 디렉토리 위치를 가리 킵니다. 예를 들면-
OS | 산출 |
---|---|
윈도우 | 환경 변수 JAVA_HOME을 C : \ Program Files \ Java \ jdk1.7.0_25로 설정합니다. |
리눅스 | 내보내기 JAVA_HOME = / usr / local / java-current |
맥 | export JAVA_HOME = / Library / Java / Home |
시스템 경로에 Java 컴파일러 위치를 추가합니다.
OS | 산출 |
---|---|
윈도우 | 문자열을 추가하십시오. C : \ Program Files \ Java \ jdk1.7.0_25 \ bin 시스템 변수의 끝인 Path. |
리눅스 | 내보내기 PATH = $ PATH : $ JAVA_HOME / bin / |
맥 | 필요하지 않음 |
다음을 사용하여 Java 설치 확인 java -version 위에서 설명한대로 명령.
3 단계 : JMeter 다운로드
최신 버전의 JMeter 다운로드 https://jmeter.apache.org/download_jmeter.cgi. 이 튜토리얼에서는 apache-jmeter-2.9를 다운로드 하여 C : \> JMeter 폴더에 복사했습니다.
디렉토리 구조는 다음과 같아야합니다.
- apache-jmeter-2.9
- apache-jmeter-2.9\bin
- apache-jmeter-2.9\docs
- apache-jmeter-2.9\extras
- apache-jmeter-2.9\lib\
- apache-jmeter-2.9\lib\ext
- apache-jmeter-2.9\lib\junit
- apache-jmeter-2.9\printable_docs
원하는 경우 상위 디렉토리 (예 : apache-jmeter-2.9)의 이름을 바꿀 수 있지만 하위 디렉토리 이름은 변경하지 마십시오.
4 단계 : JMeter 실행
JMeter를 다운로드 한 후 bin 디렉토리 로 이동합니다 . 이 경우/home/manisha/apache-jmeter-2.9/bin. 이제 다음을 클릭하십시오-
OS | 산출 |
---|---|
윈도우 | jmeter.bat |
리눅스 | jmeter.sh |
맥 | jmeter.sh |
잠시 후, 다음 스크린 샷과 같이 Swing 애플리케이션 인 JMeter GUI가 나타납니다.
이것은 도구의 기본 페이지이자 기본 페이지입니다.
테스트 계획이란 무엇입니까?
테스트 계획은 테스트 실행을위한 컨테이너로 볼 수 있습니다. 무엇을 테스트하고 어떻게해야하는지 정의합니다. 전체 테스트 계획은 스레드 그룹, 로직 컨트롤러, 샘플 생성 컨트롤러, 리스너, 타이머, 어설 션 및 구성 요소와 같은 하나 이상의 요소로 구성됩니다. 테스트 계획에는 스레드 그룹이 하나 이상 있어야합니다.
테스트 계획 작성
아래 단계에 따라 테스트 계획을 작성하십시오.
1 단계 : JMeter 창 시작
클릭하여 JMeter 창을 엽니 다. /home/manisha/apache-jmeter-2.9/bin/jmeter.sh. JMeter 창이 아래와 같이 나타납니다.
이것은 추가 요소가 추가되지 않은 평범하고 빈 JMeter 창입니다. 그것은 두 개의 노드를 포함합니다-
Test Plan node − 실제 테스트 계획이 보관되는 곳입니다.
Workbench node− 단순히 복사 / 붙여 넣기를 위해 사용하지 않는 동안 테스트 요소를 임시로 저장할 수있는 공간을 제공합니다. 테스트 계획을 저장할 때 워크 벤치 항목은 함께 저장되지 않습니다.
2 단계 : 요소 추가 / 제거
테스트 계획 노드를 마우스 오른쪽 버튼으로 클릭하고 "추가"목록에서 새 요소를 선택하여 요소 (다음 장 테스트 계획 요소에서 설명 )를 테스트 계획에 추가 할 수 있습니다.
또는 파일에서 요소를로드하고 "병합"또는 "열기"옵션을 선택하여 추가 할 수 있습니다.
예를 들어, 아래와 같이 테스트 계획에 스레드 그룹 요소를 추가해 보겠습니다.
요소를 제거하려면 요소가 선택되었는지 확인하고 요소를 마우스 오른쪽 버튼으로 클릭 한 다음 "제거"옵션을 선택하십시오.
3 단계 : 요소로드 및 저장
파일에서 요소를로드하려면-
- 로드 된 요소를 추가하려는 기존 트리 요소를 마우스 오른쪽 버튼으로 클릭합니다.
- 병합을 선택합니다.
- 요소를 저장 한 파일을 선택하십시오.
- JMeter는 요소를 트리에 병합합니다.
기본적으로 JMeter는 요소를 저장하지 않으므로 명시 적으로 저장해야합니다.
트리 요소를 저장하려면-
- 요소를 마우스 오른쪽 버튼으로 클릭합니다.
- 다른 이름으로 선택 저장 ... 옵션을 선택합니다.
JMeter는 선택된 요소와 그 아래에있는 모든 자식 요소를 저장합니다. 기본적으로 JMeter는 요소를 저장하지 않으므로 앞서 언급 한대로 명시 적으로 저장해야합니다.
4 단계 : 트리 요소 구성
테스트 계획의 모든 요소는 JMeter의 오른쪽 프레임에있는 컨트롤을 사용하여 구성 할 수 있습니다. 이러한 컨트롤을 사용하면 특정 테스트 요소의 동작을 구성 할 수 있습니다. 예를 들어 스레드 그룹은 아래와 같이 여러 사용자, 램프 업 기간 등에 대해 구성 할 수 있습니다.
5 단계 : 테스트 계획 저장
다음 중 하나를 사용하여 전체 테스트 계획을 저장할 수 있습니다. Save 또는 "Save Test Plan As ..." 파일 메뉴에서.
6 단계 : 테스트 계획 실행
클릭하여 테스트 계획을 실행할 수 있습니다. Start(Ctrl + r) Run메뉴 아이템. JMeter가 실행을 시작하면 메뉴 바 바로 아래 섹션의 오른쪽 끝에 작은 녹색 상자가 표시됩니다.
녹색 상자 왼쪽에있는 숫자는 활성 스레드 수 / 총 스레드 수입니다. 이는 로컬에서 실행되는 테스트에만 적용됩니다. 클라이언트-서버 모드를 사용할 때 원격 시스템에서 시작된 스레드는 포함되지 않습니다.
7 단계 : 테스트 계획 중지
두 가지 방법으로 테스트를 중지 할 수 있습니다.
사용 Stop(Ctrl + '.'). 가능한 경우 즉시 스레드를 중지합니다.
사용 Shutdown(Ctrl + ','). 현재 작업이 끝나면 스레드가 중지되도록 요청합니다.
JMeter 테스트 계획은 아래에서 설명하는 테스트 요소로 구성됩니다. 테스트 계획은 하나 이상의 스레드 그룹으로 구성됩니다. 각 스레드 그룹 내에서 샘플러, 로직 컨트롤러, 구성 요소, 리스너 및 타이머와 같은 다른 요소 중 하나 이상의 조합을 배치 할 수 있습니다. 각 샘플러 앞에는 하나 이상의 전 처리기 요소, 후 처리기 요소 및 / 또는 어설 션 요소가 올 수 있습니다. 이러한 각 요소를 자세히 살펴 보겠습니다.
스레드 그룹
스레드 그룹 요소는 테스트 계획의 시작점입니다. 이름에서 알 수 있듯이 스레드 그룹 요소는 JMeter가 테스트 중에 사용할 스레드 수를 제어합니다. 스레드 그룹을 통해 다음을 제어 할 수도 있습니다.
스레드 수 설정
램프 업 시간 설정
테스트 반복 횟수 설정
스레드 그룹 제어판은 다음과 같습니다.
스레드 그룹 패널에는 다음 구성 요소가 있습니다.
Action to be taken after a Sampler error − 테스트 실행 중 오류가 발생하는 경우 테스트를 허용 할 수 있습니다. −
Continue 테스트의 다음 요소로
Stop Thread 현재 스레드를 중지합니다.
Stop Test 완전히 실행하기 전에 오류를 검사하려는 경우
Number of Threads − 서버 응용 프로그램에 대한 사용자 또는 연결 수를 시뮬레이션합니다.
Ramp-Up Period JMeter가 모든 스레드를 실행하는 데 걸리는 시간을 정의합니다.
Loop Count − 테스트를 실행할 횟수를 정의합니다.
Scheduler checkbox − 선택하면 제어판 하단에 스케줄러 구성 섹션이 나타납니다.
Scheduler Configuration − 테스트 시작 및 종료 시간을 설정할 수 있습니다.
컨트롤러
JMeter에는 샘플러 와 로직 컨트롤러 의 두 가지 유형의 컨트롤러가 있습니다.
샘플러
샘플러를 사용하면 JMeter가 특정 유형의 요청을 서버에 보낼 수 있습니다. 대상 서버의 페이지에 대한 사용자 요청을 시뮬레이션합니다. 예를 들어 HTTP 서비스에서 POST, GET 또는 DELETE를 수행해야하는 경우 HTTP 요청 샘플러를 추가 할 수 있습니다.
유용한 샘플러는 다음과 같습니다.
- HTTP 요청
- FTP 요청
- JDBC 요청
- 자바 요청
- SOAP / XML 요청
- RPC 요청
다음 스크린 샷은 HTTP 요청 샘플러 제어판을 보여줍니다.
로직 컨트롤러
로직 컨트롤러를 사용하면 스레드에서 샘플러의 처리 순서를 제어 할 수 있습니다. 논리 컨트롤러는 자식 요소에서 오는 요청의 순서를 변경할 수 있습니다. 예를 들면 ForEach 컨트롤러, While 컨트롤러, 루프 컨트롤러, IF 컨트롤러, 런타임 컨트롤러, 인터리브 컨트롤러, 처리량 컨트롤러 및 한 번 실행 컨트롤러입니다.
다음 스크린 샷은 루프 컨트롤러 제어판을 보여줍니다.
다음 목록은 JMeter가 제공하는 모든 로직 컨트롤러로 구성되어 있습니다.
- 간단한 컨트롤러
- 루프 컨트롤러
- 한 번만 컨트롤러
- 인터리브 컨트롤러
- 랜덤 컨트롤러
- 랜덤 오더 컨트롤러
- 처리량 컨트롤러
- 런타임 컨트롤러
- 컨트롤러
- 컨트롤러 동안
- 스위치 컨트롤러
- ForEach 컨트롤러
- 모듈 컨트롤러
- 컨트롤러 포함
- 거래 컨트롤러
- 녹음 컨트롤러
조각 테스트
테스트 조각은 스레드 그룹 요소와 동일한 수준에 배치 된 특수 유형의 요소입니다. 모듈 컨트롤러 또는 Include_Controller에서 참조하지 않는 한 실행되지 않는다는 점에서 스레드 그룹과 구별됩니다. 이 요소는 순전히 테스트 계획 내에서 코드 재사용을위한 것입니다.
청취자
리스너를 사용하면 일부 로그 파일에서 테이블, 그래프, 트리 또는 간단한 텍스트의 형태로 샘플러의 결과를 볼 수 있습니다. JMeter의 샘플러 구성 요소가 실행될 때 테스트 케이스에 대해 JMeter에서 수집 한 데이터에 대한 시각적 액세스를 제공합니다.
리스너는 테스트 계획 바로 아래를 포함하여 테스트의 모든 위치에 추가 할 수 있습니다. 해당 수준 이하의 요소에서만 데이터를 수집합니다. 다음 목록은 JMeter가 제공하는 모든 리스너로 구성됩니다-
- 샘플 결과 저장 구성
- 전체 결과 그래프
- 그래프 결과
- 스플라인 시각화 도우미
- 어설 션 결과
- 결과 트리보기
- 집계 보고서
- 표에서 결과보기
- 단순 데이터 작성기
- 결과 모니터링
- 분포 그래프 (알파)
- 집계 그래프
- 메일러 시각화 도우미
- BeanShell 리스너
- 요약 보고서
타이머
기본적으로 JMeter 스레드는 각 샘플러간에 일시 중지하지 않고 요청을 보냅니다. 이것은 당신이 원하는 것이 아닐 수도 있습니다. 각 요청 사이에 대기 할 기간을 정의 할 수있는 타이머 요소를 추가 할 수 있습니다.
다음 목록은 JMeter가 제공하는 모든 타이머를 보여줍니다-
- 일정 타이머
- 가우스 랜덤 타이머
- 균일 랜덤 타이머
- 일정한 처리량 타이머
- 타이머 동기화
- JSR223 시간
- BeanShell 시간
- BSF 시간
- 푸 아송 임의 시간
다음 스크린 샷은 Constant Timer Control Panel을 보여줍니다.
어설 션
어설 션을 사용하면 샘플러를 사용하여 만든 요청의 응답에 대한 일부 유효성 검사 테스트를 포함 할 수 있습니다. 어설 션을 사용하면 애플리케이션이 올바른 데이터를 반환하고 있음을 증명할 수 있습니다. JMeter는 어설 션이 실패하면 강조 표시됩니다.
다음 목록은 JMeter가 제공하는 모든 주장으로 구성되어 있습니다.
- 빈쉘 어설 션
- BSF 어설 션
- 어설 션 비교
- JSR223 어설 션
- 응답 주장
- 기간 어설 션
- 크기 주장
- XML 어설 션
- BeanShell 어설 션
- MD5Hex 어설 션
- HTML 어설 션
- XPath 어설 션
- XML 스키마 어설 션
다음 스크린 샷은 Response Assertion Control Panel을 보여줍니다.
구성 요소
구성 요소를 사용하면 샘플러에서 사용할 기본값과 변수를 만들 수 있습니다. 샘플러의 요청을 추가하거나 수정하는 데 사용됩니다.
동일한 범위에있는 샘플러보다 먼저 해당 범위의 시작 부분에서 실행됩니다. 따라서 구성 요소는 배치 된 분기 내부에서만 액세스됩니다.
다음 목록은 JMeter가 제공하는 모든 구성 요소로 구성되어 있습니다.
- Counter
- CSV 데이터 세트 구성
- FTP 요청 기본값
- HTTP 인증 관리자
- HTTP 캐시 관리자
- HTTP 쿠키 관리자
- HTTP 프록시 서버
- HTTP 요청 기본값
- HTTP 헤더 관리자
- Java 요청 기본값
- 키 저장소 구성
- JDBC 연결 구성
- 로그인 구성 요소
- LDAP 요청 기본값
- LDAP 확장 요청 기본값
- TCP 샘플러 구성
- 사용자 정의 변수
- 단순 구성 요소
- 랜덤 변수
전 처리기 요소
전 처리기 요소는 샘플러가 실행되기 직전에 실행되는 요소입니다. 샘플 요청이 실행되기 직전에 설정을 수정하거나 응답 텍스트에서 추출되지 않은 변수를 업데이트하는 데 자주 사용됩니다.
다음 목록은 JMeter가 제공하는 모든 전 처리기 요소로 구성되어 있습니다.
- HTML 링크 파서
- HTTP URL 재 작성 수정 자
- HTTP 사용자 매개 변수 수정 자
- 사용자 매개 변수
- JDBC 전 처리기
- JSR223 전 처리기
- RegEx 사용자 매개 변수
- BeanShell 전 처리기
- BSF 전 처리기
포스트 프로세서 요소
포스트 프로세서는 샘플러가 실행을 마친 후에 실행됩니다. 이 요소는 예를 들어 나중에 사용할 특정 값을 검색하기 위해 응답 데이터를 처리하는 데 가장 자주 사용됩니다.
다음 목록은 JMeter가 제공하는 모든 포스트 프로세서 요소로 구성되어 있습니다.
- 정규식 추출기
- XPath 추출기
- 결과 상태 작업 처리기
- JSR223 포스트 프로세서
- JDBC 포스트 프로세서
- BSF 포스트 프로세서
- CSS / JQuery 추출기
- BeanShell 포스트 프로세서
- 포스트 프로세서 디버그
테스트 요소의 실행 순서
다음은 테스트 계획 요소의 실행 순서입니다.
- 구성 요소
- Pre-Processors
- Timers
- Sampler
- 포스트 프로세서 (SampleResult가 null 인 경우 제외)
- 어설 션 (SampleResult가 널이 아닌 경우)
- 리스너 (SampleResult가 널이 아닌 경우)
웹 페이지를 테스트하는 간단한 테스트 계획을 세워 보겠습니다. Apache JMeter로 테스트 계획을 작성하여 URL www.tutorialspoint.com에 표시된 웹 페이지의 성능을 테스트 할 수 있습니다 .
JMeter 시작
클릭하여 JMeter 창을 엽니 다. /home/manisha/apache-jmeter-2.9/bin/jmeter.sh. JMeter 창이 아래와 같이 나타납니다.
테스트 계획 이름 변경
이름 텍스트 상자 에서 테스트 계획 노드의 이름을 Sample Test 로 변경하십시오 . 워크 벤치 노드로 초점을 변경하고 테스트 계획 노드로 돌아가 이름이 반영되는지 확인해야합니다.
스레드 그룹 추가
이제 창에 첫 번째 요소를 추가합니다. 샘플러, 컨트롤러 및 리스너와 같은 다른 모든 요소에 대한 자리 표시자인 스레드 그룹 하나를 추가합니다. 시뮬레이션 할 사용자 수를 구성하려면 하나가 필요합니다.
JMeter에서 모든 노드 요소는 컨텍스트 메뉴를 사용하여 추가됩니다.
하위 요소 노드를 추가 할 요소를 마우스 오른쪽 버튼으로 클릭합니다.
추가 할 적절한 옵션을 선택하십시오.
샘플 테스트 (테스트 계획) → 추가 → 스레드 (사용자) → 스레드 그룹을 마우스 오른쪽 버튼으로 클릭합니다. 따라서 스레드 그룹은 테스트 계획 (샘플 테스트) 노드 아래에 추가됩니다.
스레드 그룹의 이름을 Users로 지정 합니다. 우리에게이 요소는 TutorialsPoint 홈 페이지를 방문하는 사용자를 의미합니다.
샘플러 추가
스레드 그룹 (사용자)에 하나의 샘플러를 추가해야합니다. 스레드 그룹을 추가하기 위해 앞서 수행 한 것처럼 이번에는 마우스 오른쪽 버튼을 클릭하여 스레드 그룹 (사용자) 노드의 컨텍스트 메뉴를 열고 추가 → 샘플러 → HTTP 요청 옵션을 선택하여 HTTP 요청 샘플러를 추가합니다.
스레드 그룹 (사용자) 노드 아래에 하나의 빈 HTTP 요청 샘플러를 추가합니다. 이 노드 요소를 구성 해 보겠습니다.
Name− 우리가 달성하고자하는 행동을 반영하기 위해 이름을 변경할 것입니다. 우리는 이름을Visit TutorialsPoint Home Page
Server Name or IP− 여기에 웹 서버 이름을 입력해야합니다. 우리의 경우에는www.tutorialspoint.com. (http : // 부분은 작성되지 않았습니다. 이것은 서버의 이름 또는 IP 일뿐입니다.)
Protocol −이 항목을 비워두면 HTTP를 프로토콜로 사용합니다.
Path− 경로를 / (슬래시)로 입력합니다. 그것은 우리가 서버의 루트 페이지를 원한다는 것을 의미합니다.
리스너 추가
이제 리스너를 추가합니다. Thread Group (User) 노드 아래에 View Results Tree Listener를 추가하겠습니다. 샘플러의 결과를이 리스너 노드 요소에서 볼 수 있도록합니다.
청취자를 추가하려면-
컨텍스트 메뉴 열기
스레드 그룹 (사용자)을 마우스 오른쪽 단추로 클릭하십시오.
추가 → 리스너 → 결과 트리보기 옵션을 선택합니다.
테스트 계획 실행
이제 모든 설정을 마쳤으므로 테스트 계획을 실행하겠습니다. 스레드 그룹 (사용자)의 구성으로 모든 기본값을 유지합니다. 이는 JMeter가 샘플러를 한 번만 실행 함을 의미합니다. 단일 사용자와 비슷하지만 한 번만 있습니다.
이것은 JMeter 샘플러를 사용하여 브라우저를 통해 웹 페이지를 방문하는 사용자와 유사합니다. 테스트 계획을 실행하려면 메뉴에서 실행을 선택하고 시작 옵션을 선택하십시오.
Apache JMeter는 실제로 테스트를 시작하기 전에 테스트 계획을 디스크 파일에 저장하도록 요청합니다. 테스트 계획을 여러 번 실행하려는 경우 중요합니다. 저장하지 않고 실행할 수도 있습니다.
출력보기
스레드 그룹의 설정을 단일 스레드 (한 명의 사용자 만 해당) 및 1 회 루프 (한 번만 실행)로 유지 했으므로 View Result Tree Listener에서 단일 트랜잭션의 결과를 얻습니다.
위 결과의 세부 사항은-
Visit TutorialsPoint Home Page 라는 이름에 대한 녹색 은 성공을 나타냅니다.
JMeter는 웹 서버에서 보낸 모든 헤더와 응답을 저장했으며 다양한 방법으로 결과를 보여줄 준비가되어 있습니다.
첫 번째 탭은 샘플러 결과입니다. JMeter 데이터와 웹 서버가 반환 한 데이터를 보여줍니다.
두 번째 탭은 요청의 일부로 웹 서버에 전송 된 모든 데이터를 표시하는 요청입니다.
마지막 탭은 응답 데이터입니다. 이 탭에서 리스너는 서버에서받은 데이터를 텍스트 형식으로 표시합니다.
이것은 하나의 요청 만 실행하는 간단한 테스트 계획입니다. 그러나 JMeter의 진정한 강점은 많은 사용자가 보내는 것처럼 동일한 요청을 보내는 것입니다. 여러 사용자가있는 웹 서버를 테스트하려면 스레드 그룹 (사용자) 설정을 변경해야합니다.
이 장에서는 데이터베이스 서버를 테스트하기위한 간단한 테스트 계획을 만드는 방법을 살펴 봅니다. 테스트 목적으로 MYSQL 데이터베이스 서버를 사용합니다. 테스트를 위해 다른 데이터베이스를 사용할 수 있습니다. MYSQL에서의 설치 및 테이블 생성에 대해서는 MYSQL Tutorial을 참조하십시오 .
MYSQL이 설치되면 아래 단계에 따라 데이터베이스를 설정하십시오.
이름이 "tutorial"인 데이터베이스를 작성하십시오.
tutorials_tbl 테이블을 만듭니다 .
아래와 같이 tutorials_tbl에 레코드를 삽입하십시오 -
mysql> use TUTORIALS;
Database changed
mysql> INSERT INTO tutorials_tbl
->(tutorial_title, tutorial_author, submission_date)
->VALUES
->("Learn PHP", "John Poul", NOW());
Query OK, 1 row affected (0.01 sec)
mysql> INSERT INTO tutorials_tbl
->(tutorial_title, tutorial_author, submission_date)
->VALUES
->("Learn MySQL", "Abdul S", NOW());
Query OK, 1 row affected (0.01 sec)
mysql> INSERT INTO tutorials_tbl
->(tutorial_title, tutorial_author, submission_date)
->VALUES
->("JAVA Tutorial", "Sanjay", '2007-05-06');
Query OK, 1 row affected (0.01 sec)
mysql>
적절한 JDBC 드라이버를 다음 위치에 복사하십시오. /home/manisha/apache-jmeter-2.9/lib.
JMeter 테스트 계획 생성
JMeter를 시작하겠습니다. /home/manisha/apache-jmeter-2.9/bin/jmeter.sh.
사용자 추가
스레드 그룹을 생성하려면
테스트 계획을 마우스 오른쪽 버튼으로 클릭합니다.
추가 → 스레드 (사용자) → 스레드 그룹을 선택합니다.
따라서 스레드 그룹은 테스트 계획 노드 아래에 추가됩니다.
이 스레드 그룹의 이름을 JDBC 사용자 로 바꿉니다 .
스레드 그룹의 기본 속성은 변경하지 않습니다.
JDBC 요청 추가
이제 사용자를 정의 했으므로 사용자가 수행 할 작업을 정의해야합니다. 이 섹션에서 수행 할 JDBC 요청을 지정합니다.
JDBC 사용자 요소를 마우스 오른쪽 단추로 클릭하십시오.
고르다 Add → Config Element → JDBC Connection Configuration.
다음 필드를 설정합니다 (튜토리얼이라는 MySQL 데이터베이스를 사용하고 있습니다)-
풀에 바인딩 된 변수 이름입니다. 구성을 고유하게 식별해야합니다. JDBC 샘플러에서 사용할 구성을 식별하는 데 사용됩니다. 우리는 그것을 test 라고 명명했습니다 .
데이터베이스 URL-jdbc : mysql : // localhost : 3306 / tutorial.
JDBC 드라이버 클래스 : com.mysql.jdbc.Driver.
사용자 이름 : 루트.
비밀번호 : 루트의 비밀번호입니다.
화면의 다른 필드는 아래와 같이 기본값으로 남아 있습니다.
이제 위에서 정의한 JDBC 구성 풀을 참조하는 JDBC 요청을 추가하십시오. JDBC 사용자 요소를 선택하십시오.
마우스 오른쪽 버튼을 클릭하여 추가 메뉴를 가져옵니다.
고르다 Add → Sampler → JDBC Request.
제어판을 보려면이 새 요소를 선택하십시오.
아래와 같이 속성을 편집하십시오-
풀에 바인딩 된 변수 이름입니다. 구성을 고유하게 식별해야합니다. JDBC 샘플러에서 사용할 구성을 식별하는 데 사용됩니다. test 로 명명했습니다 .
이름-배우다.
풀 이름-테스트를 입력하십시오 (구성 요소에서와 동일).
쿼리 유형-선택 문.
SQL 쿼리 문자열 필드를 입력합니다.
리스너 생성
이제 Listener 요소를 추가하십시오. 이 요소는 JDBC 요청의 모든 결과를 파일에 저장하고 데이터의 시각적 모델을 제공합니다.
JDBC 사용자 요소를 선택하십시오.
View Results Tree 리스너 (Add → Listener → View Results Tree).
테스트 계획 저장 및 실행
이제 위의 테스트 계획을 db_test.jmx 로 저장합니다 . 다음을 사용하여이 테스트 계획 실행Run → Start 선택권.
출력 확인
마지막 이미지에서 두 개의 레코드가 선택되었음을 알 수 있습니다.
이 장에서는 JMeter를 사용하여 FTP 사이트를 테스트하는 방법을 살펴 봅니다. FTP 사이트를 테스트하기위한 테스트 계획을 작성하겠습니다.
테스트 계획 이름 변경
/home/manisha/apache-jmeter-2.9/bin/jmeter.sh를 클릭하여 JMeter 창을 엽니 다.
테스트 계획 노드를 클릭하십시오.
이 테스트 계획 노드의 이름을 TestFTPSite로 바꿉니다.
스레드 그룹 추가
샘플러, 컨트롤러 및 리스너와 같은 다른 모든 요소의 자리 표시자인 스레드 그룹 하나를 추가합니다.
TestFTPSite (테스트 계획)를 마우스 오른쪽 버튼으로 클릭합니다.
추가 → 스레드 (사용자) → 스레드 그룹을 선택합니다. 스레드 그룹은 테스트 계획 (TestFTPSite) 노드 아래에 추가됩니다.
다음과 같이 테스트에 적합하도록 스레드 그룹의 기본 속성을 수정합니다.
Name − FTP 사용자
Number of Threads (Users) − 4
Ramp-Up Period − 기본값 인 0 초를 그대로 둡니다.
Loop Count − 1
샘플러 추가-FTP 요청
이제 사용자를 정의 했으므로 수행 할 작업을 정의 할 차례입니다. FTP 요청 요소를 추가합니다. 두 개의 FTP 요청 요소를 추가합니다. 하나는 파일을 검색하고 다른 하나는 ftp 사이트에 파일을 저장합니다.
FTP 사용자 요소를 선택하십시오.
마우스 오른쪽 버튼을 클릭하면 추가 메뉴가 나타납니다.
추가 → 샘플러 → FTP 요청을 선택합니다.
트리에서 FTP 요청 요소를 선택하십시오.
아래와 같이 다음 속성을 편집하십시오-
이 요소에는 다음 세부 정보가 입력됩니다.
Name − FTP 요청 가져 오기
Server Name or IP − 184.168.74.29
Remote File − /home/manisha/sample_ftp.txt
Local File − sample_ftp.txt
get (RETR) 선택
Username − 마니 샤
Password − manisha123
이제 위와 같이 다른 FTP 요청을 추가하고 다음 스크린 샷과 같이 속성을 편집합니다.
이 요소에는 다음 세부 정보가 입력됩니다.
Name − FTP 요청 넣기
Server Name or IP − 184.168.74.29
Remote File − /home/manisha/examplefile.txt
Local File − /home/manisha/work/examplefile.txt
풋 선택 (STOR)
Username − 마니 샤
Password − manisha123
리스너 추가
테스트 계획에 추가해야하는 마지막 요소는 리스너입니다. 이 요소는 FTP 요청의 모든 결과를 파일에 저장하고 데이터의 시각적 모델을 표시합니다.
FTP 사용자 요소를 선택하십시오.
추가> 리스너> 결과 트리보기를 선택하여 결과 트리보기 리스너를 추가하십시오.
테스트 계획 실행
이제 위의 테스트 계획을 ftpsite_test.jmx 로 저장합니다 . 다음을 사용하여이 테스트 계획 실행Run → Start 선택권.
출력보기
다음 출력은 리스너에서 볼 수 있습니다.
각 FTP 요청에 대해 4 개의 요청이 작성되고 테스트가 성공한 것을 볼 수 있습니다. GET 요청을 위해 검색된 파일은 / bin 폴더에 저장됩니다. 우리의 경우에는/home/manisha/apache-jmeter-2.9/bin/. PUT 요청의 경우 파일이 경로에 업로드됩니다./home/manisha/.
이 장에서는 웹 서비스를 테스트하기위한 테스트 계획을 작성하는 방법을 배웁니다. 테스트 목적으로 간단한 웹 서비스 프로젝트를 만들어 Tomcat 서버에 로컬로 배포했습니다.
웹 서비스 프로젝트 만들기
웹 서비스 프로젝트를 만들기 위해 Eclipse IDE를 사용했습니다. 먼저 서비스 엔드 포인트 인터페이스 작성HelloWorld 패키지 아래 com.tutorialspoint.ws. HelloWorld.java의 내용은 다음과 같습니다.
package com.tutorialspoint.ws;
import javax.jws.WebMethod;
import javax.jws.WebService;
import javax.jws.soap.SOAPBinding;
import javax.jws.soap.SOAPBinding.Style;
//Service Endpoint Interface
@WebService
@SOAPBinding(style = Style.RPC)
public interface HelloWorld {
@WebMethod String getHelloWorldMessage(String string);
}
이 서비스에는 방법이 있습니다 getHelloWorldMessage String 매개 변수를받습니다.
다음으로 구현 클래스를 만듭니다. HelloWorldImpl.java 패키지 아래 com.tutorialspoint.ws.
package com.tutorialspoint.ws;
import javax.jws.WebService;
@WebService(endpointInterface="com.tutorialspoint.ws.HelloWorld")
public class HelloWorldImpl implements HelloWorld {
@Override
public String getHelloWorldMessage(String myName) {
return("Hello "+myName+" to JAX WS world");
}
}
이제 끝점 게시자를 만들고 서버에 서비스를 노출하여이 웹 서비스를 로컬로 게시하겠습니다.
게시 방법은 두 개의 매개 변수를 사용합니다.
끝점 URL 문자열.
구현 자 객체 (이 경우 HelloWorld 구현 클래스)는 위의 매개 변수에 언급 된 URL로 식별되는 끝점에서 웹 서비스로 노출됩니다.
HelloWorldPublisher.java의 내용은 다음과 같습니다.
package com.tutorialspoint.endpoint;
import javax.xml.ws.Endpoint;
import com.tutorialspoint.ws.HelloWorldImpl;
public class HelloWorldPublisher {
public static void main(String[] args) {
Endpoint.publish("http://localhost:9000/ws/hello", new HelloWorldImpl());
}
}
아래와 같이 web.xml 내용을 수정하십시오-
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE web-app PUBLIC "-//Sun Microsystems,
Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/j2ee/dtds/web-app_2_3.dtd">
<web-app>
<listener>
<listener-class>
com.sun.xml.ws.transport.http.servlet.WSServletContextListener
</listener-class>
</listener>
<servlet>
<servlet-name>hello</servlet-name>
<servlet-class>com.sun.xml.ws.transport.http.servlet.WSServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>hello</servlet-name>
<url-pattern>/hello</url-pattern>
</servlet-mapping>
<session-config>
<session-timeout>120</session-timeout>
</session-config>
</web-app>
이 애플리케이션을 웹 서비스로 배포하려면 다른 구성 파일이 필요합니다. sun-jaxws.xml. 이 파일의 내용은 다음과 같습니다.
<?xml version = "1.0" encoding = "UTF-8"?>
<endpoints
xmlns = "http://java.sun.com/xml/ns/jax-ws/ri/runtime"
version = "2.0">
<endpoint name = "HelloWorld"
implementation = "com.tutorialspoint.ws.HelloWorldImpl"
url-pattern = "/hello"/>
</endpoints>
이제 모든 파일이 준비되었으므로 디렉토리 구조는 다음 스크린 샷과 같이 보일 것입니다.
이제이 애플리케이션의 WAR 파일을 만듭니다.
프로젝트 선택 → 마우스 오른쪽 버튼 클릭 → 내보내기 → WAR 파일.
이것을 다른 이름으로 저장 hello.war 아래에 파일 webapps Tomcat 서버의 폴더.
이제 Tomcat 서버를 시작하십시오.
서버가 시작되면 URL http : // localhost : 8080 / hello / hello를 사용하여 웹 서비스에 액세스 할 수 있습니다.
JMeter 테스트 계획 생성
이제 위의 웹 서비스를 테스트하기위한 테스트 계획을 작성하겠습니다.
테스트 계획 이름 변경
/home/manisha/apache-jmeter2.9/bin/jmeter.sh를 클릭하여 JMeter 창을 엽니 다.
테스트 계획 노드를 클릭하십시오.
이 테스트 계획 노드의 이름을 WebserviceTest로 바꿉니다.
스레드 그룹 추가
샘플러, 컨트롤러 및 리스너와 같은 다른 모든 요소의 자리 표시자인 스레드 그룹 하나를 추가합니다.
WebserviceTest (테스트 계획) → 추가 → 스레드 (사용자) → 스레드 그룹을 마우스 오른쪽 버튼으로 클릭합니다. 스레드 그룹은 테스트 계획 (WebserviceTest) 노드 아래에 추가됩니다.
다음으로 테스트에 맞게 스레드 그룹의 기본 속성을 수정 해 보겠습니다. 다음 속성이 변경됩니다-
Name − 웹 서비스 사용자
Number of Threads (Users) − 2
Ramp-Up Period − 기본값 인 0 초를 그대로 둡니다.
Loop Count − 2
샘플러 추가-SOAP / XML-RPC 요청
사용자를 정의 했으므로 이제 수행 할 작업을 정의 할 차례입니다.
SOAP / XML-RPC 요청 요소를 추가합니다.
마우스 오른쪽 버튼을 클릭하면 추가 메뉴가 나타납니다.
추가 → 샘플러 → SOAP / XML-RPC 요청을 선택합니다.
트리에서 SOAP / XML-RPC 요청 요소를 선택하십시오.
아래 이미지와 같이 다음 속성을 편집하십시오-
이 요소에는 다음 세부 정보가 입력됩니다.
Name − SOAP/XML-RPC Request
URL − http : // localhost : 8080 / hello / hello? wsdl
Soap/XML-RPC Data − 아래 내용 입력
<soapenv:Envelope xmlns:soapenv = "http://schemas.xmlsoap.org/soap/envelope/"
xmlns:web = "http://ws.tutorialspoint.com/">
<soapenv:Header/>
<soapenv:Body>
<web:getHelloWorldMessage>
<arg0>Manisha</arg0>
</web:getHelloWorldMessage>
</soapenv:Body>
</soapenv:Envelope>
리스너 추가
테스트 계획에 추가해야하는 마지막 요소는 리스너입니다. 이 요소는 HTTP 요청의 모든 결과를 파일에 저장하고 데이터의 시각적 모델을 표시합니다.
웹 서비스 사용자 요소를 선택하십시오.
추가 → 리스너 → 결과 트리보기를 선택하여 결과 트리보기 리스너를 추가하십시오.
테스트 계획 실행
이제 위의 테스트 계획을 test_webservice.jmx 로 저장합니다 . 실행 → 시작 옵션을 사용하여이 테스트 계획을 실행하십시오.
출력보기
다음 출력은 리스너에서 볼 수 있습니다.
마지막 이미지에서 "Hello Manisha to JAX WS world"라는 응답 메시지를 볼 수 있습니다.
이 장에서는 JMS (Java Messaging Service)를 테스트하기위한 간단한 테스트 계획을 작성하는 방법을 배웁니다. JMS는 두 가지 유형의 메시징을 지원합니다.
Point-to-Point messaging− 대기열 메시징은 일반적으로 발신자가 응답을 기대하는 트랜잭션에 사용됩니다. 메시징 시스템은 일반 HTTP 요청과 상당히 다릅니다. HTTP에서는 단일 사용자가 요청을 보내고 응답을받습니다.
Topic messaging− 주제 메시지는 일반적으로 게시 / 구독 메시징으로 알려져 있습니다. 토픽 메시징은 일반적으로 생산자가 메시지를 게시하고 여러 구독자가 사용하는 경우에 사용됩니다.
각각에 대한 테스트 예제를 살펴 보겠습니다. JMS 테스트를위한 전제 조건은 다음과 같습니다.
예제에서는 Apache ActiveMQ를 사용합니다. IBM WebSphere MQ (이전 MQSeries), Tibco 등과 같은 다양한 JMS 서버가 있습니다. Apache ActiveMQ 웹 사이트의 바이너리에서 다운로드하십시오 .
아카이브의 압축을 풀고 압축이 풀린 디렉토리로 이동 한 다음 명령 콘솔에서 다음 명령을 실행하여 ActiveMQ 서버를 시작합니다.
.\bin\activemq start
다음 주소의 관리자 인터페이스를 방문하여 ActiveMQ 서버가 시작되었는지 확인할 수 있습니다. http://localhost:8161/admin/. 인증을 요청하는 경우 사용자 ID와 비밀번호를 admin 으로 입력하십시오 . 화면은 아래와 비슷합니다.
이제 ActiveMQ 압축이 풀린 디렉토리에서 activemq-all-xxxjar (버전에 따라 XXX)를 복사합니다. /home/manisha/apache-jmeter-2.9/lib.
위의 설정으로 다음에 대한 테스트 계획을 세우겠습니다.
JMS 지점 간 테스트 계획
JMS 주제 테스트 계획
이 장에서는 JMeter를 사용하여 웹 서버를 모니터링하는 테스트 계획을 만드는 방법에 대해 설명합니다. 모니터 테스트의 용도는 다음과 같습니다.
모니터는 스트레스 테스트 및 시스템 관리에 유용합니다.
스트레스 테스트와 함께 사용되는 모니터는 서버 성능에 대한 추가 정보를 제공합니다.
모니터를 사용하면 클라이언트 측에서 서버 성능과 응답 시간 간의 관계를 쉽게 확인할 수 있습니다.
시스템 관리 도구 인 모니터는 하나의 콘솔에서 여러 서버를 쉽게 모니터링 할 수있는 방법을 제공합니다.
모니터링을 위해 Tomcat 5 이상이 필요합니다. 테스트 목적으로 Tomcat 7.0.42 서버를 모니터링합니다. JMX (Java Management Extension)를 지원하는 모든 서블릿 컨테이너를 테스트 할 수 있습니다. Tomcat 서버를 모니터링하기위한 테스트 케이스를 작성하겠습니다. 먼저 Tomcat 서버를 설정하겠습니다.
Tomcat 서버 설정
Tomcat 서비스 상태를 여는 것으로 시작합니다. 이렇게하려면 사용자의 구성 파일을 편집하고<TOMCAT_HOME>/conf/tomcat-users.xml. 이 파일에는 다음과 같이 tomcat-users 섹션 (주석 처리됨)이 포함되어 있습니다.
<tomcat-users>
<!--
<role rolename = "tomcat"/>
<role rolename = "role1"/>
<user username = "tomcat" password = "tomcat" roles = "tomcat"/>
<user username = "both" password = "tomcat" roles = "tomcat,role1"/>
<user username = "role1" password = "tomcat" roles = "role1"/>
-->
</tomcat-users>
관리자 역할, 관리자, manager-gui를 추가하고 사용자 "admin"을 할당하려면이 섹션을 변경해야합니다. 수정 된 파일은 다음과 같습니다.
<tomcat-users>
<role rolename = "manager-gui"/>
<role rolename = "manager-script"/>
<role rolename = "manager-jmx"/>
<role rolename = "manager-status"/>
<user username = "admin" password = "admin" roles = "manager-gui,manager-script,manager-jmx,manager-status"/>
</tomcat-users>
이제 Linux의 경우 Tomcat 서버 <TOMCAT_HOME> /bin/startup.sh 및 Windows의 경우 <TOMCAT_HOME> /bin/startup.bat를 시작하십시오. 시작되면 브라우저에 다음 링크를 입력하여 Tomcat 감독이 작동하는지 확인하십시오.
http://localhost:8080/manager/status?XML=true
브라우저에 인증 창이 나타납니다. 연결된 tomcat 로그인 및 비밀번호를 입력합니다 (이 경우에는 admin입니다). 그러면 브라우저는 아래와 같이 Tomcat의 실행 상태를 보여줍니다.
위의 스크린 샷에서 몇 가지 사항을 확인할 수 있습니다.
URL에서 XML = true (대소 문자 구분에주의)를 사용하면 JMeter 기능에 필요한 감독 Tomcat을 깔끔하게 표시 할 수 있습니다.
또한 기본적으로 두 개의 커넥터가 있습니다. 일반적으로 사용되는 AJP 커넥터는 mod_jk Apache HTTPD 프론트 모듈 및 포트 8080을 통해 Tomcat에 직접 액세스하기 위해 일반적으로 사용되는 커넥터 인 HTTP 커넥터와 결합됩니다.
JMeter 테스트 계획 작성
테스트 계획을 작성하여 Tomcat 서버를 모니터링하겠습니다.
테스트 계획 이름 변경
/home/manisha/apache-jmeter2.9/bin/jmeter.sh를 클릭하여 JMeter 창을 엽니 다.
테스트 계획 노드를 클릭하십시오.
다음 단계에 설명 된대로 스레드 그룹을 추가하십시오.
스레드 그룹 추가
오른쪽 클릭 Test Plan → Add → Threads(Users) → Thread Group. 스레드 그룹은 테스트 계획 노드 아래에 추가됩니다.
충분한 샘플이 생성되도록 루프 수를 영원히 (또는 일부 큰 수)로 변경하십시오.
HTTP 인증 관리자
추가 → 구성 요소 → HTTP 권한 부여 관리자를 선택하여 스레드 그룹 요소에 HTTP 권한 부여 관리자를 추가하십시오. 이 요소는 Tomcat 서버 상태를보기 위해 브라우저에서 요청한 인증을 관리합니다.
HTTP 권한 부여 관리자를 선택하십시오.
다음 세부 정보를 편집하십시오-
Username − admin (tomcat-users.xml 파일의 구성에 따라 다름)
Password − admin (tomcatusers.xml 파일의 구성에 따라 다름)
다른 필드는 비어 있습니다.
샘플러 -HTTP 요청 추가
이제 사용자를 정의 했으므로 수행 할 작업을 정의 할 차례입니다. HTTP 요청 요소를 추가합니다.
마우스 오른쪽 버튼을 클릭하면 추가 메뉴가 나타납니다.
추가 → 샘플러 → HTTP 요청을 선택합니다.
그런 다음 트리에서 HTTP 요청 요소를 선택하십시오.
아래 이미지와 같이 다음 속성을 편집하십시오-
이 요소에는 다음 세부 정보가 입력됩니다.
Name − 서버 상태
Server Name or IP − 로컬 호스트
Port − 8080
Path − / 관리자 / 상태
Parameters− "XML"이라는 요청 매개 변수를 대문자로 추가합니다. 소문자로 "true"값을 지정하십시오.
Optional Tasks − 샘플러 하단의 "모니터로 사용"에 체크하십시오.
상수 타이머 추가
주기적으로 서버의 상태를 요청하려면 각 요청 사이에 시간 간격을 허용하는 상수 타이머를 추가하십시오. Add → Timer → Constant Timer를 선택하여이 스레드 그룹에 타이머를 추가합니다.
스레드 지연 상자 에 5000 밀리 초를 입력합니다 . 일반적으로 5 초보다 짧은 간격을 사용하면 서버에 스트레스가 추가 될 수 있습니다. 프로덕션 환경에 모니터를 배치하기 전에 허용 가능한 간격을 확인하십시오.
리스너 추가
테스트 계획에 추가해야하는 마지막 요소는 리스너입니다. 두 가지 유형의 청취자를 추가합니다. 하나는 결과를 파일에 저장하고 두 번째는 결과의 그래픽보기를 표시합니다.
스레드 그룹 요소를 선택합니다.
Simple Data Writer 리스너 추가 추가 → Listener → Simple Data Writer.
출력 파일의 디렉토리와 파일 이름을 지정합니다 (이 경우에는 /home/manisha/work/sample.csv).
테스트 계획 요소 추가 → 리스너 → 모니터 결과를 선택하여 다른 리스너를 추가하겠습니다.
테스트 계획 실행
이제 위의 테스트 계획을 monitor_test.jmx 로 저장합니다 . 실행 → 시작 옵션을 사용하여이 테스트 계획을 실행하십시오.
출력보기
결과는 /home/manisha/work/sample.csv 파일에 저장됩니다. 아래 이미지와 같이 모니터 결과 리스너에서 그래픽 결과를 볼 수도 있습니다.
그래프의 양쪽에는 캡션이 있습니다. 왼쪽은 백분율이고 오른쪽은 사망 / 건강입니다. 메모리 라인이 급격히 증가 및 감소하면 메모리 스 래싱을 나타낼 수 있습니다. 이러한 상황에서는 Borland OptimizeIt 또는 JProbe를 사용하여 애플리케이션을 프로파일 링하는 것이 좋습니다. 보고 싶은 것은로드, 메모리 및 스레드에 대한 규칙적인 패턴입니다. 모든 비정상적인 동작은 일반적으로 성능 저하 또는 일종의 버그를 나타냅니다.
리스너는 JMeter가 실행되는 동안 테스트 케이스에 대해 JMeter가 수집하는 정보에 대한 액세스를 제공합니다. 청취자가 수집 한 결과 또는 정보는 다음과 같은 형태로 표시 될 수 있습니다.
- tree
- tables
- graphs
- 로그 파일
모든 리스너는 하나가 지정되면 동일한 원시 데이터를 출력 파일에 씁니다.
기본 구성
저장할 기본 항목은 다음 두 가지 방법 중 하나로 정의 할 수 있습니다.
에서 jmeter.properties(또는 user.properties) 파일. 이 파일은/bin JMeter의 폴더. 기본 형식을 변경하려면 jmeter.properties에서 다음 행을 찾으십시오.
jmeter.save.saveservice.output_format=
다음 스크린 샷과 같이 Config 팝업을 사용하여-
JMeter는 테스트 실행 결과를 JTL (JMeter Text Logs)로 생성합니다. 기본 확장자이므로 일반적으로 JTL 파일이라고하지만 모든 확장자를 사용할 수 있습니다.
동일한 출력 파일 이름을 사용하여 여러 테스트를 실행하는 경우 JMeter는 파일 끝에 새 데이터를 자동으로 추가합니다.
리스너는 결과를 파일에 기록 할 수 있지만 UI에는 기록 할 수 없습니다. GUI 오버 헤드를 제거하여 데이터를 기록하는 효율적인 수단을 제공하기위한 것입니다.
실행시 −
GUI mode − 리스너 Simple Data Writer 사용
non-GUI mode − -l 플래그를 사용하여 데이터 파일을 생성 할 수 있습니다.
청취자는 샘플이 많으면 많은 메모리를 사용할 수 있습니다. 필요한 메모리 양을 최소화하려면 CSV 형식의 단순 데이터 쓰기를 사용하십시오.
CSV 로그 형식
CSV 로그 형식은 구성에서 선택한 데이터 항목에 따라 다릅니다. 지정된 데이터 항목 만 파일에 기록됩니다. 열의 표시 순서는 고정되어 있으며 다음과 같습니다.
들 | 기술 | 값 예 |
---|---|---|
timeStamp | 1/1/1970 이후 밀리 초 단위 | 1354223881017 |
경과 | 밀리 초 | 1858 년 |
상표 | 샘플러 라벨 | HTTP 요청 |
responseCode | 예 : 200, 404 | 200 |
responseMessage | 예 : OK | 확인 |
threadName | 스레드 그룹 1-1 | |
데이터 형식 | 예 : 텍스트 | 본문 |
성공 | 참 또는 거짓 | 진실 |
failureMessage | 만약에 어떠한 | |
바이트 | 샘플의 바이트 수 | 34908 |
grpThreads | 이 스레드 그룹의 활성 스레드 수 | 1 |
allThreads | 모든 그룹의 총 활성 스레드 수 | 1 |
URL | http://tutorialspoint.com | |
파일 이름 | 파일에 응답 저장이 사용 된 경우 | |
지연 시간 | 첫 번째 응답 시간 | 132 |
부호화 | utf-8 | |
SampleCount | 샘플 수 (여러 샘플이 집계되지 않은 경우 1) | 1 |
ErrorCount | 오류 수 (여러 샘플이 집계되지 않은 경우 0 또는 1) | 0 |
호스트 이름 | 샘플이 생성 된 위치 | 노트북 |
유휴 시간 | '유휴'시간의 밀리 초 수 (일반적으로 0) | |
변수 | 지정된 경우 |
응답 데이터 저장
응답 데이터는 필요한 경우 XML 로그 파일에 저장할 수 있습니다. 그러나 큰 파일과 이미지를 저장할 수 없습니다. 이러한 경우 포스트 프로세서 Save_Responses_to_a_file을 사용하십시오. 이렇게하면 각 샘플에 대한 새 파일이 생성되고 샘플과 함께 파일 이름이 저장됩니다. 그런 다음 파일 이름을 샘플 로그 출력에 포함 할 수 있습니다. 샘플 로그 파일을 다시로드 할 때 필요한 경우 파일에서 데이터를 검색합니다.
응답 데이터로드 (읽기)
기존 결과 파일을 보려면 파일 "찾아보기 ..."버튼을 사용하여 파일을 선택할 수 있습니다. 필요한 경우 적절한 리스너가 포함 된 더미 테스트 계획을 만듭니다.
리스너 GUI 데이터 저장
JMeter는 모든 리스너를 PNG 파일로 저장할 수 있습니다. 그렇게하려면
편집 → 이미지로 저장을 선택하여 왼쪽 패널에서 리스너를 선택합니다. 파일 대화 상자가 나타납니다.
원하는 이름을 입력하십시오.
리스너를 저장하십시오.
JMeter 함수 및 사용자 변수
JMeter 함수는 테스트 트리의 샘플러 또는 기타 요소의 필드를 채울 수있는 특수 값입니다.
함수 호출은 다음과 같습니다.
${__functionName(var1,var2,var3)}
_functionName 은 함수의 이름과 일치합니다. 예를 들면${__threadNum}.
함수 매개 변수에 쉼표가 포함 된 경우 아래에 표시된대로 "\"로 이스케이프해야합니다.
${__time(EEE\, d MMM yyyy)}
변수는 다음과 같이 참조됩니다.
${VARIABLE}
기능 목록
다음 표는 느슨하게 유형으로 그룹화 된 함수 그룹을 나열합니다.
기능 유형 | 이름 | 논평 |
---|---|---|
정보 | threadNum | 스레드 번호를 가져옵니다. |
정보 | samplerName | 샘플러 이름 (라벨)을 가져옵니다. |
정보 | machineIP | 로컬 컴퓨터 IP 주소를 가져옵니다. |
정보 | machineName | 로컬 컴퓨터 이름을 가져옵니다. |
정보 | 시각 | 다양한 형식으로 현재 시간을 반환합니다. |
정보 | 로그 | 메시지를 기록 (또는 표시)하고 값을 반환합니다. |
정보 | logn | 메시지를 기록 (또는 표시)합니다 (빈 반환 값). |
입력 | StringFromFile | 파일에서 한 줄을 읽습니다. |
입력 | FileToString | 전체 파일을 읽습니다. |
입력 | CSVRead | CSV로 구분 된 파일에서 읽습니다. |
입력 | XPath | XPath 표현식을 사용하여 파일에서 읽습니다. |
계산 | 카운터 | 증가하는 숫자를 생성합니다. |
계산 | intSum | 정수를 추가하십시오. |
계산 | longSum | 긴 숫자를 추가하십시오. |
계산 | 랜덤 | 난수를 생성합니다. |
계산 | RandomString | 임의의 문자열을 생성합니다. |
계산 | UUID | 임의 유형 4 UUID를 생성합니다. |
스크립팅 | BeanShell | BeanShell 스크립트를 실행하십시오. |
스크립팅 | 자바 스크립트 | JavaScript (Mozilla Rhino)를 처리합니다. |
스크립팅 | jexl, jexl2 | Commons Jexl 표현식을 평가합니다. |
속성 | 특성 | 속성을 읽으십시오. |
속성 | 피 | 속성을 읽습니다 (속기 방법). |
속성 | setProperty | JMeter 속성을 설정합니다. |
변수 | 스플릿 | 문자열을 변수로 분할합니다. |
변수 | V | 변수 이름을 평가하십시오. |
변수 | 평가 | 변수 식을 평가합니다. |
변수 | evalVar | 변수에 저장된 식을 평가합니다. |
끈 | regexFunction | 정규식을 사용하여 이전 응답을 구문 분석합니다. |
끈 | escapeOroRegexpChars | ORO 정규식에서 사용하는 따옴표 메타 문자입니다. |
끈 | 숯 | 숫자 목록에서 유니 코드 문자 값을 생성합니다. |
끈 | Unscape | Java 이스케이프가 포함 된 프로세스 문자열 (예 : \ n & \ t). |
끈 | unescapeHtml | HTML로 인코딩 된 문자열을 디코딩합니다. |
끈 | escapeHtml | HTML 인코딩을 사용하여 문자열을 인코딩합니다. |
끈 | TestPlanName | 현재 테스트 계획의 이름을 반환합니다. |
두 종류의 기능이 있습니다-
사용자 정의 정적 값 (또는 변수)
내장 기능
사용자 정의 정적 값을 통해 사용자는 테스트 트리가 컴파일되고 실행되도록 제출 될 때 정적 값으로 대체 될 변수를 정의 할 수 있습니다.
변수는 중첩 될 수 없습니다. 즉${Var${N}} 작동하지 않습니다.
__V (변수) 함수 (2.2 이후 버전)를 사용하여 $ {__ V (Var $ {N})}를 수행 할 수 있습니다.
이러한 유형의 교체는 기능 없이도 가능하지만 덜 편리하고 덜 직관적입니다.
함수와 변수를 사용하는 곳
함수와 변수는 모든 테스트 구성 요소의 모든 필드에 쓸 수 있습니다.
다음 기능은 테스트 계획에서 잘 작동합니다.
- intSum
- longSum
- machineName
- BeanShell
- javaScript
- jexl
- random
- time
- 속성 함수
- 로그 기능
테스트 계획에서 사용되는 기능에는 몇 가지 제한이 있습니다. JMeter 스레드 변수는 함수가 처리 될 때 완전히 설정되지 않았으므로 매개 변수로 전달 된 변수 이름이 설정되지 않고 변수 참조가 작동하지 않습니다. 따라서 split () 및 regex () 및 변수 평가 함수가 작동하지 않습니다. threadNum () 기능이 작동하지 않습니다 그것은 테스트 계획 수준에서 이해가되지 않습니다.
변수 및 함수 참조
테스트 요소에서 변수 참조는 변수 이름을 '$ {'및 '}'로 괄호로 묶어 수행됩니다.
함수는 동일한 방식으로 참조되지만 규칙에 따라 함수 이름은 사용자 값 이름과의 충돌을 피하기 위해 "__"로 시작합니다.
일부 함수는이를 구성하기 위해 인수를 취하며, 괄호로 묶여 쉼표로 구분됩니다. 함수에 인수가 없으면 괄호를 생략 할 수 있습니다. 예를 들면-
${__BeanShell(vars.put("name"\,"value"))}
또는 테스트 계획에서 스크립트를 변수로 정의 할 수 있습니다.
SCRIPT vars.put("name","value")
스크립트는 다음과 같이 참조 할 수 있습니다.
${__BeanShell(${SCRIPT})}
함수 도우미 대화 상자
함수 도우미 대화 상자는 JMeter에서 사용할 수 있습니다. Options 탭.
함수 도우미를 사용하여 풀다운에서 함수를 선택하고 인수 값을 할당 할 수 있습니다. 테이블의 왼쪽 열은 인수에 대한 간략한 설명을 제공하고 오른쪽 열은 해당 인수에 대한 값을 쓰는 곳입니다. 다른 함수는 다른 인수를 사용합니다.
이 작업을 완료 한 후 "Generate"버튼을 클릭하면 적절한 문자열이 생성되어 필요할 때마다 테스트 계획에 복사하여 붙여 넣을 수 있습니다.
미리 정의 된 변수
일부 변수는 JMeter에 의해 내부적으로 정의됩니다. 그들은-
COOKIE_cookiename-쿠키 값을 포함합니다.
JMeterThread.last_sample_ok-마지막 샘플이 정상인지 여부-참 / 거짓. 참조 : 이것은 포스트 프로세서와 어설 션이 실행 된 후에 업데이트됩니다.
START 변수.
미리 정의 된 속성
일부 내장 속성은 JMeter에 의해 정의됩니다. 아래에 나열되어 있습니다. 편의를 위해 START 속성은 같은 이름의 변수에도 복사됩니다.
START.MS-JMeter 시작 시간 (밀리 초).
START.YMD-JMeter 시작 시간 (yyyyMMdd).
START.HMS-HHmmss로 JMeter 시작 시간.
TESTSTART.MS-테스트 시작 시간 (밀리 초).
START 변수 / 속성은 테스트 시작 시간이 아니라 JMeter 시작 시간을 나타냅니다. 주로 파일 이름 등에 사용하기위한 것입니다.
정규식은 패턴을 기반으로 텍스트를 검색하고 조작하는 데 사용됩니다. JMeter는 패턴 일치 소프트웨어 Apache Jakarta ORO 를 포함하여 JMeter 테스트 계획 전체에서 사용되는 정규식 또는 패턴의 형태를 해석합니다 .
정규식을 사용하면 테스트 계획을 만들거나 향상시킬 때 확실히 많은 시간을 절약하고 더 큰 유연성을 얻을 수 있습니다. 정규식은 결과를 예측하는 것이 불가능하거나 매우 어려울 때 페이지에서 정보를 가져 오는 간단한 방법을 제공합니다.
표현식 사용의 표준 사용 예는 서버 응답에서 세션 ID를 가져 오는 것입니다. 서버가 고유 한 세션 키를 반환하면로드 스크립트의 표현식을 사용하여 쉽게 가져올 수 있습니다.
테스트 계획에서 정규식을 사용하려면 JMeter의 정규식 추출기를 사용해야합니다. 테스트 계획의 모든 구성 요소에 정규식을 배치 할 수 있습니다.
차이점을 강조 할 가치가 있습니다. contains 과 matches, Response Assertion 테스트 요소에 사용됨 −
contains정규 표현식이 대상의 일부 이상과 일치했음을 의미하므로 'alphabet'은 'contains' 'ph.b'를 의미합니다. 정규 표현식이 하위 문자열 'phabe'와 일치하기 때문입니다.
matches정규식이 전체 대상과 일치했음을 의미합니다. 따라서 '알파벳'은 'al. * t'와 "일치"됩니다.
웹 페이지의 다음 부분과 일치한다고 가정 해보십시오.
name = "file" value = "readme.txt"
그리고 readme.txt를 추출하고 싶습니다. 적합한 정규식은 다음과 같습니다.
name = "file" value = "(.+?)">
위의 특수 문자는-
( 과 ) − 반환 될 일치 문자열의 일부를 묶습니다.
. − 모든 문자와 일치
+ − 1 회 이상
? − 첫 번째 경기가 성공하면 중지
JMeter 테스트 계획 생성
테스트 계획을 작성하여 정규식 추출기 (포스트 프로세서 요소)에서 정규식의 사용을 이해하겠습니다. 이 요소는 원하는 요소가 준수하는 텍스트 패턴을 식별하기 위해 정규식을 사용하여 현재 페이지에서 텍스트를 추출합니다.
먼저 사람들과 이메일 ID 목록이있는 HTML 페이지를 작성합니다. Tomcat 서버에 배포합니다. html (index.html)의 내용은 다음과 같습니다.
<html>
<head>
</head>
<body>
<table style = "border: 1px solid #000000;">
<th style = "border: 1px solid #000000;">ID</th>
<th style = "border: 1px solid #000000;">name</th>
<th style = "border: 1px solid #000000;">Email</th>
<tr>
<td id = "ID" style = "border: 1px solid #000000;">3</td>
<td id = "Name" style = "border: 1px solid #000000;">Manisha</td>
<td id = "Email" style = "border: 1px solid #000000;">[email protected]</td>
</tr>
<tr>
<td id = "ID" style = "border: 1px solid #000000;">4</td>
<td id = "Name" style = "border: 1px solid #000000;">joe</td>
<td id = "Email" style = "border: 1px solid #000000;">[email protected]</td>
</tr>
</table>
</body>
</html>
tomcat 서버에 배포 할 때이 페이지는 다음 스크린 샷과 같이 보입니다.
테스트 계획에서 위의 사람 목록 페이지에 표시된 사람 테이블의 첫 번째 행에서 사람을 선택합니다. 이 사람의 ID를 캡처하려면 먼저 두 번째 행에서 사람을 찾을 패턴을 결정합니다.
다음 스냅 샷에서 볼 수 있듯이 두 번째 사람의 ID는 <td id = "ID"> 및 </ td>로 둘러싸여 있으며이 패턴을 갖는 데이터의 두 번째 행입니다. 이를 사용하여 정보를 추출하려는 정확한 패턴과 일치시킬 수 있습니다. 이 페이지에서 개인 ID와 개인 이름의 두 가지 정보를 추출하고자하므로 필드는 다음과 같이 정의됩니다.
JMeter 시작, 스레드 그룹 추가 Test Plan → Add→ Threads(Users)→ Thread Group.
다음으로 샘플러 HTTP 요청을 추가하고 테스트 계획을 선택하고 마우스 오른쪽 버튼을 클릭합니다. Add → Sampler → HTTP Request 다음과 같이 세부 정보를 입력하십시오-
Name − 관리
Server Name or IP − 로컬 호스트
Port Number − 8080
Protocol −이 항목을 비워두면 HTTP를 프로토콜로 사용합니다.
Path − jmeter / index.html
다음으로 정규식 추출기를 추가하십시오. HTTP 요청 샘플러 (관리)를 선택하고 마우스 오른쪽 단추를 클릭하십시오.Add → Post Processor → Regular Expression Extractor.
다음 표는 위 스크린 샷에서 사용 된 필드에 대한 설명을 제공합니다.
Sr. 아니요 | 필드 및 설명 |
---|---|
1 | Reference Name 추출 된 테스트가 저장 될 변수의 이름 (refname). |
2 | Regular Expression 추출 할 텍스트가 일치하는 패턴입니다. 추출 할 텍스트 그룹은 '('및 ')'문자로 묶여 있습니다. '. +?'를 사용합니다. <td ..> .. </ td> 태그로 묶인 텍스트의 단일 인스턴스를 나타냅니다. 이 예에서 표현식은 − <td id = "ID"> (+?) </ td> \ s * <td id = "Name"> (+?) </ td> \ s * |
삼 | Template 추출 된 각 텍스트 그룹은 '('및 ')'로 묶인 각 패턴 그룹의 순서에 따라 변수 Person의 구성원으로 배치됩니다. 각 그룹은 refname_g #으로 저장됩니다. 여기서 refname은 참조 이름으로 입력 한 문자열이고 #은 그룹 번호입니다. $ 1 $는 그룹 1을, $ 2 $는 그룹 2를 나타냅니다. $ 0 $는 전체 표현식이 일치하는 모든 것을 나타냅니다. 이 예에서 추출한 ID는 Person_g1에 유지되고 Name 값은 Person_g2에 저장됩니다. |
4 | Match No. 두 번째 자원자와 일치하는이 패턴의 두 번째 발생 만 추출 할 계획이므로 값 2를 사용합니다. 값 0은 무작위로 일치하는 반면 음수 값은 ForEach 컨트롤러에서 사용해야합니다. |
5 | Default 항목을 찾을 수없는 경우 이것이 기본값입니다. 이것은 선택적 필드입니다. 비워 둘 수 있습니다. |
이 테스트 계획의 결과를 캡처하려면 리스너를 추가하십시오. 스레드 그룹을 마우스 오른쪽 단추로 클릭하고 추가 → 리스너 → 결과 트리보기 옵션을 선택하여 리스너를 추가하십시오.
테스트 계획을 reg_express_test.jmx 로 저장하고 테스트를 실행합니다. 출력은 다음 스크린 샷과 같이 성공할 것입니다.
JMeter는 특히 분산 환경에서 실행되는 경우 몇 가지 제한 사항이 있습니다. 이 지침을 따르면 실제적이고 지속적인 부하를 생성하는 데 도움이됩니다.
스레드 수가 더 많은 경우 JMeter의 여러 인스턴스를 사용하십시오.
범위 지정 규칙을 확인하고 그에 따라 디자인하십시오.
모든 요소에 항상 이름 지정 규칙을 사용하십시오.
스크립트를 실행하기 전에 기본 브라우저 연결 설정을 확인하십시오.
리스너를 적절하게 추가하십시오.
다음은 자원 요구 사항을 줄이기위한 몇 가지 제안입니다.
비 GUI 모드 사용 : jmeter -n -t test.jmx -l test.jtl.
가능한 한 적은 수의 청취자를 사용하십시오. 위와 같이 -l 플래그를 사용하면 모두 삭제하거나 비활성화 할 수 있습니다.
"View Result Tree"리스너는 많은 메모리를 사용하고 콘솔이 멈추거나 JMeter의 메모리가 부족해질 수 있으므로 비활성화합니다. 그러나 "오류"만 선택하여 "결과 트리보기"리스너를 사용하는 것이 안전합니다.
유사한 샘플러를 많이 사용하는 대신 루프에서 동일한 샘플러를 사용하고 변수 (CSV 데이터 세트)를 사용하여 샘플을 변경하십시오. 또는 액세스 로그 샘플러를 사용할 수도 있습니다.
기능 모드를 사용하지 마십시오.
XML 대신 CSV 출력을 사용하십시오.
필요한 데이터 만 저장하십시오.
가능한 한 적은 어설 션을 사용하십시오.
많은 메모리를 소비하므로 모든 JMeter 그래프를 비활성화합니다. 웹 인터페이스의 JTL 탭을 사용하여 모든 실시간 그래프를 볼 수 있습니다.
사용하는 경우 CSV 데이터 세트 구성에서 로컬 경로를 지우는 것을 잊지 마십시오.
모든 테스트 실행 전에 파일 탭을 정리하십시오.