전체 · 247

  1. 2026
  2. 6월
  3. MEOVV - Favorite Song06.15
  4. 4월
  5. [0419] REBEL HEART04.19
  6. 1월
  7. [0115] 항저우01.22
  8. e ∈ F01.20
  9. 기술개발 진행상황 공유 101.20
  10. 기술개발 진행상황 공유 201.20
  11. 기술개발 진행상황 공유 301.20
  12. 『실패를 통과하는 일』01.16
  13. 2025
  14. 12월
  15. Kittyy & The Class - I'm Not Remarkable12.12
  16. 10월
  17. 『싯다르타』10.26
  18. [1024] 어제까지의 이야기10.24
  19. The killers - Shot At the night10.24
  20. 『학문의 즐거움』10.20
  21. 심통봇 - GHOSTagram10.12
  22. [1009] 돈 벌기10.09
  23. 9월
  24. My Chemical Romance - Welcome To The Black Parade09.13
  25. [0902] PERFECT BLUE09.11
  26. [0831] 코코아분말 0.9%09.10
  27. TUBE - The Season In The Sun09.10
  28. [0830] WHAT THE09.08
  29. [0829] 문을 닫고 들어오세요09.06
  30. [0828] 하우스도르프 공간09.02
  31. 8월
  32. [0827] All Time Low08.30
  33. Ado - The World’s Continuation08.30
  34. [0826] 세상의 끝을 겨눈대도08.29
  35. [0825] 앉은 자리가 꽃자리08.28
  36. 『생각 좀 하며 세상을 보자』08.27
  37. [0823] 아직 아무 문제도 발견되지 않았습니다08.26
  38. [0824] 6과 7 사이 자연수08.26
  39. [0822] Adventure08.25
  40. [0821] Adobe Creek 08.24
  41. [0820] 나의 무가지보(無價之寶)08.22
  42. [0819] T. Rex08.21
  43. [0818] 누구를 위하여 종은 울리나08.20
  44. HUNTR/X - What It Sounds Like08.20
  45. [0817] Sunday Morning08.19
  46. [0816] 일상의 안녕08.18
  47. [0815] 친애하는 우리의 결함에게08.16
  48. [0814] 이것이 있으므로 저것이 있다08.15
  49. [0813] 나는 나의 길을 간다08.14
  50. 『초신성의 후예』08.14
  51. [0812] Vanilla Latte08.13
  52. Aimer - 蝶々結び (나비매듭)08.13
  53. [0811] 그것은 하나의 가까움08.12
  54. [0810] 정복 불허의 공간에08.11
  55. Vaundy - 踊り子 (무희)08.11
  56. [0809] 쉼 없이 수선하기08.10
  57. [0806] 난 포기에 소질 있음08.09
  58. [0807] 철판치즈버거08.09
  59. [0808] 나는 전설이다08.09
  60. [0805] 스피또런08.07
  61. 『나는 포기를 모른다』08.07
  62. [0803] 세상에 딱 하나뿐인08.05
  63. [0804] 하룻밤 만에08.05
  64. Myuk - Black Sheep08.04
  65. [0802] 게으름뱅이를 위한 변명08.03
  66. 『심장보다 높이』08.03
  67. [0801] 북극 백화점08.02
  68. Myuk - Gift08.02
  69. 『누가 내 치즈를 옮겼을까?』08.02
  70. [0731] 사람은 무엇으로 사는가?08.02
  71. 7월
  72. [0730] KRAFTON Yeoksam Office07.31
  73. [0729] Slowly flowing day07.30
  74. [0728] What's this?07.30
  75. Tani Yuuki - W/X/Y07.30
  76. [0726] 우리가 기다린 미래07.28
  77. [0727] Lime Light07.28
  78. Architectural Improvements 407.28
  79. [0722] 순살치킨 -> 치킨너겟07.27
  80. [0723] IYKYK07.27
  81. [0724] 폭풍의 눈07.27
  82. [0725] Final approach07.27
  83. [0721] TRAIN - TRAIN07.25
  84. Poster Design Note : Form and Flow07.25
  85. Poster Design Note : How We Made It07.25
  86. [0719] 시간이 느리게 가는 건07.24
  87. [0720] 어떤 통찰도 지름길로는 얻을 수 없다07.24
  88. [0718] EVEREST07.23
  89. [0715] 무엇이든, 언제가는07.21
  90. [0716] 이기적인 토대 위07.21
  91. [0717] 깊은 사고는 더 이상 니즈가 없다07.21
  92. Architectural Improvements 307.21
  93. Logo Design Note : The Logic of Flow07.21
  94. DeepDive : Many Over Mighty07.20
  95. JINI - Bad Reputation07.20
  96. Architectural Improvements 207.19
  97. DeepDive : GC-Triggered Stop-the-World07.19
  98. [0714] 경험을 압축하는 알고리즘은 존재하지 않는다 ⏳07.18
  99. Architectural Improvements 107.18
  100. PhantomFlow : High-performance HTTP request simulator07.18
  101. Introduction to Project KlickLab07.18
  102. What is Clickstream data?07.18
  103. Official HIGE DANdism - Universe07.15
  104. [0710] Tropical Blue 🌊07.14
  105. [0711] Kentucky Fried Chicken 🍗07.14
  106. [0713] 무한한 가능성을 가질 것07.14
  107. [0712] 화려한 거짓을 향해07.14
  108. 『료의 생각 없는 생각』07.14
  109. [0708] 어제와 다른 하늘의 색07.11
  110. [0707] 누군가의 달이었기를 🌕07.11
  111. [0709] 처음처럼 내 딛는07.11
  112. [0706] 아직 뜯지 않은 마음 🎁07.08
  113. Furui riho - Hello07.08
  114. [0705] 황금의 오솔길07.07
  115. [0704] 우리는 오가는 바람07.05
  116. noa - A8番出口 (A8번출구)07.05
  117. [0703] Nic dwa razy07.04
  118. [0702] Never basic07.03
  119. [0630] 그럼에도 불구하고07.02
  120. [0701] 입꼬리올림근07.02
  121. MEOVV - DROP TOP07.02
  122. 6월
  123. [0629] 과잉포장된 자존심06.29
  124. [0628] E3i3 🛫06.29
  125. Steve Winwood – Higher Love06.29
  126. 『어린 왕자』06.29
  127. [0626] 무한 우주에 순간의 빛일지라도 🌌06.28
  128. [0627] 118 ✨06.28
  129. [0625] RUSH06.27
  130. [0624] 그래, 우리는06.26
  131. Mercury Rev - Holes06.26
  132. Cloudybay - 내게로06.25
  133. [0623] The wind blowing low06.24
  134. 『이건 다만 사랑의 습관』06.24
  135. [0621] 하나는 죽고, 하나는 살았다 💡06.23
  136. [0622] 피어나는 마음의 꽃06.23
  137. 『생각 망치』06.23
  138. [0620] 초속일초06.21
  139. 『2025 제16회 젊은작가상 수상작품집』06.21
  140. [0619] 씨앗이 가장 고귀한 이유는06.20
  141. [0617] 마음이 휑뎅그렁할 때06.18
  142. [0618] Evening Primrose 🏵️06.18
  143. [0616] 하나06.17
  144. [0615] 강철무지개06.16
  145. Vaundy - しわあわせ (주름 맞추기)06.16
  146. [0613] 13일의 금요일 ⏰06.15
  147. [0614] 유람 🚉06.15
  148. Will Ye Go, Lassie Go?06.15
  149. [0612] 백만 스물하나, 백만 스물둘06.13
  150. [0609] Tampermonkey 🖥️06.12
  151. [0610] 달이 아름답네요 🌕06.12
  152. [0611] 경안천 🥩06.12
  153. Yuuri - ドライフラワー (드라이플라워)06.10
  154. 『하늘과 바람과 별과 시』06.10
  155. [0608] 미르 ✨06.09
  156. Hump Back - 拝啓、少年よ (친애하는 소년이여) 06.09
  157. Yuuri - ガリレオは恋をする(갈릴레오는 사랑을 한다)06.09
  158. [0606] 아르기닌 🍫06.08
  159. [0607] 나 평생 꿈만을06.08
  160. 『인간의 대지』06.08
  161. [0604] Global Running Day 🏃‍06.06
  162. [0605] 변속주 🌃06.06
  163. [0603] 가장 밝은 별06.05
  164. THE BLUE HEARTS - 情熱の薔薇 (정열의 장미) 06.05
  165. noa - ホットレモン (Hot Lemon) 06.05
  166. [0602] 천천히 🌃06.04
  167. [0601] circular metal ring 🏀06.03
  168. [0531] 담장과 쪽문 🐋06.01
  169. 5월
  170. [0529] 출발선 🏃05.31
  171. [0530] 투표런 🚀05.31
  172. [0527] SET 🎂05.29
  173. [0528] Post Traumatic Growth 🌠05.29
  174. [0526] READY 📅05.28
  175. [0525] 청복 💙05.26
  176. [0522] 유로파 🍏05.25
  177. [0523] 강제 푸시 반성합니다 🔁05.25
  178. [0524] 열복 🫀05.25
  179. [0521] 떠오름과 저묾 🌞05.23
  180. [0520] Family Friend Fools05.22
  181. [0519] Time machine ⏰05.20
  182. Aimyon - 裸の心 (벌거벗은 마음)05.20
  183. [0518] 맑은 일요일 🧼05.18
  184. [0517] 흐린 토요일 🐢05.18
  185. [0515] 셋이 만드는 하나 🧭05.17
  186. [0516] PTG 🌧️05.17
  187. [0513] 오십삼 🌤️05.15
  188. [0514] Lotte+Cafeteria 🍔05.15
  189. [0512] 일장춘몽 💊05.14
  190. [0511] 𝑬𝒗𝒆𝒓𝒍𝒂𝒏𝒅, 𝑬𝒗𝒆𝒓 𝑴𝒊𝒏𝒅 🎡05.12
  191. [0510] 五月雨よ 🌧05.11
  192. [0509] Your Journey Starts Here 🪧05.11
  193. [0508] 「권의 속도」 📄05.10
  194. [0506] 놀자판 하루 🐷05.08
  195. [0507] Quiet Air ⏳05.08
  196. [0505] 뭔데이 🎏05.06
  197. [0503] 나침반이 가리킨 곳 🌌05.05
  198. [0504] After School 🎒05.05
  199. [0502] 짧은 하루 📖05.03
  200. [0501] 예고된 악재는 악재가 아니다 🌧️05.02
  201. [0430] Can More 🍧05.01
  202. 『오즈의 마법사』05.01
  203. 4월
  204. [0429] 초급반 🏃‍04.30
  205. [0427] 맥도날드 원정 🍔04.29
  206. [0428] 감사합니다. 죄송합니다. 🙏04.29
  207. [0425] Sunny Day 🌞04.28
  208. [0426] 무용(無用)의 쓸모 🛤️04.28
  209. [0424] 벚나무 아래에서 🌸04.26
  210. [0422] D-100 🧑‍💻04.24
  211. [0423] 언제나 이타카를 마음에 두라 🌿04.24
  212. [0421] 수상한 미용실 💇‍♂️04.22
  213. [0420] 손으로 컴퓨터를 마주하다🔧04.21
  214. [0419] 비가 오면 빨래를 하자 🌧️04.20
  215. [0418] 반차😴04.19
  216. [0415] 첫 달리기🏃‍04.18
  217. [0417] 발표, 청소, 러닝🗣️04.18
  218. [0416] 반티 발주👕04.18
  219. [0414] 선택과 해석🗳️04.15
  220. [0413] Home Sweet Home🏠04.14
  221. 신지훈 - 시가 될 이야기04.14
  222. [0412] 人生04.12
  223. [0410] 알고리즘의 끝, C언어의 시작🧭04.11
  224. [0411] 반티 디자인 공모 & 제출👕04.11
  225. KiiiKiii - I DO ME04.11
  226. [0409] 하와이안 스테이크🥩04.10
  227. [0407] Es irrt der Mensch, solang' er strebt.📚04.08
  228. [0408] Long Chat (#🎮)04.08
  229. [0406] 마무리🛌04.06
  230. [0405] 움직이는 물체의 시간은 느리게 간다💤04.06
  231. [0404] 하나의 칼날🗡️04.05
  232. [0403] 3x7=21🧗04.04
  233. [0402] 퀴즈 다음날, 시험 전날😴04.03
  234. [0401] April Fools' Day🎭04.02
  235. [0331] 1년의 90번째 날🌅04.01
  236. 3월
  237. [0330] 日曜日은 칠요일 중 첫째 날 이다⏰03.31
  238. 『카할의 과학하는 삶』03.31
  239. [0329] 토요일은 주말이 아니다☕03.30
  240. [0328] 그래프와 치킨버거🐔03.28
  241. [0327] 3주차의 시작🗓️03.27
  242. [0325] 기초 다지기 & 정리해야 할 CS 개념들💡03.26
  243. [0326] 기초 다지기🔧03.26
  244. [0324] 0.44%03.25
  245. [0322] 문제 풀이에 집중한 하루 📅03.23
  246. [0323] 본가 다녀온 날🏡03.23
  247. [0320] 첫번째 시험📝03.22
  248. [0321] 동료학습🌿03.22
  249. [0319] 먹다가 끝난 하루🍖03.20
  250. [0318] 눈이 쌓이면 버그도 쌓인다❄️03.19
  251. [0315] 첫 주말🛏️03.17
  252. [0316] 외출과 배달🚶🛍️03.17
  253. [0317] 깃허브, 팀별 면담, 키워드 공부👨‍💻03.17
  254. RADWIMPS - 正解 (정답)03.17
  255. ILLIT - Almond Chocolate03.16
  256. Kep1er - HighLight03.16
  257. [0311] 정글 입성🏕03.15
  258. [0312] 디지털 포춘쿠키🍪03.15
  259. [0310] 입소 당일📅03.15
  260. [0313] cookie4u.store🍪 + 1주차 발제📚 + 회식🍺03.15
  261. [0314] 컴퓨팅 사고로의 전환🧠03.15

DeepDive : Many Over Mighty

해결법 2: 인스턴스 스케일 아웃 전략 변경


힙 메모리 확장이 RPS 최고치를 높여주긴 했지만
주기적인 멈춤 현상을 해결하지 못했기 때문에…
다른 해결책을 생각해내야 했다.

만약 GC가 유일한 원인이었다면
메모리를 2배 이상 늘렸을 때
‘멈춤’ 현상이 발생하는 간격도 2배 이상으로 길어져야 한다.
하지만 현실은 그렇지 않았다.

여전히 약 20~30초마다 RPS가 바닥을 찍는 현상이 반복되었다.

이 결과는 문제를 단순히 ‘힙 크기’의 문제가 아니라,
‘단일 Node.js 프로세스’의 한계와 Stop-the-World GC가 필연적으로 발생시키는
지연 시간 그 자체에 있다는 결론으로 이어졌다.

아무리 힙을 늘려도 결국 GC는 발생하고
그때마다 모든 요청 처리가 멈춘다는 본질적인 문제는 변하지 않는다.


전략 수정

각 인스턴스가 더 적은 부하를 처리하면서 GC의 영향을 최소화하는 방법,
Stop-the-World GC가 전체 서비스에 미치는 영향을 희석하는 전략이 필요했다.


인스턴스 사양 변경: 더 작게, 더 많이

기존 인프라는 고성능 네트워크와 CPU를 자랑하는
c6in.xlarge (RAM 8 GB) 17개 인스턴스로 구성되어 있었다.

쉽게 말해 좋은(비싼) 인스턴스를 적게 배치하고
각 인스턴스가 많은 요청을 처리하도록 설계된 구조였다.

하지만 Node.js의 단일 스레드 기반 특성과
GC로 인한 Stop-the-World 현상은 이 전략에 치명적인 제약이 되었다.

그래서 다음과 같이 스케일 아웃 전략을 변경했다.


파이프라인에서의 병목 지점: EC2 Auto Scaling

우리가 운영하는 파이프라인은 다음과 같다:

KlickLab SDK → NLB → EC2 (Auto Scaling) → Amazon MSK → AWS Lambda → ClickHouse

이 중 병목 지점은 예상 밖에도 EC2 (Auto Scaling)이었다.
GC가 쌓이는 순간마다 요청이 끊기고, 전체 성능이 급락했다.

Node.js 런타임의 단일 스레드 특성과
GC가 맞물리면서 전체 파이프라인의 발목을 잡았던 것이다.

그래서 EC2 인스턴스를 잘게 쪼갰다.
그 결과, 마침내 RPS 10,000을 넘기는 데 성공했다.


할당량과 예산의 제약

단순히 기술적인 이유만 있었던 것은 아니다.
우리는 다음과 같은 현실적인 인프라 제약에도 부딪히고 있었다:

Service Quotas에 따라 On-Demand 인스턴스의 vCPU 할당량이 96개로 제한되어 있었고,
백엔드 서버나 ClickHouse와 같은 필수 인스턴스에 이미 일부 vCPU가 할당된 상황이었다.

실제로는 사용 가능한 여유 vCPU가 74개뿐이었기 때문에
c6in.xlarge처럼 vCPU를 4개씩 사용하는 인스턴스를 계속 늘리는 것이 불가능했다.

그래서 병렬성을 극대화하기 위해
1개의 Vcpu를 가진 t2.small을 선택하여
인스턴스의 갯수를 최대한으로 늘리기로 했다.

게다가 우리에겐 AWS 크레딧 1,000달러라는 예산 한도도 존재했다.
고성능 인스턴스를 계속 쓴다면 빠르게 비용 한도를 초과할 수밖에 없는 구조였다.

결국 우리가 선택할 수 있는 전략은 명확했다.
싸고, vCPU가 적고, 비용을 예측할 수 있는 인스턴스를 많이 쓰는 것
기술적 이유와 비용 구조, 할당량 제약이 모두 맞물리며
‘더 작고 많은 인스턴스’ 전략이 선택된 것이다.


왜 더 작고 많은 인스턴스가 효과적일까?

  1. Stop-the-World GC의 영향 분산

    • t2.small 인스턴스는 적은 요청을 처리하므로, GC가 발생하더라도 전체 서비스에 미치는 영향은 작다.
    • NLB가 요청을 분산시켜 GC 중인 인스턴스를 자동 회피할 수 있다.
  2. 힙 크기 대비 GC 주기 최적화

    • RAM이 작기 때문에 기본 힙 크기도 작지만, 처리량 역시 적기 때문에 GC 주기도 길어지거나 GC 자체가 가볍게 끝난다.
    • GC가 발생해도 해당 인스턴스에만 국한되어 전체 서비스가 멈추는 일은 없다.
  3. 비용 효율성

    • t2.small은 단가가 매우 낮다.
    • 인스턴스 수가 늘었지만, 비용 대비 성능 효율이 오히려 더 높아졌다.

해결 결과: RPS 10,000 달성


스케일 아웃 전략을 적용한 후 부하 테스트를 다시 실행했고, 다음과 같은 결과를 얻었다.

이 전략은 특히 Node.js처럼 단일 스레드 기반의 런타임에서 Stop-the-World GC를 분산시키는 데 매우 효과적이었다.


정리