inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

한 입 크기로 잘라먹는 Next.js

5.3) 풀 라우트 캐시 3. 동적 경로에 적용하기

풀라우트캐시 3강. book/4를 URL로 요청시 렌더링 과정

해결된 질문

177

dudptl0220

작성한 질문수 2

0

안녕하세요 선생님, 질문이 있어서 남깁니다.

만약 book/4를 URL로 요청하면 과정이

 

URL로 book/4 요청 시 Link 등이 없으므로 프리페칭은 안됨

- 서버에서 JS 실행 (렌더링)

- 렌더링 된 HTML 브라우저에 넘김

- 브라우저에서 화면에 렌더링

- 서버에서 JSBundel, RSC payload 브라우저에 넘김

- 수화과정

- 상호작용 가능

 

이게 맞나요?

 

book/1~3은 staticPage로 풀라우트캐시되어있으니

URL로 요청하면 풀라우트캐시에서 바로 HIT해서 주는거고요?

react typescript next.js

답변 2

0

이정환 Winterlood

안녕하세요 이정환입니다.

generateStaticParams에 1, 2, 3만 리턴한 상황을 말씀하시는 거라면 말씀하신 내용이 맞습니다.

참고로 Static 페이지로 생성되어 있는 페이지들 또한 JS Bundle 전달 + 하이드레이션 과정은 동일하게 이루어집니다.

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. dudptl0220님.

Next.js의 풀 라우트 캐시에 대해 질문해 주셨네요. 질문하신 내용을 기준으로 설명드리겠습니다.

렌더링 과정 설명:

  1. URL 요청 (book/4):

    • 프리페칭은 Link 컴포넌트를 통해 연결된 페이지에서 이루어지며, book/4는 직접 URL로 접근하는 경우 프리페칭이 이루어지지 않습니다.
  2. 서버에서 JS 실행 및 렌더링:

    • 서버에서 해당 경로에 대한 요청을 받으면, 필요한 데이터를 받아와서 페이지를 렌더링합니다. 이 과정은 서버에서 처리되므로 클라이언트가 요청 시점에 서버 컴포넌트를 실행하게 됩니다.
  3. 렌더링된 HTML 전달:

    • 렌더링된 HTML이 브라우저로 전달되어 초기 화면으로 보여지게 됩니다. 이는 SEO에도 유리한 방식입니다.
  4. RSC Payload와 JS Bundle 전달:

    • 이후, RSC(React Server Components) Payload와 필요한 JS Bundle들이 브라우저로 전달됩니다. 이 과정에서 클라이언트 측의 리액트 동작과정이 포함됩니다.
  5. 수화(hydration) 과정:

    • 브라우저에서 전달받은 JS를 통해 수화가 이루어집니다. 이로 인해 클라이언트 측의 상호작용이 가능해집니다.
  6. 상호작용 가능:

    • 수화 과정이 완료되면, 사용자는 페이지와 상호작용할 수 있습니다.

Static Page와 풀 라우트 캐시:

  • book/1~3가 static page로 사전 빌드되어 풀 라우트 캐시에 저장되어 있다면, 사용자가 해당 페이지를 요청할 때마다 동적으로 페이지를 생성하지 않고 풀 라우트 캐시에서 저장된 정적 HTML을 즉시 전달받게 됩니다. 이는 빠른 응답 속도를 제공합니다.

더 자세한 정보 확인:

이와 관련하여 정적 페이지 캐싱과 ISR 메커니즘에 대해 설명한 링크를 참고해주세요. Next.js의 업데이트된 기능을 활용한 최적화 방법에 대해 더 깊게 이해하실 수 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

풀라우트캐시 동작 원리에서 데이터 캐시 관련 질문

0

23

2

next.js 프로젝트

0

28

1

Next.js + Tanstack Query BFF 구조 질문

0

29

2

Next.js 사전렌더링 이해하기 부분

0

34

2

모달 관련 질문

0

42

3

렌더링 관련 질문

0

80

2

중복으로 하나의 api를 요청할 때 캐싱 옵션 통일화

0

64

2

라우트 세그먼트 옵션 강좌 노트에 사소한 제보 남깁니다.

0

65

2

SSR시 context에 params말고 query를 사용하면 안되나요?

0

75

2

npx prisma db push 시 에러가 뜹니다.

0

94

3

vercel 배포를 실패하였습니다.

0

101

3

Image 컴포넌트 사용시 브라우저 콘솔에 경고는 왜 뜨는걸까요?

0

57

2

getServerSideProps 함수와 SSR의 관계

0

78

6

없는 페이지인데 풀라우트캐시로 저장이 되는 이유가 궁금합니다

0

61

2

실제 프로젝트에서 SSR 사용에 관해서 질문드립니다.

0

117

2

일반적인 nextjs project architecture에 대하여..

0

90

2

2.14 Search에서 작성한건 static이긴하지만 CSR이 아닌가요?

0

74

2

배포 시 오류 발생

0

90

2

백엔드 서버 오류납니다.

0

83

2

취약점 제거시 nestjs 버전 문제가 생길까요?

0

93

1

eslint.config.mjs 내 rules 어떻게 설정 하나요?

0

107

1

[book]/[id]/page.tsx 모달 띄울 때 성능 하락 현상은 ReviewList를 불러오면서 발생하는 문제 같습니다.

0

63

2

빨간줄 설정

0

77

2

익스텐션 질문

0

61

1