From 65f6a04eda4ba38a404c27964892b70ee07a6e91 Mon Sep 17 00:00:00 2001
From: Gyunseo Lee <rbstj0311@naver.com>
Date: Mon, 8 Jul 2024 01:32:48 +0900
Subject: [PATCH]  2024-07-08 01:32:48
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

Affected files:
src/content/blog/왜-node에서-pino-logger를-이용한-log-io는-cpu-usage에-큰-영향이-없을까?.md
---
 ...\235\264-\354\227\206\354\235\204\352\271\214?.md" | 11 +++++++++++
 1 file changed, 11 insertions(+)

diff --git "a/src/content/blog/\354\231\234-node\354\227\220\354\204\234-pino-logger\353\245\274-\354\235\264\354\232\251\355\225\234-log-io\353\212\224-cpu-usage\354\227\220-\355\201\260-\354\230\201\355\226\245\354\235\264-\354\227\206\354\235\204\352\271\214?.md" "b/src/content/blog/\354\231\234-node\354\227\220\354\204\234-pino-logger\353\245\274-\354\235\264\354\232\251\355\225\234-log-io\353\212\224-cpu-usage\354\227\220-\355\201\260-\354\230\201\355\226\245\354\235\264-\354\227\206\354\235\204\352\271\214?.md"
index 9b1060006..d4944132b 100644
--- "a/src/content/blog/\354\231\234-node\354\227\220\354\204\234-pino-logger\353\245\274-\354\235\264\354\232\251\355\225\234-log-io\353\212\224-cpu-usage\354\227\220-\355\201\260-\354\230\201\355\226\245\354\235\264-\354\227\206\354\235\204\352\271\214?.md"
+++ "b/src/content/blog/\354\231\234-node\354\227\220\354\204\234-pino-logger\353\245\274-\354\235\264\354\232\251\355\225\234-log-io\353\212\224-cpu-usage\354\227\220-\355\201\260-\354\230\201\355\226\245\354\235\264-\354\227\206\354\235\204\352\271\214?.md"
@@ -81,3 +81,14 @@ Node.js는 기본적으로 위에서 Single Threaded하고 Blocking한 (위에
 그래서 libuv로 넘어갈테고, libuv에서는 epoll(I/O Multiplexing 방식)을 이용해, file descriptor들을 감시하죠.
 그래서 감시 중인 file descriptor들 중에 읽고 쓸 수 있는 fd가 생기면 해당 fd들을 반환받고, 이에 상응하는 작업을 하게 됩니다.  
 물론 이때도 logging이라면 결국, read와 write 시스템 콜을 호출하게 될 것이고, cpu의 개입은 결국 거의 없을 것이라는 겁니다.
+Node.js API 공식 문서에 이런 말이 있습니다.
+
+> Synchronous writes block the event loop until the write has completed. This can be near instantaneous in the case of output to a file, but under high system load, pipes that are not being read at the receiving end, or with slow terminals or file systems, it's possible for the event loop to be blocked often enough and long enough to have severe negative performance impacts. This may not be a problem when writing to an interactive terminal session, but consider this particularly careful when doing production logging to the process output streams.
+
+요약하자면, 동기식으로 로깅하면 시스템에 로드가 클 때, event loop가 block돼서 심각한 문제가 생길 것이다라고 말하네요.  
+즉, 로깅이 많이 되는 것도 Node.js에서는 성능 상에 큰 문제를 야기할 수 있겠군요!
+그런데 제가 예상한 것이랑은 다른 이슈긴 하죠? 일단, CPU Usage가 갑자기 튀어서 일어난 서비스 다운인데, Logging 많이 일어나서, 성능 상에 큰 문제가 생기는 건 CPU Usage랑 아무런 관련이 없습니다.  
+그리고 결정적으로, Pino Logger는 비동기로 처리됩니다.  
+결국 제가 틀린 게 맞습니다.
+
+끄읕