Programming/web
k6로 성능 테스트 하기
유주원
2023. 12. 29. 16:49
mac 환경에서 성능 테스트를 진행할 목적으로 k6를 써보기로 했다.
설치는 간단하다. 아래와 같이 설치 하자
$> brew install k6
k6를 실행하기 위해서는 실행 코드가 담긴 js 스크립트 파일이 있어야 한다.
아래와 같이 작성하자.
import http from 'k6/http';
import { SharedArray } from 'k6/data';
import { htmlReport } from "https://raw.githubusercontent.com/benc-uk/k6-reporter/main/dist/bundle.js";
import { textSummary } from "https://jslib.k6.io/k6-summary/0.0.1/index.js";
export function handleSummary(data) {
return {
"./reports/result.html": htmlReport(data),
stdout: textSummary(data, { indent: " ", enableColors: true }),
};
}
const testQueries = new SharedArray('another data name', function () {
return open('./data/thumb_image.dat').split(/\r?\n/);
});
export const options = {
stages: [
{ duration: '480m', target: 100},
],
};
export default function () {
for (const query of testQueries) {
if (query !== "") {
const url = "http://test.com?target=" + query
http.get(url, {
headers: {
"Content-Type": "application/json",
"Authorization": "인증키"
}
});
}
}
}
실행 후의 html 파일 형태의 리포트 작성과 테스트 시 입력 값을 파일로부터 읽기 위해 아래의 패키지를 선언했다.
import { SharedArray } from 'k6/data';
import { htmlReport } from "https://raw.githubusercontent.com/benc-uk/k6-reporter/main/dist/bundle.js";
import { textSummary } from "https://jslib.k6.io/k6-summary/0.0.1/index.js";
options의 stage를 통해 단계 별 성능 테스트 시나리오를 준비할 수가 있다.
나같은 경우엔 그냥 단순하게 8시간 동안 100 user가 서서히 호출하는 방법으로 진행했다.
나같은 경우에는 초당 request를 제어하고 싶었는데, k6에서는 따로 그 방법은 제공하지 않는 것 같다.
일단 확인한 바로는 1user가 1 query / s는 아닌 것 같다.
서버 응답에 따라 다르긴 하겠지만 나 같은 경우에는 1 user가 10 query / s 정도 나타났다.
초당 request에 맞는 적절한 user 수는 결과 report를 보면서 적절히 맞춰 나가야 할 것 같았다.
function 부분에 이제 실제 호출할 구현을 작성해 준다.
위와 같이 js 파일 작성이 완료되었다면 이제 k6를 실행해보자.
$> k6 run test.js
위의 명령을 실행하면 아래와 같은 화면이 뜨고 프로그래스 바를 통해 성능 테스트가 진행 중인 것을 확인 할 수가 있다.
reports 폴더에 result.html 파일이 생성되어 있는데 열어보면 해당 성능테스트 진행 결과를 페이지 결과로 확인해 볼 수가 있다.