Error Handling
Runtime Error Case
API ์๋ฒ๋ก ์ผ์์ ์ผ๋ก ๋ฌธ์ ๊ฐ ๋ฐ์ํ๋ค๋ฉด ์คํฌ๋ฆฝํธ ์๋ฌ๋ก ์ธํด ํ์ด์ง ํ์๊ฐ ์๋๋ ๋ฌธ์ ๋ฐ์
try & catch ๋ก ๊ฐ์ธ๋ ์์ ํ์ง ์๋ค.
request abort
์ ๋ฐ์๋๋ error๋AbortError
, DOMException์ด๋ฏ๋ก cause ์์ฑ์ด ์๋ค.DOMException error๋ ์ผ๋ฐ์ ์ธ ํ์ ์๋ฌ๊ฐ ์๋๊ธฐ ๋๋ฌธ์ ์๋ฌ๊ฐ ์ผ์ด๋ ์์ฑ(
error.cause
)์ด ์์ด ์คํฌ๋ฆฝํธ ์๋ฌ๋ก ์ธํด ํ์ด์ง ํ์๊ฐ ์๋จ
JSON.stringify()๋ฅผ ์ฌ์ฉํ ๋ data๊ฐ Serializable ํ์ง ์์ ๊ฒฝ์ฐ (์ค๋ธ์ ํธ๊ฐ ์ํ์ฐธ์กฐ๊ฐ ๋๋ ๊ฒฝ์ฐ) ํ์ ์๋ฌ ๋ฐ์์ผ๋ก ํ์ด์ง ํ์ ์๋จ
์ ์ดํ ์ ์๋ ์๋ฌ
์๋ฌ๋ ์ํฉ์ ๋ฐ๋ผ ๊ฐ๊ฐ ๋ค๋ฅด๊ฒ ๋ฐ์ํ๋ฉฐ ๋ชจ๋ ์ผ์ด์ค๋ฅผ ์์ ํ ์ ์ดํ๋ ๊ฒ์ ์ด๋ ต๋ค.
์ ์ดํ ์ ์๋ ๋ถ๋ถ์์ UI Blocking์ ๋ฐ์์ํค๋๊ฒ์ด ๋ฌธ์
์ ์ดํ ์ ์๋ ๋ถ๋ถ์์ ์๋ฌ๊ฐ ๋ฐ์ํ ๊ฒฝ์ฐ, ํด๋น ๋ถ๋ถ์ ๊ฐ์ธ ์๋ฌ๊ฐ ์ ํ๋์ด ํ์ด์ง๊ฐ ์ค๋จ๋๋ ๊ฒ์ ๋ฐฉ์งํ๋ ๊ฒ์ด ์ค์
Error Boundary
UI ์ผ๋ถ๋ถ์ ์คํฌ๋ฆฝํธ ์๋ฌ๊ฐ ์ ์ฒด ์ ํ๋ฆฌ์ผ์ด์ ์ ์ค๋จํด์๋ ์๋๋ค.
์ ํ๋ฆฌ์ผ์ด์ ์ ์ฒด๊ฐ ์ค๋จ๋๋๊ฒ์ ๋ฐฉ์งํ๊ธฐ ์ํด React v16์์ Error Boundary๋ผ๋ ์๋ก์ด ๊ฐ๋ ์ด ๋์ ๋จ
React Component tree ํ์ ๋ด๋ถ์ ์๋ฐ์คํฌ๋ฆฝํธ error๋ฅผ catchํ๋ ์ปดํฌ๋ํธ
๋ฌธ์ ๊ฐ ๋ฐ์ํ ๋ถ๋ถ์ ๋ํด falback UI๋ฅผ ์ ๊ณตํ๋ค.
ํน์ง
ErrorBoundary ์์ ์ปดํฌ๋ํธ์์ ์๋ฌ๊ฐ ๋ฐ์๋ ๊ฒฝ์ฐ ๊ฐ์ฅ ์ธ์ ํ ์์ ErrorBoundary์ ์ ๊ณต๋ Fallback UI๋ฅผ ๋ ๋๋ง
ErrorBoundary๋
componentDidCatch
๋ผ์ดํ์ฌ์ดํด ๋ฉ์๋๋ฅผ ์ฌ์ฉํ์ฌ ์๋ฌ๋ฅผ ์ฒ๋ฆฌํ๋ค.ํด๋น ๋ฉ์๋๋ Class Component์์๋ง ์ฌ์ฉ์ด ๊ฐ๋ฅํ๊ธฐ ๋๋ฌธ์ ErrorBoundary ์ปดํฌ๋ํธ๋ Class๋ก ๋ง๋ค์ด์ง๋ค.
ErrorBoundary๋ฅผ ๊ตฌํํ ๋ ์ค๋ฅ์ ๋ํ ์๋ต์ผ๋ก ์ํ๋ฅผ ์ ๋ฐ์ดํธํ๊ณ ์ฌ์ฉ์์๊ฒ ์ค๋ฅ ๋ฉ์์ง๋ฅผ ํ์ํ ์ ์๋
Static getDerivedStateFromError
,componentDidCatch method
์ด ๊ตฌํ๋์ด์ผ ํ๋ค.
getDerivedStateFromError()
error๋ฅผ ๋งค๊ฐ๋ณ์๋ก ๊ฐฑ์ ๋ state๋ฅผ ๋ฐํํ๋ค.
render step์์ ํธ์ถ (VDOM์ด ์์ฑ๋๊ณ ์ด์ VDOM๊ณผ ๋น๊ตํ๋ ๋จ๊ณ์์ ํธ์ถ๋จ)
VDOM ๊ตฌ์ฑ์ด ๊นจ์ง๋ฉด ์๋๊ธฐ ๋๋ฌธ์ ๋ด๋ถ์์ ์ฌ์ด๋์ดํํธ๊ฐ ๋ฐ์ ๊ฐ๋ฅํ ์์ ์ ํด์ ์๋จ
fallback UI๋ฅผ ๋ ๋๋งํ ์ง ์ฌ๋ถ๋ฅผ ๊ฒฐ์ ํ๋ ์์ ์ผ๋ก์ ์๋ฌ ์ํ๋ฅผ ์ ๋ฐ์ดํธํ๋ ์ฝ๋๋ง ์์ฑ
componentDidCatch()
commit step์์ ํธ์ถ (VDOM ๋ณ๊ฒฝ์ฌํญ์ ์ค์ DOM์ ์ ์ฉํ๋ ๋จ๊ณ์์ ํธ์ถ๋จ)
์ฌ์ด๋์ดํํธ๊ฐ ๋ฐ์ํด๋ ๋ฌด๊ด
์๋ฌ ์ ๋ณด๋ฅผ ๋จ๊ธธ ๋ ์ฌ์ฉํ๋ค. (์๋ฌ ๋ก๊น )
error -> ์๋ฌ์ ๋ํ ์ ๋ณด
info -> ์ด๋ค ์ปดํฌ๋ํธ๊ฐ ์๋ฌ๋ฅผ ๋ฐ์์์ผฐ๋์ง์ ๋ํ ์ ๋ณด (componentStack)
ErrorBoundary๊ฐ ๋ค๋ฃจ์ง ์๋ Error
Async ๋์๋ค (Event Handler, setTimeout, rAF)
์ฌ์ฉ์ ์ธํฐ๋ ์ ๋๋ ํน์ ์ด๋ฒคํธ๋ก ๋ ๋๋ ์ดํ์ ๋ฐ์๋๊ธฐ ๋๋ฌธ์ ErrorBoundary๊ฐ catchํ์ง ๋ชปํ๋ค.
์ฆ, ๋ ๋๋ง ๋์ค์ ์ผ์ด๋ Error๋ง catch ๊ฐ๋ฅ
unhandledrejection
์ด๋ฒคํธ๋ฅผ ํตํด ํ์ ์ปดํฌ๋ํธ์ ๋น๋๊ธฐ ์๋ฌ๋ฅผ ์์ ์ปดํฌ๋ํธ์์ ์ก์๋ผ ์ ์๋ค.promise.reject๊ฐ ๋ฐ์ํ๋ฉด ์ด๋ฒคํธ ๋ฐ์๋จ
ServerSide Rendering
ErrorBoundary ๋ด๋ถ ์๋ฌ
try-catch๋ก ์ฒ๋ฆฌ๋ ์๋ฌ
unhandledrejection event
react-Error-Boundary
์ง์ ErrorBoundary๋ฅผ ์ ์ํ์ง ์๊ณ ์์ฉํ๋ ๋ผ์ด๋ธ๋ฌ๋ฆฌ๋ฅผ ์ฌ์ฉ
fallbackRender()
-> props์ผ๋ก ์๋ฌ์ ๋ฐ๋ฅธ fallback UI ๊ตฌ์ฑ ๊ฐ๋ฅ
useErrorBoundary() hook
-๋น๋๊ธฐ ์ฝ๋ ์คํ ์ดํ์ ๋ฐ์ํ๋ ์๋ฌ๋ฅผ ๋์ํ๊ธฐ ์ํ showBoundary() ๋ฅผ ์ ๊ณต
fallback ์ปดํฌ๋ํธ ๋ด์์ ๋ฆฌ๋ ๋๋ง์ ๋ฐ์์ํค๊ธฐ ์ํ resetBoundary()๋ฅผ ์ ๊ณต
withErrorBoundary() HOC ์ปดํฌ๋ํธ ์ ๊ณต
Sentry
์ฝ๋ ๊ด๋ จ ๋ฌธ์ ๋ฅผ ์๋ณํ๊ณ ์์ ํ๋๋ฐ ๋์์ ์ฃผ๋ ์ํํธ์จ์ด ๋ชจ๋ํฐ๋ง ๋๊ตฌ
๋ฐํ์ ๋จ๊ณ์ ์๋ฌ๋ฅผ ์์ง
์๋ฌ๊ฐ ๋ฐ์ํ ํ๊ฒฝ์ ๋ก๊ทธ๋ฅผ ์ง์ ํ์ธํ๋ ๊ฒ์ ๋ถ๊ฐ๋ฅํ๊ณ ์๋ฌํ๊ฒฝ์ ์ฌํ์ด ๋ถ๊ฐ๋ฅํ๊ธฐ ๋๋ฌธ์ ์๋ฌ๋ฅผ ์์งํ๋๊ฒ์ด ์ค์ํ๋ค.
ํด๋ผ์ด์ธํธ ์๋ฌ๋ฅผ ์์งํ์ฌ ์ฌ๋์ ์ฐ๋ํ์ฌ ์๋ฆผ ์ ๊ณต
์์ค์ฝ๋ ์ปจํ ์คํธ์ ๋๋ถ์ด Stack trace ์ ๊ณต
Commit ์ ๋ณด ๋ฐ Stack trace ๊ธฐ๋ฐ์ผ๋ก ์์ฌ์ค๋ฌ์ด commit ๋ฐ ํ ๋น์ ์ ์
Sentry ๊ธฐ๋ฅ
Stack trace
์ ๊ณต๋ SourceMap ๊ธฐ๋ฐ Stack trece๋ก ์๋ฌ ํ๊ฒฝ ํ์ ๊ฐ๋ฅ
์ฌ๋ฌ ์๋ฌ๋ฅผ ๊ทธ๋ฃนํํ์ฌ ํ๋์ ์ด์๋ก ์ ์
์ด๋ฒคํธ๊ฐ ๋ฐ์ํ ์ฝ๋๊ฐ ์ด๋์์ ์๋ฌ๋ฅผ ๋ฐ์ ์์ผฐ๋์ง ํ์ธ ๊ฐ๋ฅ
Breadcrumb
Error Event ๋ฐ์๊น์ง์ ๊ธฐ๋ก๊ณผ ํ์๋ผ์ธ ์ ๊ณต
HTTP Request, Console.log, Server log, DOM Event ๋ฑ์ด ํฌํจ๋๋ค.
์ด๋ค ๋์๋ค๋ก ์ฌ์ฉ์๊ฐ ์๋ฌ๊ฐ ๋ฐ์ํ๋์ง ์ด์ ๋ฅผ ๋ช ํํ๊ฒ ํ์ ํ๊ณ ํด๋น ์ปจํ ์ค๋ฅผ ์ดํดํจ์ผ๋ก์จ ์๋ฌ๋ฅผ ์ฌํํ๊ธฐ ์ฉ์ดํด์ง๋ค.
Session Replay
์ฌ์ฉ์ ์ธ์ ์ ๋น๋์ค์ฒ๋ผ ์ฌํ
์ค๋ฅ/์ฑ๋ฅ ๋ฌธ์ ๋ฐ์ ์ /ํ ์ํฉ ํ์
๋ฌธ์ ์ ๋ํ ์ฌ์ธต์ ์ธ ๋๋ฒ๊น , ๋ฌธ์ ๋ฅผ ์ฌํํ๊ณ ๋ ๋น ๋ฅด๊ฒ ํด๊ฒฐ ๊ฐ๋ฅ
UI ์ด์์ ๊ฒฝ์ฐ ์ ๊ณต
๋ นํ ์์ ํธ๋ฆฌ๊ฑฐ
replay.start()
์๋ ํธ์ถ์ธ์ ์ด replaySessionSampleRate์ ์ํด ๋ นํ์ฌ๋ถ ๊ฒฐ์
๋ นํ ์ข ๋ฃ ํธ๋ฆฌ๊ฑฐ
replay.stop()
์๋ ํธ์ถ์ฌ์ฉ์ ๋นํ์ฑ ์ํ, ์ต๋ ์๊ฐ์ ๋๋ฌ (๊ธฐ๋ณธ 60๋ถ)
Alert
์ฝ๋์ ๋ฌธ์ / ์ฌ์ฉ์์๊ฒ ๋ฏธ์น๋ ์ํฅ์ ๋ํ ์ค์๊ฐ์ ์ธ ๊ฐ์์ฑ ์ ๊ณต
์ง์ ํ ๊ท์น์ ์ํด ๋ฐ์๋๋ alert
alert ๋ชฉ๋ก ํํฐ๋ง, alert์ ๋ํ ๋นํ์ฑํ/mute ๊ธฐ๋ฅ, notification ์ ๊ณต
์ค์น
๋ถ๊ฐ ์ฌ์ฉ ๋ฐฉ๋ฒ
Issue ํจ๋
์ ํ๋ฆฌ์ผ์ด์ ์ค๋ฅ, ์ฑ๋ฅ๋ฌธ์ ์ ๋ํ ์ ๋ณด ํ์
ํ๊ฒฝ์ ๋ฐ๋ฅธ ํํฐ๋ง ๊ฐ๋ฅ
ํ๋์ ์ด์๋ ์ ์ฌํ ์์ธ์ผ๋ก ๊ทธ๋ฃนํ๋ ์๋ฌ๋ค
์ด์์ ๋ฐ์ ๋น๋, ์ถ์ด, ์ฌ์ฉ์๋ณ ์ํฅ๋ ํ์ ๊ฐ๋ฅ
์ผ๋ฐ์ ์ธ ์ฑ์ ๋๋์ ์ด๋ฒคํธ๋ค์ ์ผํธ๋ฆฌ์ ์ ์กํ๊ฒ ๋๋๋ฐ ์ ๋ง์ ์๋ฌ๋ค์ด ์ ์ก๋๋ฉด์ ์ด๋ฐ ์๋ฌ๋ค์ ํํฐ๋ง ๋ฐ ๊ทธ๋ฃนํํด์ ๋ณด์ฌ์ฃผ์ง ์๊ฒ๋๋ฉด ์ฐพ๊ณ ํ์๋ ๋ฉ์ด์ ํ ์ด์ ๋ฐ ๋ณด๊ณ ์๋ ์ด์๋ค์ ํธ๋ํฝ, ๋น๋, ์ํฉ ์ถ์ด ๋ฑ์ ์ ๋ณด๋ค์ ํฝํด์ ๋ณด๊ธฐ ์ฝ์ง ์๊ธฐ์ ์ผํธ๋ฆฌ๋ ์ด๋ฐ ๋๋ ์ด๋ฒคํธ๋ค์ ๊ทธ๋ฃนํํด์ ์ฒ๋ฆฌํ๊ฒ ๋๋ค.
Issue ์ํ
New: ์์ฑํ์ง 7์ผ ์ด๋ด์ธ ์ด์
Ongoing: 7์ผ ์ด์ ๋์๊ฑฐ๋, ์๋์ผ๋ก reviewed ์ฒ๋ฆฌ๋ ์ด์
Escalating: ์ค๋๋ ์ด์ ์ค ๋น๋๊ฐ ๊ธ๊ฒฉํ ๋์ด๋ ์ด์
Regressed: resolved ๋์๋ค๊ฐ ๋ค์ ๋ํ๋ ์ด์
Archived: ๋ณด๊ด์ฒ๋ฆฌ๋ ์ด์
Resolved: ํด๊ฒฐ ์ฒ๋ฆฌ๋ ์ด์
Issue ํญ
Unresolved: ๊ฒํ ๊ฐ ํ์ํ, ์์ง ํด๊ฒฐ๋์ง ์์ ๋ชจ๋ ์ด์ ์ด์งํฉ
For Review: ๊ฒํ ๋ชฉ๋ก, ๊ฒํ ๊ฐ ํ์ํ ์ด์, ํด๊ฒฐ๋์ง ์์ ์ด์๋ค์ ํ์ ์งํฉ
Regressed: ํด๊ฒฐ๋ ์ด์, ํด๊ฒฐ๋์ด์๊ฐ ๋ค์ ๋ฐ์ํ ์ด์
Escalating: ์ด์ ์ archived ๋ฌ๋ ์ด์ ์ค ์์๋๋ ์ด์ ๋น๋๊ฐ ์ด๊ณผ๋ ์ด์
Archived: ํด๊ฒฐ ์ฒ๋ฆฌ๋ ์ด์๋ค
Issue ํํฐ
By Project
By Environment
By Time
Custom filter
Issue ์์ธ ํจ๋
์ด์ ์ถ์ฒ
์ํฅ ๋ฒ์
๊ทธ๋ฃนํ๋ ์ด์์ ๋ํ ์์ฝ
24์๊ฐ/30์ผ๊ฐ์ ๋น๋
๊ด๋ จ ํ๊ทธ ์ ๋ณด
Stack Trace
Breadcrumbs
Session Replay ์ค์
Sentry.init() ๋ด์ ๊ธฐ๋กํ๋ ์ค์ ๊ฐ
์๋ ์ค์ ์, sentry.client.config.ts/js ์ ์ ์
Sampling Rate ์ค์ ํ๋ ์ด์
๋งค์ฐ ๋น์
quota์ ๋ํ ์ดํด์ ๊ธฐ๋ฐ
-> ์ฌ์ฉ๋์ ๋ฐ๋ฅธ ๊ณผ๊ธ ๊ตฌ์กฐ
์ผ๋ฐ sentry error ๋ณด๋ค 10๋ฐฐ ์ด์์ ๊ฐ๊ฒฉ
๊ผญ ํ์ํ ๋ถ๋ถ์์๋ง ๋์ or ์ํ๋ง ๋น์จ ์กฐ์
Session Replay ํจ๋
ํ์๋ผ์ธ
ํ๋ ์ด์ด
Breadcrumbs
๊ธฐํ ์ปดํฌ๋ํธ ํจ๋๋ก ๊ตฌ๋ถ
ํ์ด์ง ์ก์
๋ฆฌํ๋ ์ด ๊ณต์
์ญ์
Last updated