전체 · 249

  1. 2026
  2. 6월
  3. 06.16JT Music - Join Us For A Bite
  4. 06.15aespa - 'Til We Die
  5. 06.15MEOVV - Favorite Song
  6. 4월
  7. 04.19REBEL HEART
  8. 1월
  9. 01.20e ∈ F
  10. 01.20기술개발 진행상황 공유 2
  11. 01.20기술개발 진행상황 공유 3
  12. 01.20기술개발 진행상황 공유 1
  13. 01.16『실패를 통과하는 일』
  14. 01.15항저우
  15. 2025
  16. 12월
  17. 12.12Kittyy & The Class - I'm Not Remarkable
  18. 10월
  19. 10.26『싯다르타』
  20. 10.24어제까지의 이야기
  21. 10.24The killers - Shot At the night
  22. 10.20『학문의 즐거움』
  23. 10.12심통봇 - GHOSTagram
  24. 10.09돈 벌기
  25. 9월
  26. 09.13My Chemical Romance - Welcome To The Black Parade
  27. 09.10TUBE - The Season In The Sun
  28. 09.02PERFECT BLUE
  29. 8월
  30. 08.31코코아분말 0.9%
  31. 08.30WHAT THE
  32. 08.30Ado - The World’s Continuation
  33. 08.29문을 닫고 들어오세요
  34. 08.28하우스도르프 공간
  35. 08.27All Time Low
  36. 08.27『생각 좀 하며 세상을 보자』
  37. 08.26세상의 끝을 겨눈대도
  38. 08.25앉은 자리가 꽃자리
  39. 08.246과 7 사이 자연수
  40. 08.23아직 아무 문제도 발견되지 않았습니다
  41. 08.22Adventure
  42. 08.21Adobe Creek
  43. 08.20나의 무가지보(無價之寶)
  44. 08.20HUNTR/X - What It Sounds Like
  45. 08.19T. Rex
  46. 08.18누구를 위하여 종은 울리나
  47. 08.17Sunday Morning
  48. 08.16일상의 안녕
  49. 08.15친애하는 우리의 결함에게
  50. 08.14이것이 있으므로 저것이 있다
  51. 08.14『초신성의 후예』
  52. 08.13나는 나의 길을 간다
  53. 08.13Aimer - 蝶々結び (나비매듭)
  54. 08.12Vanilla Latte
  55. 08.11그것은 하나의 가까움
  56. 08.11Vaundy - 踊り子 (무희)
  57. 08.10정복 불허의 공간에
  58. 08.09쉼 없이 수선하기
  59. 08.08나는 전설이다
  60. 08.07철판치즈버거
  61. 08.07『나는 포기를 모른다』
  62. 08.06난 포기에 소질 있음
  63. 08.05스피또런
  64. 08.04하룻밤 만에
  65. 08.04Myuk - Black Sheep
  66. 08.03세상에 딱 하나뿐인
  67. 08.03『심장보다 높이』
  68. 08.02게으름뱅이를 위한 변명
  69. 08.02Myuk - Gift
  70. 08.02『누가 내 치즈를 옮겼을까?』
  71. 08.01북극 백화점
  72. 7월
  73. 07.31사람은 무엇으로 사는가?
  74. 07.30KRAFTON Yeoksam Office
  75. 07.30Tani Yuuki - W/X/Y
  76. 07.29Slowly flowing day
  77. 07.28What's this?
  78. 07.28Architectural Improvements 4
  79. 07.27Lime Light
  80. 07.26우리가 기다린 미래
  81. 07.25Final approach
  82. 07.25Poster Design Note : Form and Flow
  83. 07.25Poster Design Note : How We Made It
  84. 07.24폭풍의 눈
  85. 07.23IYKYK
  86. 07.22순살치킨 -> 치킨너겟
  87. 07.21TRAIN - TRAIN
  88. 07.21Architectural Improvements 3
  89. 07.21Logo Design Note : The Logic of Flow
  90. 07.20어떤 통찰도 지름길로는 얻을 수 없다
  91. 07.20DeepDive : Many Over Mighty
  92. 07.20JINI - Bad Reputation
  93. 07.19시간이 느리게 가는 건
  94. 07.19Architectural Improvements 2
  95. 07.19DeepDive : GC-Triggered Stop-the-World
  96. 07.18EVEREST
  97. 07.18Architectural Improvements 1
  98. 07.18PhantomFlow : High-performance HTTP request simulator
  99. 07.18Introduction to Project KlickLab
  100. 07.18What is Clickstream data?
  101. 07.17깊은 사고는 더 이상 니즈가 없다
  102. 07.16이기적인 토대 위
  103. 07.15무엇이든, 언제가는
  104. 07.15Official HIGE DANdism - Universe
  105. 07.14경험을 압축하는 알고리즘은 존재하지 않는다 ⏳
  106. 07.14『료의 생각 없는 생각』
  107. 07.13무한한 가능성을 가질 것
  108. 07.12화려한 거짓을 향해
  109. 07.11Kentucky Fried Chicken 🍗
  110. 07.10Tropical Blue 🌊
  111. 07.09처음처럼 내 딛는
  112. 07.08어제와 다른 하늘의 색
  113. 07.08Furui riho - Hello
  114. 07.07누군가의 달이었기를 🌕
  115. 07.06아직 뜯지 않은 마음 🎁
  116. 07.05황금의 오솔길
  117. 07.05noa - A8番出口 (A8번출구)
  118. 07.04우리는 오가는 바람
  119. 07.03Nic dwa razy
  120. 07.02Never basic
  121. 07.02MEOVV - DROP TOP
  122. 07.01입꼬리올림근
  123. 6월
  124. 06.30그럼에도 불구하고
  125. 06.29과잉포장된 자존심
  126. 06.29Steve Winwood – Higher Love
  127. 06.29『어린 왕자』
  128. 06.28E3i3 🛫
  129. 06.27118 ✨
  130. 06.26무한 우주에 순간의 빛일지라도 🌌
  131. 06.26Mercury Rev - Holes
  132. 06.25RUSH
  133. 06.25Cloudybay - 내게로
  134. 06.24그래, 우리는
  135. 06.24『이건 다만 사랑의 습관』
  136. 06.23The wind blowing low
  137. 06.23『생각 망치』
  138. 06.22피어나는 마음의 꽃
  139. 06.21하나는 죽고, 하나는 살았다 💡
  140. 06.21『2025 제16회 젊은작가상 수상작품집』
  141. 06.20초속일초
  142. 06.19씨앗이 가장 고귀한 이유는
  143. 06.18Evening Primrose 🏵️
  144. 06.17마음이 휑뎅그렁할 때
  145. 06.16하나
  146. 06.16Vaundy - しわあわせ (주름 맞추기)
  147. 06.15강철무지개
  148. 06.15Will Ye Go, Lassie Go?
  149. 06.14유람 🚉
  150. 06.1313일의 금요일 ⏰
  151. 06.12백만 스물하나, 백만 스물둘
  152. 06.11경안천 🥩
  153. 06.10달이 아름답네요 🌕
  154. 06.10Yuuri - ドライフラワー (드라이플라워)
  155. 06.10『하늘과 바람과 별과 시』
  156. 06.09Tampermonkey 🖥️
  157. 06.09Hump Back - 拝啓、少年よ (친애하는 소년이여)
  158. 06.09Yuuri - ガリレオは恋をする(갈릴레오는 사랑을 한다)
  159. 06.08미르 ✨
  160. 06.08『인간의 대지』
  161. 06.07나 평생 꿈만을
  162. 06.06아르기닌 🍫
  163. 06.05변속주 🌃
  164. 06.05THE BLUE HEARTS - 情熱の薔薇 (정열의 장미)
  165. 06.05noa - ホットレモン (Hot Lemon)
  166. 06.04Global Running Day 🏃‍
  167. 06.03가장 밝은 별
  168. 06.02천천히 🌃
  169. 06.01circular metal ring 🏀
  170. 5월
  171. 05.31담장과 쪽문 🐋
  172. 05.30투표런 🚀
  173. 05.29출발선 🏃
  174. 05.28Post Traumatic Growth 🌠
  175. 05.27SET 🎂
  176. 05.26READY 📅
  177. 05.25청복 💙
  178. 05.24열복 🫀
  179. 05.23강제 푸시 반성합니다 🔁
  180. 05.22유로파 🍏
  181. 05.21떠오름과 저묾 🌞
  182. 05.20Family Friend Fools
  183. 05.20Aimyon - 裸の心 (벌거벗은 마음)
  184. 05.19Time machine ⏰
  185. 05.18맑은 일요일 🧼
  186. 05.17흐린 토요일 🐢
  187. 05.16PTG 🌧️
  188. 05.15셋이 만드는 하나 🧭
  189. 05.14Lotte+Cafeteria 🍔
  190. 05.13오십삼 🌤️
  191. 05.12일장춘몽 💊
  192. 05.11𝑬𝒗𝒆𝒓𝒍𝒂𝒏𝒅, 𝑬𝒗𝒆𝒓 𝑴𝒊𝒏𝒅 🎡
  193. 05.10五月雨よ 🌧
  194. 05.09Your Journey Starts Here 🪧
  195. 05.08「권의 속도」 📄
  196. 05.07Quiet Air ⏳
  197. 05.06놀자판 하루 🐷
  198. 05.05뭔데이 🎏
  199. 05.04After School 🎒
  200. 05.03나침반이 가리킨 곳 🌌
  201. 05.02짧은 하루 📖
  202. 05.01예고된 악재는 악재가 아니다 🌧️
  203. 05.01『오즈의 마법사』
  204. 4월
  205. 04.30Can More 🍧
  206. 04.29초급반 🏃‍
  207. 04.28감사합니다. 죄송합니다. 🙏
  208. 04.27맥도날드 원정 🍔
  209. 04.26무용(無用)의 쓸모 🛤️
  210. 04.25Sunny Day 🌞
  211. 04.24벚나무 아래에서 🌸
  212. 04.23언제나 이타카를 마음에 두라 🌿
  213. 04.22D-100 🧑‍💻
  214. 04.21수상한 미용실 💇‍♂️
  215. 04.20손으로 컴퓨터를 마주하다🔧
  216. 04.19비가 오면 빨래를 하자 🌧️
  217. 04.18반차😴
  218. 04.17발표, 청소, 러닝🗣️
  219. 04.16반티 발주👕
  220. 04.15첫 달리기🏃‍
  221. 04.14선택과 해석🗳️
  222. 04.14신지훈 - 시가 될 이야기
  223. 04.13Home Sweet Home🏠
  224. 04.12人生
  225. 04.11반티 디자인 공모 & 제출👕
  226. 04.11KiiiKiii - I DO ME
  227. 04.10알고리즘의 끝, C언어의 시작🧭
  228. 04.09하와이안 스테이크🥩
  229. 04.08Long Chat (#🎮)
  230. 04.07Es irrt der Mensch, solang' er strebt.📚
  231. 04.06마무리🛌
  232. 04.05움직이는 물체의 시간은 느리게 간다💤
  233. 04.04하나의 칼날🗡️
  234. 04.033x7=21🧗
  235. 04.02퀴즈 다음날, 시험 전날😴
  236. 04.01April Fools' Day🎭
  237. 3월
  238. 03.311년의 90번째 날🌅
  239. 03.31『카할의 과학하는 삶』
  240. 03.30日曜日은 칠요일 중 첫째 날 이다⏰
  241. 03.29토요일은 주말이 아니다☕
  242. 03.28그래프와 치킨버거🐔
  243. 03.273주차의 시작🗓️
  244. 03.26기초 다지기🔧
  245. 03.25기초 다지기 & 정리해야 할 CS 개념들💡
  246. 03.240.44%
  247. 03.23본가 다녀온 날🏡
  248. 03.22문제 풀이에 집중한 하루 📅
  249. 03.21동료학습🌿
  250. 03.20첫번째 시험📝
  251. 03.19먹다가 끝난 하루🍖
  252. 03.18눈이 쌓이면 버그도 쌓인다❄️
  253. 03.17깃허브, 팀별 면담, 키워드 공부👨‍💻
  254. 03.17RADWIMPS - 正解 (정답)
  255. 03.16외출과 배달🚶🛍️
  256. 03.16ILLIT - Almond Chocolate
  257. 03.16Kep1er - HighLight
  258. 03.15첫 주말🛏️
  259. 03.14컴퓨팅 사고로의 전환🧠
  260. 03.13cookie4u.store🍪 + 1주차 발제📚 + 회식🍺
  261. 03.12디지털 포춘쿠키🍪
  262. 03.11정글 입성🏕
  263. 03.10입소 당일📅

경험을 압축하는 알고리즘은 존재하지 않는다 ⏳

오늘은 클릭하우스를
듀얼 클러스터로 만들어서
쓰기 전용과 읽기 전용으로 데이터 베이스를
나누는 작업을 진행했다.

이를 CQRS(command query responsibility segregation,명령 쿼리 책임 분리)라고 한다.

우리가 데이터 베이스를 클릭하우스로 선택한 이유를 설명하려면
우리가 뭘 하는질 알아야하는데

클릭랩은 클릭스트림이라고 불리는 웹사이트 사용자 행동 데이터를
초고속으로 수집 분석하는 웹 애널리틱스 플랫폼이다(구글 애널리틱스같은)

이런 주제 특성상 다음과 같은 요구사항이 있는데

이처럼 수많은 이벤트를 빠르게 기록하고
대용량 데이터를 효율적으로 분석해야 하는 환경에서

일반적인 관계형 데이터베이스로는
초당 수만 건의 데이터를 빠르게 쓰기 어렵고

복잡한 조건의 분석 쿼리를 처리하면
금방 느려지는 문제가 생길 것이라고 생각했다

그래서 찾아보다 발견한게 클릭하우스이다

클릭하우스는 컬럼 지향 저장 방식과
벡터화된 실행 엔진을 기반으로
대규모 데이터를 초고속으로 집계하고 필터링할 수 있는 성능을 갖추고 있다

즉 프로젝트 클릭랩에 가장 적합한 선택지처럼 보였다.

페이즈2로 넘어오면서
CQRS를 할 수 밖에 없었던 이유는

클릭랩의 시스템은 한쪽으로는
수십만 건의 사용자 행동 이벤트를 지연 없이 받아들여야 하고

다른 한쪽으로는 복잡한 조건으로 사용자 흐름을 분석하거나
시각화해야 하는 이중적인 요구를 동시에 만족시켜야 하기 때문인데

이 두 가지 작업은 기술적으로 성격이 완전히 다르다
쓰기 작업은 단순하지만 고빈도이고
읽기 작업은 빈도는 낮지만 계산이 복잡하고 리소스를 많이 사용한다

하나의 데이터베이스에 이 두 작업을 동시에 처리하려고 하면
성능 병목이나 데이터 유실의 위험이 존재하게 되고

실제로 API게이트웨이 병목으로 인한 접근 차단과
80%수준의 데이터 전송율을 통해서 직접 경험해보았기 때문에
단일 데이터베이스의 문제점을 체감했다

이를 해결하기 위해 CQRS패턴을 도입한것이다
즉, 쓰기 전용 인스턴스와 읽기 전용 인스턴스를 분리하여
데이터베이스의 분업화를 이룬 것이다

쓰기 전용 데이터베이스는 오직 이벤트 수집에 집중할 수 있도록 설계되어
SDK를 통해 수집된 클릭스트림 데이터는 쓰기전용 데이터베이스에 쌓이고

읽기 전용 데이터베이스는 쿼리 최적화와 캐싱 분석에 집중하여
프론트엔드(대시보드)와 연결되어있다.

그리고 그 둘을 동기화 시켜주기위해
클릭하우스 키퍼라는 개념또한 도입하였다.

키퍼는 쉽게 말해서
조율 도구이다

여러 데이터 베이스 인스턴스가 서로 동시기화 할때
헷갈리지 않게,
데이터를 올바르게 복제-동기화할 수 있도록 해주는 중심축이라고 보면 된다.

우리 클릭랩은 읽기전용 서버와 쓰기 전용 서버를 분리해 놓았는데
고객사 프론트에 설치된 SDK를 통해 발생한 이벤트는
먼저 우리 쓰기 전용 서버에 쓰여지고
읽기 전용 서버는 업데이트되는
쓰기 전용 서버의 데이터를 따라잡기 위해
ReplicatedMergeTree라는 엔진을 사용한다.

이 엔진은 쓰기 전용 서버의 데이터를 보면서
어떤 데이터가 새로 생겼는지
어떤 파티션이 병합됐는지
같은 걸 추적한다

그걸 키퍼를 통해 주기적으로 동기화하면서
읽기 전용 서버가 항상 최신 데이터를 갖고 있도록 해주는 것이다

결국 키퍼가 있어야,
읽기 전용 서버가 안정적으로 분석 쿼리를 처리하면서도
쓰기 서버와 데이터 불일치 없이
잘 따라갈 수 있는 구조가 만들어진다는 것.

이렇게 CQRS구현이 끝나고
이제 오토스케일링 그룹의
시작 템플릿을 만져야 했는데…

시작 템플릿은
나를 밤새게 했다…

월요일과 화요일의 기억은
오로지
시작 템플릿 뿐이다.


경험을 압축하는 알고리즘은 존재하지 않는다.

AWS가 이야기하는 격언으로서,
인류를 지속적으로 진화시키는 것은 ‘직감’이 아닌,
‘직접 겪은 경험을 기반으로 한 데이터와 사고방식’이라는 뜻에서 유래되었다.
실제로 아마존은 타 회사들을 압도적으로 상회하는 수준의 Data-Driven 사고방식을 보여준다.

댓글