{"id":1014,"date":"2023-06-08T17:40:39","date_gmt":"2023-06-08T08:40:39","guid":{"rendered":"https:\/\/www.gyuroot.com\/wordpress\/?p=1014"},"modified":"2023-07-04T22:10:20","modified_gmt":"2023-07-04T13:10:20","slug":"sprint-aws-ec2%ec%99%80-k6%eb%a5%bc-%ec%9d%b4%ec%9a%a9%ed%95%9c-%ec%84%b1%eb%8a%a5-%ed%85%8c%ec%8a%a4%ed%8a%b8","status":"publish","type":"post","link":"https:\/\/www.gyuroot.com\/wordpress\/?p=1014","title":{"rendered":"[Sprint] aws EC2\uc640 k6\ub97c \uc774\uc6a9\ud55c \uc131\ub2a5 \ud14c\uc2a4\ud2b8"},"content":{"rendered":"<div id=\"ez-toc-container\" class=\"ez-toc-v2_0_63 counter-hierarchy ez-toc-counter ez-toc-white ez-toc-container-direction\">\n<div class=\"ez-toc-title-container\">\n<p class=\"ez-toc-title \" >\ubaa9\ucc28<\/p>\n<span class=\"ez-toc-title-toggle\"><a href=\"#\" class=\"ez-toc-pull-right ez-toc-btn ez-toc-btn-xs ez-toc-btn-default ez-toc-toggle\" aria-label=\"Toggle Table of Content\"><span class=\"ez-toc-js-icon-con\"><span class=\"\"><span class=\"eztoc-hide\" style=\"display:none;\">Toggle<\/span><span class=\"ez-toc-icon-toggle-span\"><svg style=\"fill: #999;color:#999\" xmlns=\"http:\/\/www.w3.org\/2000\/svg\" class=\"list-377408\" width=\"20px\" height=\"20px\" viewBox=\"0 0 24 24\" fill=\"none\"><path d=\"M6 6H4v2h2V6zm14 0H8v2h12V6zM4 11h2v2H4v-2zm16 0H8v2h12v-2zM4 16h2v2H4v-2zm16 0H8v2h12v-2z\" fill=\"currentColor\"><\/path><\/svg><svg style=\"fill: #999;color:#999\" class=\"arrow-unsorted-368013\" xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"10px\" height=\"10px\" viewBox=\"0 0 24 24\" version=\"1.2\" baseProfile=\"tiny\"><path d=\"M18.2 9.3l-6.2-6.3-6.2 6.3c-.2.2-.3.4-.3.7s.1.5.3.7c.2.2.4.3.7.3h11c.3 0 .5-.1.7-.3.2-.2.3-.5.3-.7s-.1-.5-.3-.7zM5.8 14.7l6.2 6.3 6.2-6.3c.2-.2.3-.5.3-.7s-.1-.5-.3-.7c-.2-.2-.4-.3-.7-.3h-11c-.3 0-.5.1-.7.3-.2.2-.3.5-.3.7s.1.5.3.7z\"\/><\/svg><\/span><\/span><\/span><\/a><\/span><\/div>\n<nav><ul class='ez-toc-list ez-toc-list-level-1 ' ><li class='ez-toc-page-1 ez-toc-heading-level-1'><a class=\"ez-toc-link ez-toc-heading-1\" href=\"https:\/\/www.gyuroot.com\/wordpress\/?p=1014\/#_%ED%95%99%EC%8A%B5_%EB%AA%A9%ED%91%9C\" title=\"# \ud559\uc2b5 \ubaa9\ud45c\"># \ud559\uc2b5 \ubaa9\ud45c<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-1'><a class=\"ez-toc-link ez-toc-heading-2\" href=\"https:\/\/www.gyuroot.com\/wordpress\/?p=1014\/#_%ED%95%B4%EA%B2%B0_%EA%B3%BC%EC%A0%9C\" title=\"# \ud574\uacb0 \uacfc\uc81c\"># \ud574\uacb0 \uacfc\uc81c<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-3\" href=\"https:\/\/www.gyuroot.com\/wordpress\/?p=1014\/#1_aws_ec2_%EC%9D%B8%EC%8A%A4%ED%84%B4%EC%8A%A4_%EC%83%9D%EC%84%B1\" title=\"1. aws ec2 \uc778\uc2a4\ud134\uc2a4 \uc0dd\uc131\">1. aws ec2 \uc778\uc2a4\ud134\uc2a4 \uc0dd\uc131<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-4\" href=\"https:\/\/www.gyuroot.com\/wordpress\/?p=1014\/#2_install_k6\" title=\"2. install k6\">2. install k6<\/a><\/li><\/ul><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-1'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/www.gyuroot.com\/wordpress\/?p=1014\/#_%EC%8B%A4%EC%8A%B5_%EC%9E%90%EB%A3%8C\" title=\"# \uc2e4\uc2b5 \uc790\ub8cc\"># \uc2e4\uc2b5 \uc790\ub8cc<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-1'><a class=\"ez-toc-link ez-toc-heading-6\" href=\"https:\/\/www.gyuroot.com\/wordpress\/?p=1014\/#_%EA%B3%BC%EC%A0%9C_%ED%95%AD%EB%AA%A9%EB%B3%84_%EC%A7%84%ED%96%89_%EC%83%81%ED%99%A9\" title=\"# \uacfc\uc81c \ud56d\ubaa9\ubcc4 \uc9c4\ud589 \uc0c1\ud669\"># \uacfc\uc81c \ud56d\ubaa9\ubcc4 \uc9c4\ud589 \uc0c1\ud669<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-7\" href=\"https:\/\/www.gyuroot.com\/wordpress\/?p=1014\/#%EC%9D%B8%EC%8A%A4%ED%84%B4%EC%8A%A4_%EC%8B%9C%EC%9E%91\" title=\"\uc778\uc2a4\ud134\uc2a4 \uc2dc\uc791\">\uc778\uc2a4\ud134\uc2a4 \uc2dc\uc791<\/a><\/li><\/ul><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-1'><a class=\"ez-toc-link ez-toc-heading-8\" href=\"https:\/\/www.gyuroot.com\/wordpress\/?p=1014\/#basic_test\" title=\"basic test\">basic test<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-1'><a class=\"ez-toc-link ez-toc-heading-9\" href=\"https:\/\/www.gyuroot.com\/wordpress\/?p=1014\/#load_testjs\" title=\"load_test.js\">load_test.js<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-1'><a class=\"ez-toc-link ez-toc-heading-10\" href=\"https:\/\/www.gyuroot.com\/wordpress\/?p=1014\/#soak_testjs\" title=\"soak_test.js\">soak_test.js<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-1'><a class=\"ez-toc-link ez-toc-heading-11\" href=\"https:\/\/www.gyuroot.com\/wordpress\/?p=1014\/#stress_testjs\" title=\"stress_test.js\">stress_test.js<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-1'><a class=\"ez-toc-link ez-toc-heading-12\" href=\"https:\/\/www.gyuroot.com\/wordpress\/?p=1014\/#spike_testjs\" title=\"spike_test.js\">spike_test.js<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-1'><a class=\"ez-toc-link ez-toc-heading-13\" href=\"https:\/\/www.gyuroot.com\/wordpress\/?p=1014\/#_TROUBLE_SHOOTING_LOG\" title=\"# TROUBLE SHOOTING LOG\"># TROUBLE SHOOTING LOG<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-14\" href=\"https:\/\/www.gyuroot.com\/wordpress\/?p=1014\/#%EC%9B%90%EC%9D%B8\" title=\"\uc6d0\uc778\">\uc6d0\uc778<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-15\" href=\"https:\/\/www.gyuroot.com\/wordpress\/?p=1014\/#%ED%95%B4%EA%B2%B0_%EB%B0%A9%EC%95%88\" title=\"\ud574\uacb0 \ubc29\uc548\">\ud574\uacb0 \ubc29\uc548<\/a><\/li><\/ul><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-1'><a class=\"ez-toc-link ez-toc-heading-16\" href=\"https:\/\/www.gyuroot.com\/wordpress\/?p=1014\/#References\" title=\"#References\">#References<\/a><\/li><\/ul><\/nav><\/div>\n\n<h1 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"_%ED%95%99%EC%8A%B5_%EB%AA%A9%ED%91%9C\"><\/span># \ud559\uc2b5 \ubaa9\ud45c<span class=\"ez-toc-section-end\"><\/span><\/h1>\n\n\n<ul>\n<li>k6 \ub3c4\uad6c \ud65c\uc6a9\ubc95\uc744 \ud559\uc2b5\ud569\ub2c8\ub2e4.<\/li>\n\n\n<li>\uc131\ub2a5 \ud14c\uc2a4\ud2b8 \uc720\ud615\ubcc4 \uc2a4\ud06c\ub9bd\ud2b8\ub97c \uc791\uc131\ud560 \uc218 \uc788\uc2b5\ub2c8\ub2e4.<\/li>\n\n\n<li>aws ec2 \uc778\uc2a4\ud134\uc2a4\ub97c \ubaa8\ub2c8\ud130\ub9c1\ud560 \uc218 \uc788\uc2b5\ub2c8\ub2e4.<\/li>\n\n\n<li>aws\uc5d0\uc11c \uc81c\uacf5\ud558\ub294 \ubc84\uc2a4\ud2b8 \ud06c\ub808\ub527\uc744 \uc774\ud574\ud560 \uc218 \uc788\uc2b5\ub2c8\ub2e4.<\/li>\n\n<\/ul>\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity is-style-wide\"\/>\n\n\n<h1 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"_%ED%95%B4%EA%B2%B0_%EA%B3%BC%EC%A0%9C\"><\/span># \ud574\uacb0 \uacfc\uc81c<span class=\"ez-toc-section-end\"><\/span><\/h1>\n\n\n<h3 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"1_aws_ec2_%EC%9D%B8%EC%8A%A4%ED%84%B4%EC%8A%A4_%EC%83%9D%EC%84%B1\"><\/span>1. aws ec2 \uc778\uc2a4\ud134\uc2a4 \uc0dd\uc131<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n<ul>\n<li>\uac01\uc790\uc758 aws \uacc4\uc815\uc5d0\uc11c EC2 \uc778\uc2a4\ud134\uc2a4\ub97c \uc0dd\uc131\ud569\ub2c8\ub2e4.<\/li>\n\n\n<li>\ubc84\uc2a4\ud2b8 \uae30\ub2a5\uc774 \uc788\ub294 t2micro\ub97c \uc0dd\uc131\ud558\uc138\uc694<\/li>\n\n\n<li>ubuntu 20.04<\/li>\n\n<\/ul>\n\n\n<ol>\n<li>ssh \uc811\uc18d\n\uc0dd\uc131\ud55c ec2\uc5d0 \uc811\uc18d\uc744 \ud569\ub2c8\ub2e4.<\/li>\n\n\n<li>install docker on EC2<\/li>\n\n<\/ol>\n\n\n<pre class=\"wp-block-code\"><code>#\uc5c5\ub370\uc774\ud2b8 \ubc0f HTTP \ud328\ud0a4\uc9c0 \uc124\uce58\nsudo apt update\nsudo apt-get install -y ca-certificates   #\uacf5\uc778 \uc778\uc99d\uc11c\ub97c \uad00\ub9ac\ud558\uae30 \uc704\ud55c \ud328\ud0a4\uc9c0\n    curl \n    software-properties-common  #\uc18c\ud504\ud2b8\uc6e8\uc5b4 \uc800\uc7a5\uc18c \uad00\ub9ac \ub3c4\uad6c\n    apt-transport-https  #HTTPS \ud504\ub85c\ud1a0\ucf5c\uc744 \ud1b5\ud574 APT \ud328\ud0a4\uc9c0 \uad00\ub9ac\uc790\ub97c \uc0ac\uc6a9\ud560 \uc218 \uc788\uac8c \ud574\uc8fc\ub294 \ud328\ud0a4\uc9c0\n    gnupg  #\uc554\ud638\ud654 \ubc0f \ub514\uc9c0\ud138 \uc11c\uba85 \ub3c4\uad6c\uc778 GNU Privacy Guard\ub97c \uc124\uce58\n    lsb-release #\ud604\uc7ac \uc6b4\uc601 \uccb4\uc81c\uc758 \ub9b4\ub9ac\uc2a4 \uc815\ubcf4\ub97c \ud655\uc778\ud558\ub294 \ub370 \uc0ac\uc6a9\ub418\ub294 \ud328\ud0a4\uc9c0\n# GPG \ud0a4 \ubc0f \uc800\uc7a5\uc18c \ucd94\uac00\nsudo mkdir -p \/etc\/apt\/keyrings\n#Docker\uc758 GPG \ud0a4\ub97c \ub2e4\uc6b4\ub85c\ub4dc\ud558\uace0 \ud30c\uc77c\ub85c \uc800\uc7a5\ud569\ub2c8\ub2e4. GPG \ud0a4\ub294 \ud328\ud0a4\uc9c0 \uad00\ub9ac\uc790\uac00 Docker \uc800\uc7a5\uc18c\uc5d0\uc11c \uc81c\uacf5\ud558\ub294 \ud328\ud0a4\uc9c0\uc758 \ubb34\uacb0\uc131\uc744 \ud655\uc778\ud558\ub294 \ub370 \uc0ac\uc6a9\ncurl -fsSL https:\/\/download.docker.com\/linux\/ubuntu\/gpg | sudo gpg --dearmor -o \/etc\/apt\/keyrings\/docker.gpg\n#Docker \uc800\uc7a5\uc18c\ub97c \uc2dc\uc2a4\ud15c\uc758 \ud328\ud0a4\uc9c0 \uc18c\uc2a4 \ubaa9\ub85d\uc5d0 \ucd94\uac00\necho \n  &quot;deb [arch=$(dpkg --print-architecture) signed-by=\/etc\/apt\/keyrings\/docker.gpg] https:\/\/download.docker.com\/linux\/ubuntu \n  $(lsb_release -cs) stable&quot; | sudo tee \/etc\/apt\/sources.list.d\/docker.list &gt; \/dev\/null\n# \ub3c4\ucee4\uc5d4\uc9c4 \uc124\uce58\nsudo apt update\nsudo apt install docker-ce docker-ce-cli containerd.io<\/code><\/pre>\n\n\n<ol>\n<li>run container<\/li>\n\n<\/ol>\n\n\n<ul>\n<li>\uc131\ub2a5 \ud14c\uc2a4\ud2b8\ub97c \uc704\ud55c \ud0c0\uae43 \uc11c\ubc84\ub97c \ucee8\ud14c\uc774\ub108\ub85c \ubc30\ud3ec\ud569\ub2c8\ub2e4.<\/li>\n\n<\/ul>\n\n\n<pre class=\"wp-block-code\"><code>sudo docker run --name &lt;\uc774\ub984&gt; -d -p 8080:8080 sebcontents\/cozserver:1.0<\/code><\/pre>\n\n\n<ul>\n<li>\uc11c\ubc84 \ubc30\ud3ec \ud655\uc778<\/li>\n\n<\/ul>\n\n\n<pre class=\"wp-block-code\"><code>curl http:\/\/localhost:8080<\/code><\/pre>\n\n\n<h3 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"2_install_k6\"><\/span>2. install k6<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n<ul>\n<li>\uacf5\uc2dd \ud648\ud398\uc774\uc9c0\ub97c \uc774\uc6a9\ud558\uc5ec k6\ub97c \uc124\uce58\ud569\ub2c8\ub2e4. (\ud2b8\ub7ec\ube14 \uc288\ud305 \uc8fc\uc758)<\/li>\n\n\n<li>\ud074\ub77c\uc6b0\ub4dc \uc0c1\uc5d0 \ube60\ub978 \uc124\uce58\ub97c \uc704\ud574\uc11c snapd\ub3c4 \ucd94\ucc9c\ud569\ub2c8\ub2e4.\n<a href=\"https:\/\/snapcraft.io\/install\/k6\/ubuntu\">https:\/\/snapcraft.io\/install\/k6\/ubuntu<\/a><\/li>\n\n<\/ul>\n\n\n<pre class=\"wp-block-code\"><code>sudo apt update\nsudo apt install snapd\nsudo snap install k6<\/code><\/pre>\n\n\n<ol>\n<li><a href=\"https:\/\/github.com\/cs-devops-bootcamp\/sprint_k6_test\">\ub9ac\ud3ec\uc9c0\ud1a0\ub9ac<\/a>\uc5d0 \uc720\ud615\ubcc4 \ud14c\uc2a4\ud2b8 \uc2a4\ud06c\ub9bd\ud2b8\uac00 \uc791\uc131\ub418\uc5b4 \uc788\uc2b5\ub2c8\ub2e4.\n\uc55e\uc5d0\uc11c \uc124\uba85\ud55c \ub0b4\uc6a9\uacfc \ube44\uad50\ud558\uba74\uc11c \ucf54\ub4dc\uc758 \uad6c\uc870\ub97c \uc798 \uc0b4\ud3b4\ubcf4\uc2dc\uae30 \ubc14\ub78d\ub2c8\ub2e4.<\/li>\n\n\n<li>run the tests\n\uac01\uac01\uc758 \uc2a4\ud06c\ub9bd\ud2b8\ub97c \uc2e4\ud589\ud574 \ubcf4\uace0 ec2 \uc778\uc2a4\ud134\uc2a4\uc758 CPU \uc0ac\uc6a9\ub960 \ub300\uc2dc\ubcf4\ub4dc\ub97c \ud655\uc778\ud574 \ubcf4\uc138\uc694.\n\ud559\uc2b5\ud588\ub358 \ub0b4\uc6a9\uc758 \uadf8\ub798\ud504\uc640 \uc720\uc0ac\ud558\uac8c \uad00\ucc30\ub418\ub294 \uc9c0 \ud655\uc778\ud558\uc138\uc694.<\/li>\n\n<\/ol>\n\n\n<pre class=\"wp-block-code\"><code>k6 run basic_test.js\nk6 run load_test.js\nk6 run stress_test.js\nk6 run spike_test.js\nk6 run soak_test.js<\/code><\/pre>\n\n\n<ol>\n<li>inspect aws burst credit\n\ub300\uc2dc \ubcf4\ub4dc\uc758 CPU \ud06c\ub808\ub527 \uc0ac\uc6a9\ub7c9(\uac1c\uc218) \uc640 CPU \ud06c\ub808\ub527 \ubc38\ub7f0\uc2a4(\uac1c\uc218)\ub97c \uad00\ucc30\ud569\ub2c8\ub2e4.<\/li>\n\n<\/ol>\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity is-style-wide\"\/>\n\n\n<h1 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"_%EC%8B%A4%EC%8A%B5_%EC%9E%90%EB%A3%8C\"><\/span># \uc2e4\uc2b5 \uc790\ub8cc<span class=\"ez-toc-section-end\"><\/span><\/h1>\n\n\n<p class=\"has-text-color\" style=\"color: rgb(0, 0, 0)\"><a href=\"https:\/\/github.com\/cs-devops-bootcamp\/sprint_k6_test\">sprint_k6_test<\/a><\/p>\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity is-style-wide\"\/>\n\n\n<h1 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"_%EA%B3%BC%EC%A0%9C_%ED%95%AD%EB%AA%A9%EB%B3%84_%EC%A7%84%ED%96%89_%EC%83%81%ED%99%A9\"><\/span># \uacfc\uc81c \ud56d\ubaa9\ubcc4 \uc9c4\ud589 \uc0c1\ud669<span class=\"ez-toc-section-end\"><\/span><\/h1>\n\n\n<h3 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"%EC%9D%B8%EC%8A%A4%ED%84%B4%EC%8A%A4_%EC%8B%9C%EC%9E%91\"><\/span>\uc778\uc2a4\ud134\uc2a4 \uc2dc\uc791<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n<p class=\"has-text-color\" style=\"color: rgb(0, 0, 0)\">CPU \uc0ac\uc6a9\ub960\uc774 5%\uc774\ud558\ub85c credit \uc0ac\uc6a9\uc774 \uac70\uc758 \uc5c6\uc74c<\/p>\n\n\n<figure class=\"wp-block-image size-large\"><img decoding=\"async\" src=\"https:\/\/www.gyuroot.com\/wordpress\/wp-content\/uploads\/image-232.png?v=1688460020\" alt=\"\"\/><\/figure>\n\n\n<h1 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"basic_test\"><\/span>basic test<span class=\"ez-toc-section-end\"><\/span><\/h1>\n\n\n<pre class=\"wp-block-code\"><code>import http from &#039;k6\/http&#039;; \/\/ \ubd80\ud558 \ud14c\uc2a4\ud2b8 \uc720\ud615 http request\nimport { sleep } from &#039;k6&#039;; \/\/ sleep \ud568\uc218 \uac00\uc838\uc624\uae30\nexport let options = {\n    insecureSkipTLSVerify: true, \/\/ HTTPS \uc5f0\uacb0\uc5d0\uc11c TLS \uc778\uc99d\uc11c\ub97c \ud655\uc778\ud558\uc9c0 \uc54a\ub3c4\ub85d \ud558\ub294 \uae30\ub2a5\n    noConnectionReuse: false, \/\/ \uc7ac\uc0ac\uc6a9 \uc5f0\uacb0 \uc0ac\uc6a9\n    vus: 10, \/\/ \uac00\uc0c1\uc0ac\uc6a9\uc790 \uc218\n    duration: &#039;30s&#039; \/\/ \uc2e4\ud589\uc2dc\uac04\n};\n\nexport default () =&gt; {\n    http.get(&#039;http:\/\/localhost:8080&#039;) \/\/ get \uc694\uccad\n    sleep(1); \/\/ 1\ucd08 \ub3d9\uc548 \ub300\uae30 (\uc2e4\uc81c \uc0ac\uc6a9\uc790 \ucc98\ub7fc \uc694\uccad\ud558\uae30 \uc704\ud568)\n};<\/code><\/pre>\n\n\n<pre class=\"wp-block-code\"><code>ubuntu@ip-172-31-4-230:~\/k6_test$ k6 run basic_test.js\n\n          \/      |\u203e\u203e| \/\u203e\u203e\/   \/\u203e\u203e\/\n     \/  \/       |  |\/  \/   \/  \/\n    \/  \/        |     (   \/   \u203e\u203e\n   \/             |  |   |  (\u203e)  |\n  \/ __________   |__| __ _____\/ .io\n\n  execution: local\n     script: basic_test.js\n     output: -\n\n  scenarios: (100.00%) 1 scenario, 10 max VUs, 1m0s max duration (incl. graceful stop):\n           * default: 10 looping VUs for 30s (gracefulStop: 30s)\n\n\n     data_received..................: 134 kB 4.4 kB\/s\n     data_sent......................: 24 kB  796 B\/s\n     http_req_blocked...............: avg=1.55ms   min=3.65\u00b5s   med=5.11\u00b5s  max=47.65ms  p(90)=9.3\u00b5s    p(95)=15.02\u00b5s\n     http_req_connecting............: avg=177.11\u00b5s min=0s       med=0s      max=6.54ms   p(90)=0s       p(95)=0s\n     http_req_duration..............: avg=2.19ms   min=703.53\u00b5s med=1.28ms  max=38.84ms  p(90)=2.73ms   p(95)=4.25ms\n       { expected_response:true }...: avg=2.19ms   min=703.53\u00b5s med=1.28ms  max=38.84ms  p(90)=2.73ms   p(95)=4.25ms\n     http_req_failed................: 0.00%  \u2713 0        \u2717 300\n     http_req_receiving.............: avg=64.28\u00b5s  min=20.88\u00b5s  med=38.12\u00b5s max=365.33\u00b5s p(90)=149.41\u00b5s p(95)=161.75\u00b5s\n     http_req_sending...............: avg=32.65\u00b5s  min=9.44\u00b5s   med=12.97\u00b5s max=1.16ms   p(90)=28.58\u00b5s  p(95)=81.05\u00b5s\n     http_req_tls_handshaking.......: avg=0s       min=0s       med=0s      max=0s       p(90)=0s       p(95)=0s\n     http_req_waiting...............: avg=2.1ms    min=642.17\u00b5s med=1.17ms  max=38.46ms  p(90)=2.66ms   p(95)=4.08ms\n     http_reqs......................: 300    9.953435\/s\n     iteration_duration.............: avg=1s       min=1s       med=1s      max=1.08s    p(90)=1s       p(95)=1s\n     iterations.....................: 300    9.953435\/s\n     vus............................: 10     min=10     max=10\n     vus_max........................: 10     min=10     max=10\n\n\nrunning (0m30.1s), 00\/10 VUs, 300 complete and 0 interrupted iterations\ndefault \u2713 [======================================] 10 VUs  30s<\/code><\/pre>\n\n\n<figure class=\"wp-block-image size-large\"><img decoding=\"async\" src=\"https:\/\/www.gyuroot.com\/wordpress\/wp-content\/uploads\/image-233.png?v=1688460023\" alt=\"\"\/><\/figure>\n\n\n<h1 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"load_testjs\"><\/span><strong>load_test.js<\/strong><span class=\"ez-toc-section-end\"><\/span><\/h1>\n\n\n<p class=\"has-text-color\" style=\"color: rgb(0, 0, 0)\">\ud3c9\uade0 \ubd80\ud558 \ud14c\uc2a4\ud2b8\ub294 \ud504\ub85c\ub355\uc158 \ud658\uacbd\uc758 \ud3c9\uade0 \ub3d9\uc791\uc744 \ubc18\uc601\ud558\ub294 \ucd08\ub2f9 \ub3d9\uc2dc \uc0ac\uc6a9\uc790 \ubc0f \uc694\uccad \uc218\ub97c \uc2dc\ubbac\ub808\uc774\uc158\ud569\ub2c8\ub2e4.<\/p>\n\n\n<pre class=\"wp-block-code\"><code>import http from &quot;k6\/http&quot;; \/\/ \ubd80\ud558 \ud14c\uc2a4\ud2b8 \uc720\ud615 http request\nimport { sleep } from &#039;k6&#039;; \/\/ sleep \ud568\uc218 \uac00\uc838\uc624\uae30\nexport let options = {\n    insecureSkipTLSVerify: true, \/\/ HTTPS \uc5f0\uacb0\uc5d0\uc11c TLS \uc778\uc99d\uc11c\ub97c \ud655\uc778\ud558\uc9c0 \uc54a\ub3c4\ub85d \ud558\ub294 \uae30\ub2a5\n    noConnectionReuse: false, \/\/ \uc7ac\uc0ac\uc6a9 \uc5f0\uacb0 \uc0ac\uc6a9\n    stages: [  \/\/ \ub2e8\uacc4\ubcc4 \uc2dc\ub098\ub9ac\uc624\ub97c \uc124\uc815\n        { duration: &#039;5m&#039;, target: 100 }, \/\/ 5\ubd84 \ub3d9\uc548 100\uac1c\uc758 \uac00\uc0c1 \uc0ac\uc6a9\uc790\ub97c \uc720\uc9c0\n        { duration: &#039;10m&#039;, target: 100 }, \/\/ 10\ubd84 \ub3d9\uc548 100\uac1c\uc758 \uac00\uc0c1 \uc0ac\uc6a9\uc790 \uc720\uc9c0\n        { duration: &#039;5m&#039;, target: 0 },   \/\/ 5\ubd84 \ub3d9\uc548 \uac00\uc0c1 \uc0ac\uc6a9\uc790\ub97c 0\uc73c\ub85c \uc904\uc784\n    ],\n    thresholds: {   \/\/ \ubd80\ud558 \ud14c\uc2a4\ud2b8 \uacb0\uacfc\ub97c \ud3c9\uac00\ud558\ub294 \uc784\uacc4\uac12\uc744 \uc124\uc815\n        http_req_duration: [&#039;p(99)&lt;150&#039;], \/\/ \uc9c0\ud45c\uc758 99%\uac00 150ms \uc774\ud558\ub97c \uc720\uc9c0\n    }\n};\nexport default () =&gt; {\n    let respose = http.get(&#039;http:\/\/localhost:8080&#039;);\n    sleep(1);\n};<\/code><\/pre>\n\n\n<pre class=\"wp-block-code\"><code>ubuntu@ip-172-31-4-230:~\/k6_test$ k6 run load_test.js\n\n          \/      |\u203e\u203e| \/\u203e\u203e\/   \/\u203e\u203e\/\n     \/  \/       |  |\/  \/   \/  \/\n    \/  \/        |     (   \/   \u203e\u203e\n   \/             |  |   |  (\u203e)  |\n  \/ __________   |__| __ _____\/ .io\n\n  execution: local\n     script: load_test.js\n     output: -\n\n  scenarios: (100.00%) 1 scenario, 100 max VUs, 20m30s max duration (incl. graceful stop):\n           * default: Up to 100 looping VUs for 20m0s over 3 stages (gracefulRampDown: 30s, gracefulStop: 30s)\n\n\n     data_received..................: 40 MB  33 kB\/s\n     data_sent......................: 7.2 MB 6.0 kB\/s\n     http_req_blocked...............: avg=7.02\u00b5s   min=3.39\u00b5s   med=5.28\u00b5s   max=4.27ms  p(90)=7.49\u00b5s   p(95)=10.07\u00b5s\n     http_req_connecting............: avg=239ns    min=0s       med=0s       max=4.06ms  p(90)=0s       p(95)=0s\n   \u2713 http_req_duration..............: avg=1.47ms   min=511.37\u00b5s med=1.17ms   max=22.66ms p(90)=2.25ms   p(95)=2.79ms\n       { expected_response:true }...: avg=1.47ms   min=511.37\u00b5s med=1.17ms   max=22.66ms p(90)=2.25ms   p(95)=2.79ms\n     http_req_failed................: 0.00%  \u2713 0         \u2717 90017\n     http_req_receiving.............: avg=106.64\u00b5s min=18.66\u00b5s  med=72.59\u00b5s  max=20.13ms p(90)=195.81\u00b5s p(95)=213.94\u00b5s\n     http_req_sending...............: avg=28.43\u00b5s  min=8.68\u00b5s   med=13.86\u00b5s  max=15.95ms p(90)=39.54\u00b5s  p(95)=72.99\u00b5s\n     http_req_tls_handshaking.......: avg=0s       min=0s       med=0s       max=0s      p(90)=0s       p(95)=0s\n     http_req_waiting...............: avg=1.33ms   min=425.17\u00b5s med=993.04\u00b5s max=22.6ms  p(90)=2.13ms   p(95)=2.64ms\n     http_reqs......................: 90017  74.952428\/s\n     iteration_duration.............: avg=1s       min=1s       med=1s       max=1.3s    p(90)=1s       p(95)=1s\n     iterations.....................: 90017  74.952428\/s\n     vus............................: 1      min=1       max=100\n     vus_max........................: 100    min=100     max=100\n\n\nrunning (20m01.0s), 000\/100 VUs, 90017 complete and 0 interrupted iterations\ndefault \u2713 [======================================] 000\/100 VUs  20m0s<\/code><\/pre>\n\n\n<figure class=\"wp-block-image size-large\"><img decoding=\"async\" src=\"https:\/\/www.gyuroot.com\/wordpress\/wp-content\/uploads\/image-234.png?v=1688460026\" alt=\"\"\/><\/figure>\n\n\n<h1 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"soak_testjs\"><\/span>soak_test.js<span class=\"ez-toc-section-end\"><\/span><\/h1>\n\n\n<ul>\n<li>\uc7a5\uae30\uac04\uc5d0 \uac78\uce5c \uc2dc\uc2a4\ud15c\uc758 \uc131\ub2a5 \uc800\ud558 \ubc0f \ub9ac\uc18c\uc2a4 \uc18c\ube44.<\/li>\n\n\n<li>\ud655\uc7a5\ub41c \uae30\uac04 \ub3d9\uc548 \uc2dc\uc2a4\ud15c\uc758 \uac00\uc6a9\uc131 \ubc0f \uc548\uc815\uc131.<\/li>\n\n<\/ul>\n\n\n<pre class=\"wp-block-code\"><code>import http from &quot;k6\/http&quot;; \/\/ \ubd80\ud558 \ud14c\uc2a4\ud2b8 \uc720\ud615 http request\nimport { sleep, check } from &#039;k6&#039;; \/\/ sleep \ud568\uc218 \uac00\uc838\uc624\uae30\nexport let options = {\n    insecureSkipTLSVerify: true, \/\/ HTTPS \uc5f0\uacb0\uc5d0\uc11c TLS \uc778\uc99d\uc11c\ub97c \ud655\uc778\ud558\uc9c0 \uc54a\ub3c4\ub85d \ud558\ub294 \uae30\ub2a5\n    noConnectionReuse: false, \/\/ \uc7ac\uc0ac\uc6a9 \uc5f0\uacb0 \uc0ac\uc6a9\n    stages: [  \/\/ \ub2e8\uacc4\ubcc4 \uc2dc\ub098\ub9ac\uc624\ub97c \uc124\uc815\n        { duration: &#039;2m&#039;, target: 400 }, \/\/ 2\ubd84\ub3d9\uc548 400\uac1c\uc758 \uac00\uc0c1 \uc0ac\uc6a9\uc790\ub97c \uc720\uc9c0\n        { duration: &#039;3h56m&#039;, target: 400 }, \/\/ 3\uc2dc\uac04 56\ubd84\ub3d9\uc548 400\uac1c\uc758 \uac00\uc0c1 \uc0ac\uc6a9\uc790\ub97c \uc720\uc9c0\n        { duration: &#039;2m&#039;, target: 0 },     \/\/ 2\ubd84\ub3d9\uc548 \uac00\uc0c1 \uc0ac\uc6a9\uc790\ub97c 0\uc73c\ub85c \uc904\uc784\n    ],  \n};\nexport default function () {\n    const res = http.get(&#039;http:\/\/localhost:8080&#039;);\n\/\/check \ud568\uc218\ub97c \uc0ac\uc6a9\ud558\uc5ec \uc751\ub2f5\uc744 \uac80\uc0ac\ud569\ub2c8\ub2e4. \n\/\/\uc774 \uacbd\uc6b0, \uc751\ub2f5\uc758 \uc0c1\ud0dc \ucf54\ub4dc\uac00 200\uc778\uc9c0 \ud655\uc778\ud569\ub2c8\ub2e4. \n\/\/\uac80\uc0ac \uacb0\uacfc\uac00 false\uc778 \uacbd\uc6b0 \uc624\ub958\uac00 \ubc1c\uc0dd\n    check(res, { &#039;status was 200&#039;: (r) =&gt; r.status == 200 });\n    sleep(1);\n  };<\/code><\/pre>\n\n\n<figure class=\"wp-block-image size-large\"><img decoding=\"async\" src=\"https:\/\/www.gyuroot.com\/wordpress\/wp-content\/uploads\/image-235.png?v=1688460029\" alt=\"\"\/><\/figure>\n\n\n<h1 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"stress_testjs\"><\/span>stress_test.js<span class=\"ez-toc-section-end\"><\/span><\/h1>\n\n\n<p class=\"has-text-color\" style=\"color: rgb(0, 0, 0)\">\uc2a4\ud2b8\ub808\uc2a4 \ud14c\uc2a4\ud2b8\ub294 \uc0ac\uc6a9\ub7c9\uc774 \ub9ce\uc740 \uc870\uac74\uc5d0\uc11c \uc2dc\uc2a4\ud15c\uc758 \uc548\uc815\uc131\uacfc \uc2e0\ub8b0\uc131\uc744 \ud655\uc778\ud569\ub2c8\ub2e4.\u00a0\uc2dc\uc2a4\ud15c\uc740 \ucc98\ub9ac \uae30\ud55c, \uc6d4\uae09\ub0a0, \ucd9c\ud1f4\uadfc \uc2dc\uac04, \uadfc\ubb34 \uc885\ub8cc \ubc0f \uace0\ubd80\ud558 \uc774\ubca4\ud2b8\ub97c \uc0dd\uc131\ud558\uae30 \uc704\ud574 \uacb0\ud569\ub420 \uc218 \uc788\ub294 \uae30\ud0c0 \ub9ce\uc740 \uaca9\ub9ac\ub41c \ub3d9\uc791\uacfc \uac19\uc740 \ube44\uc815\uc0c1\uc801\uc778 \uc21c\uac04\uc5d0 \ud3c9\uc18c\ubcf4\ub2e4 \ub192\uc740 \uc791\uc5c5 \ubd80\ud558\ub97c \ubc1b\uc744 \uc218 \uc788\uc2b5\ub2c8\ub2e4.<\/p>\n\n\n<figure class=\"wp-block-image size-large\"><img decoding=\"async\" src=\"https:\/\/www.gyuroot.com\/wordpress\/wp-content\/uploads\/image-236-1024x691.png?v=1688460033\" alt=\"\"\/><\/figure>\n\n\n<figure class=\"wp-block-image size-large\"><img decoding=\"async\" src=\"https:\/\/www.gyuroot.com\/wordpress\/wp-content\/uploads\/image-237.png?v=1688460036\" alt=\"\"\/><\/figure>\n\n\n<h1 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"spike_testjs\"><\/span>spike_test.js<span class=\"ez-toc-section-end\"><\/span><\/h1>\n\n\n<p class=\"has-text-color\" style=\"color: rgb(0, 0, 0)\">\uc2dc\uc2a4\ud15c\uc774 \uac11\uc791\uc2a4\ub7fd\uace0 \ub300\ub7c9\uc758 \uc0ac\uc6a9 \uae09\uc99d\uc5d0\uc11c \uc0b4\uc544\ub0a8\uace0 \uc131\ub2a5\uc744 \ubc1c\ud718\ud558\ub294\uc9c0 \ud655\uc778<\/p>\n\n\n<figure class=\"wp-block-image size-large\"><img decoding=\"async\" src=\"https:\/\/www.gyuroot.com\/wordpress\/wp-content\/uploads\/image-238.png?v=1688460039\" alt=\"\"\/><\/figure>\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity is-style-wide\"\/>\n\n\n<h1 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"_TROUBLE_SHOOTING_LOG\"><\/span># TROUBLE SHOOTING LOG<span class=\"ez-toc-section-end\"><\/span><\/h1>\n\n\n<p class=\"has-background\" style=\"background-color: rgb(251, 243, 219)\">&#x1f4a1; \ubb38\uc81c \ub0b4\uc6a9<\/p>\n\n\n<h3 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"%EC%9B%90%EC%9D%B8\"><\/span>\uc6d0\uc778<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n<h3 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"%ED%95%B4%EA%B2%B0_%EB%B0%A9%EC%95%88\"><\/span>\ud574\uacb0 \ubc29\uc548<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n<h1 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"References\"><\/span>#References<span class=\"ez-toc-section-end\"><\/span><\/h1>\n\n\n<p class=\"has-text-color\" style=\"color: rgb(0, 0, 0)\">\ub0b4\uc6a9<\/p>\n\n<script type=\"text\/javascript\"> toolTips('.classtoolTips11','<span class=\"notion-enable-hover\" data-token-index=\"0\">Uniform Resource Locator<br\/><\/span><br\/><br\/><a href=\"\/wordpress\/?p=65\">Detail<\/a>'); <\/script>","protected":false},"excerpt":{"rendered":"<p># \ud559\uc2b5 \ubaa9\ud45c # \ud574\uacb0 \uacfc\uc81c 1. aws ec2 \uc778\uc2a4\ud134\uc2a4 \uc0dd\uc131 2. install k6 # \uc2e4\uc2b5 \uc790\ub8cc sprint_k6_test # \uacfc\uc81c \ud56d\ubaa9\ubcc4 \uc9c4\ud589 \uc0c1\ud669 \uc778\uc2a4\ud134\uc2a4 \uc2dc\uc791 CPU \uc0ac\uc6a9\ub960\uc774 5%\uc774\ud558\ub85c credit \uc0ac\uc6a9\uc774 \uac70\uc758 \uc5c6\uc74c basic test load_test.js \ud3c9\uade0 \ubd80\ud558 \ud14c\uc2a4\ud2b8\ub294 \ud504\ub85c\ub355\uc158 \ud658\uacbd\uc758 \ud3c9\uade0 \ub3d9\uc791\uc744 \ubc18\uc601\ud558\ub294 \ucd08\ub2f9 \ub3d9\uc2dc \uc0ac\uc6a9\uc790 \ubc0f \uc694\uccad \uc218\ub97c \uc2dc\ubbac\ub808\uc774\uc158\ud569\ub2c8\ub2e4. soak_test.js stress_test.js \uc2a4\ud2b8\ub808\uc2a4 \ud14c\uc2a4\ud2b8\ub294 \uc0ac\uc6a9\ub7c9\uc774 &#8230; <a title=\"[Sprint] aws EC2\uc640 k6\ub97c \uc774\uc6a9\ud55c \uc131\ub2a5 \ud14c\uc2a4\ud2b8\" class=\"read-more\" href=\"https:\/\/www.gyuroot.com\/wordpress\/?p=1014\" aria-label=\"More on [Sprint] aws EC2\uc640 k6\ub97c \uc774\uc6a9\ud55c \uc131\ub2a5 \ud14c\uc2a4\ud2b8\">Read more<\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_eb_attr":""},"categories":[45],"tags":[],"_links":{"self":[{"href":"https:\/\/www.gyuroot.com\/wordpress\/index.php?rest_route=\/wp\/v2\/posts\/1014"}],"collection":[{"href":"https:\/\/www.gyuroot.com\/wordpress\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.gyuroot.com\/wordpress\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.gyuroot.com\/wordpress\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.gyuroot.com\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=1014"}],"version-history":[{"count":1,"href":"https:\/\/www.gyuroot.com\/wordpress\/index.php?rest_route=\/wp\/v2\/posts\/1014\/revisions"}],"predecessor-version":[{"id":1067,"href":"https:\/\/www.gyuroot.com\/wordpress\/index.php?rest_route=\/wp\/v2\/posts\/1014\/revisions\/1067"}],"wp:attachment":[{"href":"https:\/\/www.gyuroot.com\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=1014"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.gyuroot.com\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=1014"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.gyuroot.com\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=1014"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}