동시에 몇개의 요청을 받았을때 서버의 에러가 급격하게 늘까 ? ( 임계점 식별 )각 HTTP 메서드마다 얼마의 요청을 버틸 수 있을까 ? ( 병목 구간 개선 )각 테스트는 가장 무겁고 처리 로직이 복잡한것으로 선택한다.테스트는 POST / GET 이 있다.GET게시물 조회를 선택했다.게시물 조회는 현재 게시물의 좋아요 개수, 댓글 개수 , 각 댓글의 좋아요 갯수 , 대댓글 갯수 , 페이징 처리 , 차단 유저 제외데이터를 가져오도록 설계되어, 많은 테이블의 조인과 서브쿼리가 사용되어 무겁다고 판단 하였다.Post 게시물 생성 API 를 선택했다.게시물 생성로직은 여러 파일이 전송 되어야 해서 선택 하게 되었다.RPS: 초당 요청 수(request per sec)TPS: 초당 트랜잭션 처리 수 (transa..
개-발/Infra
엔그라인더로 파일 전송 테스트를 하거나 multipart-form 형식 요청의 스크립트 작성 방법scriptimport groovy.json.JsonBuilderimport static net.grinder.script.Grinder.grinderimport static org.junit.Assert.*import static org.hamcrest.Matchers.*import net.grinder.script.GTestimport net.grinder.script.Grinderimport net.grinder.scriptengine.groovy.junit.GrinderRunnerimport net.grinder.scriptengine.groovy.junit.annotation.BeforeProcess..
설치https://github.com/naver/ngrinder/releases Releases · naver/ngrinderenterprise level performance testing solution. Contribute to naver/ngrinder development by creating an account on GitHub.github.comwar 파일을 받아준다실행java -Djava.io.tmpdir={설정디렉토리} -jar {ngrinderWar파일}//exjava -Djava.io.tmpdir=/Users/hi/Desktop/ngrinder -jar ngrinder-controller-3.5.9-p1.warlocalhost:8080에 접속하면 nginder 페이지가 나온다.초기 로..
설치OS 에 따라 설치를 해준다.brew install jmeter//설치 완료 후 실행 명령어open /usr/local/bin/jmeterhttps://jmeter.apache.org/download_jmeter.cgi Apache JMeter - Download Apache JMeterDownload Apache JMeter We recommend you use a mirror to download our release builds, but you must verify the integrity of the downloaded files using signatures downloaded from our main distribution directories. Recent releases (48 hour..
problemec2 를 이전하고 시스템을 바꾸던 도중 swagger 에서 포트 바인딩을 못하고 있었다 Spring 설정은 똑같이 이전 했는데 말이다.따로 설정을 해주지 않아도 알아서 잘 잡았던 녀석....변경된 사항은 NginX 를 사용하고 있다는 것이었다.현재는 0001->1111 -> 90900001->1112 -> 90900002->1113 -> 90910002->1114 -> 9091이런식으로 바인딩 해주고 있었다.swagger 는 여기서 찾지 못한듯 하다.solution요청은 9090으로 하는데 docker 컨테이너 포트는 1111로 연결 되어있으니 swagger 가 갈 길을 잃은것 같다.ec2-info.ymlec2: host: 탄력IP prd: port: 0001 dev: po..
problemaws 프리티어는 1기가의 메모리를 제공하는데 dev 채널과 prd 채널을 docker 컨테이너화 하면 금방 메모리가 부족하여 OOM 이 발생된다.solution1. aws 볼륨 크기 조정aws 프리티어는 30기가의 디스크를 무료로 제공한다기본으로 생성 할 시 8기가로 생성 된다.[ec2 대시보드] -> [볼륨] -> [볼륨 ID] -> [오른쪽 위 수정 버튼]볼륨크기를 30기가로 늘리고 인스턴스를 재시동 한다.df -h2. 스왑 설정2-1 파일 생성sudo dd if=/dev/zero of=/swapfile bs=128M count=16또는sudo fallocate -l 2G /swapfile명령어로 2G 짜리 스왑파일을 생성 한다.2-2 권한 설정 sudo chmod 600 /swapfi..
github Actions + S3 + ec2 무 배포 for Spring (1)https://soobysu.tistory.com/184 [CICD] github Actions + S3 + ec2 무 배포 for Spring (1)problem현재 하는 사이드 프로젝트에서는 프리티어를 사용하기 때문에 젠킨스를 사용하지 않고github Actions 를 사용하게 되었다.Jenkins젠킨스를 위한 서버가 필요 없다플러그인이 풍부하여 다양한soobysu.tistory.com 작당한 이름의 파일을 만들어서./github/workflows 디렉토리에 넣어두면 자동으로 실행된다.전체 코드name: CI/CD Pipelineon: pull_request: branches: - dev - pr..
problem현재 하는 사이드 프로젝트에서는 프리티어를 사용하기 때문에 젠킨스를 사용하지 않고github Actions 를 사용하게 되었다.Jenkins젠킨스를 위한 서버가 필요 없다플러그인이 풍부하여 다양한 툴과 서비스(예: Kubernetes, Docker)와 쉽게 통합 가능자율적으로 서버와 파이프라인을 구성할 수 있어 대규모 프로젝트에 적합 하다.github Actions깃허브에 의존적이다.( 네트워크 장애때 의문점이 생길 수 있지 않을까 한다 )서버리스 방식으로 운영비 부담이 없음구현이 쉽다 ( yaml 파일 구성만으로 구현이 된다 )소규모 프로젝트일 경우 무료로 사용 가능하다solutionCode Push -> 설정파일 넣기 ( AWS , DBsource ) -> Jar 만들기 -> S3 업로..