{"id":49881,"date":"2024-08-03T12:58:30","date_gmt":"2024-08-03T03:58:30","guid":{"rendered":"https:\/\/m9js.shop\/blog\/development\/take-advantage-of-advanced-profiling-and-performance-analysis-tools-in-spring-boot"},"modified":"2024-08-03T13:46:15","modified_gmt":"2024-08-03T04:46:15","slug":"take-advantage-of-advanced-profiling-and-performance-analysis-tools-in-spring-boot","status":"publish","type":"post","link":"https:\/\/m9js.shop\/blog\/development\/take-advantage-of-advanced-profiling-and-performance-analysis-tools-in-spring-boot","title":{"rendered":"Spring Boot\uc5d0\uc11c\uc758 \uace0\uae09 \ud504\ub85c\ud30c\uc77c\ub9c1\uacfc \uc131\ub2a5 \ubd84\uc11d \ub3c4\uad6c \ud65c\uc6a9"},"content":{"rendered":"
Spring Boot\ub294 \ud604\ub300 \uc560\ud50c\ub9ac\ucf00\uc774\uc158 \uac1c\ubc1c\uc5d0\uc11c \ub110\ub9ac \uc0ac\uc6a9\ub418\ub294 \ud504\ub808\uc784\uc6cc\ud06c\ub85c, \uac1c\ubc1c\uc790\uc5d0\uac8c \ube60\ub974\uace0 \ud6a8\uc728\uc801\uc778 \uac1c\ubc1c \ud658\uacbd\uc744 \uc81c\uacf5\ud569\ub2c8\ub2e4. \uadf8\ub7ec\ub098 \uc560\ud50c\ub9ac\ucf00\uc774\uc158\uc774 \ubcf5\uc7a1\ud574\uc9d0\uc5d0 \ub530\ub77c \uc131\ub2a5 \ubb38\uc81c\ub3c4 \ubc1c\uc0dd\ud560 \uc218 \uc788\uc2b5\ub2c8\ub2e4. \uc774 \uae00\uc5d0\uc11c\ub294 Spring Boot\uc5d0\uc11c \uace0\uae09 \ud504\ub85c\ud30c\uc77c\ub9c1\uacfc \uc131\ub2a5 \ubd84\uc11d \ub3c4\uad6c\ub97c \ud65c\uc6a9\ud558\ub294 \ubc29\ubc95\uc5d0 \ub300\ud574 \ub2e4\ub8e8\uaca0\uc2b5\ub2c8\ub2e4. \ub2e4\uc74c\uc758 \uc11c\ube0c\uc8fc\uc81c\ub97c \ud1b5\ud574 \uc131\ub2a5 \ucd5c\uc801\ud654\uc758 \uc911\uc694\uc131\uacfc \uc774\ub97c \uc704\ud55c \ub3c4\uad6c \ubc0f \uae30\ubc95\uc744 \uc0b4\ud3b4\ubcf4\uaca0\uc2b5\ub2c8\ub2e4.<\/p>\n
\uc131\ub2a5 \ubd84\uc11d\uc740 \uc560\ud50c\ub9ac\ucf00\uc774\uc158\uc758 \ud6a8\uc728\uc131\uc744 \ub192\uc774\uace0 \uc0ac\uc6a9\uc790 \uacbd\ud5d8\uc744 \uac1c\uc120\ud558\ub294 \ub370 \ud544\uc218\uc801\uc785\ub2c8\ub2e4. \uc131\ub2a5 \uc800\ud558\uac00 \ubc1c\uc0dd\ud558\uba74 \uc0ac\uc6a9\uc790 \uc774\ud0c8\ub960\uc774 \uc99d\uac00\ud558\uace0, \uc774\ub294 \ub9e4\ucd9c \uac10\uc18c\ub85c \uc774\uc5b4\uc9c8 \uc218 \uc788\uc2b5\ub2c8\ub2e4. \uc608\ub97c \ub4e4\uc5b4, Amazon\uc740 \ud398\uc774\uc9c0 \ub85c\ub529 \uc2dc\uac04\uc774 1\ucd08 \uc99d\uac00\ud560 \ub54c\ub9c8\ub2e4 \ub9e4\ucd9c\uc774 1% \uac10\uc18c\ud55c\ub2e4\uace0 \ubcf4\uace0\ud588\uc2b5\ub2c8\ub2e4. \ub530\ub77c\uc11c \uc131\ub2a5 \ubd84\uc11d\uc740 \ub2e8\uc21c\ud55c \uc120\ud0dd\uc774 \uc544\ub2c8\ub77c \ud544\uc218\uc801\uc778 \uacfc\uc815\uc785\ub2c8\ub2e4.<\/p>\n
Spring Boot\ub294 \uae30\ubcf8\uc801\uc73c\ub85c \uba87 \uac00\uc9c0 \ud504\ub85c\ud30c\uc77c\ub9c1 \ub3c4\uad6c\ub97c \uc81c\uacf5\ud569\ub2c8\ub2e4. \uc774 \ub3c4\uad6c\ub4e4\uc740 \uc560\ud50c\ub9ac\ucf00\uc774\uc158\uc758 \uc131\ub2a5\uc744 \ubaa8\ub2c8\ud130\ub9c1\ud558\uace0 \ubd84\uc11d\ud558\ub294 \ub370 \uc720\uc6a9\ud569\ub2c8\ub2e4.<\/p>\n
\/\/ Spring Boot Actuator \uc124\uc815 \uc608\uc81c\nspring:\n actuator:\n endpoints:\n web:\n exposure:\n include: \"*\"<\/code><\/pre>\n3. \uace0\uae09 \ud504\ub85c\ud30c\uc77c\ub9c1 \ub3c4\uad6c<\/h2>\n
\uae30\ubcf8 \ub3c4\uad6c \uc678\uc5d0\ub3c4 \uace0\uae09 \ud504\ub85c\ud30c\uc77c\ub9c1 \ub3c4\uad6c\ub97c \ud65c\uc6a9\ud558\uba74 \ub354 \uae4a\uc774 \uc788\ub294 \uc131\ub2a5 \ubd84\uc11d\uc774 \uac00\ub2a5\ud569\ub2c8\ub2e4. \uc774\ub7ec\ud55c \ub3c4\uad6c\ub4e4\uc740 CPU \uc0ac\uc6a9\ub7c9, \uba54\ubaa8\ub9ac \ub204\uc218, \uc2a4\ub808\ub4dc \uc0c1\ud0dc \ub4f1\uc744 \uc0c1\uc138\ud788 \ubd84\uc11d\ud560 \uc218 \uc788\uc2b5\ub2c8\ub2e4.<\/p>\n
\ucd94\ucc9c \ub3c4\uad6c:<\/h3>\n\n- VisualVM<\/strong>: Java \uc560\ud50c\ub9ac\ucf00\uc774\uc158\uc758 \uc131\ub2a5\uc744 \ubaa8\ub2c8\ud130\ub9c1\ud558\uace0 \ubd84\uc11d\ud560 \uc218 \uc788\ub294 \ub3c4\uad6c\uc785\ub2c8\ub2e4. CPU \ubc0f \uba54\ubaa8\ub9ac \uc0ac\uc6a9\ub7c9, \uc2a4\ub808\ub4dc \uc0c1\ud0dc \ub4f1\uc744 \uc2dc\uac01\uc801\uc73c\ub85c \ud655\uc778\ud560 \uc218 \uc788\uc2b5\ub2c8\ub2e4.<\/li>\n
- YourKit<\/strong>: \uc0c1\uc6a9 \ud504\ub85c\ud30c\uc77c\ub7ec\ub85c, \uba54\ubaa8\ub9ac \ubc0f CPU \ud504\ub85c\ud30c\uc77c\ub9c1 \uae30\ub2a5\uc744 \uc81c\uacf5\ud569\ub2c8\ub2e4. \uba54\ubaa8\ub9ac \ub204\uc218 \ubb38\uc81c\ub97c \uc27d\uac8c \ucc3e\uc544\ub0bc \uc218 \uc788\uc2b5\ub2c8\ub2e4.<\/li>\n<\/ul>\n
4. \uc131\ub2a5 \ucd5c\uc801\ud654\ub97c \uc704\ud55c \ucf54\ub4dc \uac1c\uc120<\/h2>\n
\uc131\ub2a5 \ubd84\uc11d \ud6c4\uc5d0\ub294 \ucf54\ub4dc \uac1c\uc120\uc774 \ud544\uc694\ud569\ub2c8\ub2e4. \ub2e4\uc74c\uc740 Spring Boot \uc560\ud50c\ub9ac\ucf00\uc774\uc158\uc5d0\uc11c \uc131\ub2a5\uc744 \ucd5c\uc801\ud654\ud558\uae30 \uc704\ud55c \uba87 \uac00\uc9c0 \ubc29\ubc95\uc785\ub2c8\ub2e4.<\/p>\n
\ucd5c\uc801\ud654 \uae30\ubc95:<\/h3>\n\n- Lazy Loading<\/strong>: \ud544\uc694\ud560 \ub54c\ub9cc \ub370\uc774\ud130\ub97c \ub85c\ub4dc\ud558\uc5ec \uba54\ubaa8\ub9ac \uc0ac\uc6a9\ub7c9\uc744 \uc904\uc785\ub2c8\ub2e4.<\/li>\n
- Caching<\/strong>: \uc790\uc8fc \uc0ac\uc6a9\ud558\ub294 \ub370\uc774\ud130\ub97c \uce90\uc2f1\ud558\uc5ec \ub370\uc774\ud130\ubca0\uc774\uc2a4 \ud638\ucd9c\uc744 \uc904\uc785\ub2c8\ub2e4.<\/li>\n
- \ube44\ub3d9\uae30 \ucc98\ub9ac<\/strong>: \ube44\ub3d9\uae30 \ucc98\ub9ac\ub97c \ud1b5\ud574 \uc751\ub2f5 \uc2dc\uac04\uc744 \ub2e8\ucd95\uc2dc\ud0ac \uc218 \uc788\uc2b5\ub2c8\ub2e4.<\/li>\n<\/ul>\n
\/\/ \ube44\ub3d9\uae30 \ucc98\ub9ac \uc608\uc81c\n@Async\npublic CompletableFuture processAsync() {\n \/\/ \ube44\uc988\ub2c8\uc2a4 \ub85c\uc9c1\n return CompletableFuture.completedFuture(\"\uc644\ub8cc\");\n}<\/code><\/pre>\n5. \uc0ac\ub840 \uc5f0\uad6c: \uc131\ub2a5 \uac1c\uc120 \uc131\uacf5 \uc0ac\ub840<\/h2>\n
\uc131\uacf5\uc801\uc778 \uc131\ub2a5 \uac1c\uc120 \uc0ac\ub840\ub97c \ud1b5\ud574 \uc774\ub860\uc744 \uc2e4\uc81c\ub85c \uc801\uc6a9\ud558\ub294 \ubc29\ubc95\uc744 \uc0b4\ud3b4\ubcf4\uaca0\uc2b5\ub2c8\ub2e4. \ud55c \uc804\uc790\uc0c1\uac70\ub798 \ud50c\ub7ab\ud3fc\uc740 Spring Boot\ub97c \uc0ac\uc6a9\ud558\uc5ec \uc560\ud50c\ub9ac\ucf00\uc774\uc158\uc744 \uac1c\ubc1c\ud588\uc2b5\ub2c8\ub2e4. \ucd08\uae30 \uc131\ub2a5 \ubd84\uc11d \uacb0\uacfc, \ud398\uc774\uc9c0 \ub85c\ub529 \uc2dc\uac04\uc774 \ud3c9\uade0 5\ucd08\ub85c \ub098\ud0c0\ub0ac\uc2b5\ub2c8\ub2e4. \uc774\ub97c \ud574\uacb0\ud558\uae30 \uc704\ud574 \ub2e4\uc74c\uacfc \uac19\uc740 \uc870\uce58\ub97c \ucde8\ud588\uc2b5\ub2c8\ub2e4.<\/p>\n
\uac1c\uc120 \uc870\uce58:<\/h3>\n\n- Actuator\uc640 Micrometer\ub97c \uc0ac\uc6a9\ud558\uc5ec \uc131\ub2a5 \uba54\ud2b8\ub9ad\uc744 \ubaa8\ub2c8\ud130\ub9c1<\/li>\n
- VisualVM\uc744 \ud1b5\ud574 CPU \uc0ac\uc6a9\ub7c9\uacfc \uba54\ubaa8\ub9ac \ub204\uc218\ub97c \ubd84\uc11d<\/li>\n
- Lazy Loading\uacfc Caching \uae30\ubc95\uc744 \uc801\uc6a9\ud558\uc5ec \ub370\uc774\ud130\ubca0\uc774\uc2a4 \ud638\ucd9c \ud69f\uc218 \uac10\uc18c<\/li>\n<\/ul>\n
\uacb0\uacfc\uc801\uc73c\ub85c \ud398\uc774\uc9c0 \ub85c\ub529 \uc2dc\uac04\uc740 2\ucd08\ub85c \ub2e8\ucd95\ub418\uc5c8\uace0, \uc0ac\uc6a9\uc790 \ub9cc\uc871\ub3c4\uac00 \ud06c\uac8c \ud5a5\uc0c1\ub418\uc5c8\uc2b5\ub2c8\ub2e4.<\/p>\n
\uacb0\ub860<\/h2>\n
Spring Boot\uc5d0\uc11c\uc758 \uace0\uae09 \ud504\ub85c\ud30c\uc77c\ub9c1\uacfc \uc131\ub2a5 \ubd84\uc11d \ub3c4\uad6c \ud65c\uc6a9\uc740 \uc560\ud50c\ub9ac\ucf00\uc774\uc158\uc758 \uc131\ub2a5\uc744 \uadf9\ub300\ud654\ud558\ub294 \ub370 \ud544\uc218\uc801\uc785\ub2c8\ub2e4. \uae30\ubcf8 \ub3c4\uad6c\uc640 \uace0\uae09 \ub3c4\uad6c\ub97c \uc801\uc808\ud788 \ud65c\uc6a9\ud558\uace0, \ucf54\ub4dc \ucd5c\uc801\ud654\ub97c \ud1b5\ud574 \uc131\ub2a5 \ubb38\uc81c\ub97c \ud574\uacb0\ud560 \uc218 \uc788\uc2b5\ub2c8\ub2e4. \uc774\ub7ec\ud55c \uacfc\uc815\uc744 \ud1b5\ud574 \uc0ac\uc6a9\uc790 \uacbd\ud5d8\uc744 \uac1c\uc120\ud558\uace0, \ube44\uc988\ub2c8\uc2a4 \uc131\uacfc\ub97c \ub192\uc77c \uc218 \uc788\uc2b5\ub2c8\ub2e4. \uc131\ub2a5 \ubd84\uc11d\uc740 \ub2e8\uc21c\ud55c \uc120\ud0dd\uc774 \uc544\ub2c8\ub77c \uc131\uacf5\uc801\uc778 \uc560\ud50c\ub9ac\ucf00\uc774\uc158 \uac1c\ubc1c\uc758 \ud575\uc2ec \uc694\uc18c\uc784\uc744 \uc78a\uc9c0 \ub9d0\uc544\uc57c \ud569\ub2c8\ub2e4.<\/p>\n","protected":false},"excerpt":{"rendered":"
Spring Boot\uc5d0\uc11c\uc758 \uace0\uae09 \ud504\ub85c\ud30c\uc77c\ub9c1\uacfc \uc131\ub2a5 \ubd84\uc11d \ub3c4\uad6c \ud65c\uc6a9 Spring Boot\ub294 \ud604\ub300 \uc560\ud50c\ub9ac\ucf00\uc774\uc158 \uac1c\ubc1c\uc5d0\uc11c \ub110\ub9ac \uc0ac\uc6a9\ub418\ub294 […]<\/p>\n","protected":false},"author":1,"featured_media":33704,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[1957],"tags":[200,2156,2144],"class_list":["post-49881","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-development","tag-amazon","tag-spring","tag-web"],"acf":[],"_links":{"self":[{"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/posts\/49881","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/comments?post=49881"}],"version-history":[{"count":1,"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/posts\/49881\/revisions"}],"predecessor-version":[{"id":49921,"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/posts\/49881\/revisions\/49921"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/media\/33704"}],"wp:attachment":[{"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/media?parent=49881"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/categories?post=49881"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/m9js.shop\/blog\/wp-json\/wp\/v2\/tags?post=49881"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}