inflearn logo
강의

Khóa học

Chia sẻ kiến thức

Bộ công cụ thư viện thực hành React một miếng - Zustand, Tanstack Query, TailwindCSS

(5.13) Chuẩn hóa Cache 2

(5.12) 캐시 정규화 하기 1 질문

30

kimsuro

3 câu hỏi đã được viết

0

안녕하세요
5.12 캐시 정규화하기 부분에 궁금한 부분이 있어 질문 남겨봅니다!

이 캐시 정규화는 리스트 페이지와 상세 페이지의 데이터가 같을 경우에만 사용 가능한 패턴인가요?

만약 상세 페이지에서 백엔드가 내려주는 데이터가 리스트 페이지와 비슷하지만 몇 개의 필드가 다르게 내려온다면 사용할 수 없는 패턴인가요?

react react-query

Câu trả lời 2

0

winterlood

안녕하세요 김수로님 이정환입니다.

네 말씀하신대로 리스트 페이지에서의 데이터와 상세 페이지에서의 데이터가 구조가 다르다면 강의에서 소개해 드린 방식대로 정규화 하는 것은 다소 효율적이지는 않을 것 같습니다.

일단 정규화 한 뒤 상세 페이지에서 추가로 몇개의 필드를 불러왔을때 수동으로 저장된 캐시에 추가해주는 방법도 가능은 하나, 이러면 오히려 캐시 관리가 너무 복잡해져 다른 이슈가 발생할 수 있습니다. ㅠㅠ

0

communityai8509

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

캐시 정규화는 주로 데이터가 일관되게 여러 페이지 또는 컴포넌트에 나타날 때 유용합니다. 특히, 리스트 페이지와 상세 페이지에서 동일한 데이터 구조를 공유하고 있을 때 생산적인 패턴입니다.

캐시 정규화 사용 조건

  1. 데이터 구조의 일관성: 캐시 정규화는 데이터를 키를 기준으로 관리하며, 이를 통해 리스트 페이지와 상세 페이지 등 여러 컴포넌트가 동일한 데이터를 사용할 수 있도록 해줍니다.
  2. 데이터의 부분적 공유: 만약 상세 페이지의 데이터가 리스트 페이지의 데이터와 부분적으로 다르다면, 기본적인 캐시 정규화를 수정하여 적용할 수 있습니다. 즉, 공통된 필드를 기준으로 캐시를 구성하고, 상세 페이지에서만 필요한 데이터는 추가적으로 관리하는 방식으로 종합할 수 있습니다.

유사한 사례 연구

캐시 정규화에 대한 유용한 설명을 참고하려면 아래 링크들을 살펴보세요:

  • 캐시 정규화 기초와 적용: 이 설명은 리스트 페이지와 같은 컴포넌트에서 데이터 일관성을 유지하는 방법을 다룹니다.
  • Zustand와 캐시 관리: 실제 사용 경험을 공유한 사례로, 다양한 데이터 상태 관리에서 캐시 정규화를 어떻게 적용할 수 있는지를 설명합니다.

이러한 관리 방식은 설계와 사업 요구에 맞춰 커스터마이징하여 활용하실 수 있습니다. 마찬가지로, Tanstack Query와 같은 상태 관리 라이브러리에서의 캐시 정규화 기능을 적극 활용하시면, 더욱 효율적인 성능 최적화를 이루실 수 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.

현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏

추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

mcp 설치를 못하겠어요

0

6

1

라이브러리 관련 질문 있습니다!

0

7

1

output-styles은 Claude Code의 공식 기능이 아니라고 하는데 혹시 변경된걸까요?

0

16

2

클로드 변경

0

13

1

/config 에서 output-style 을 변경

0

15

1

한국어 문제

0

15

2

Node.js 관련 질문드립니다.

0

22

3

클로드 버전업 설치

0

20

2

쿠폰 문의 드립니다.

0

13

2

13강 프로젝트 생성 Next.js 설치이슈

0

16

3

Shell Command: Install 'cursor' command 진행에서 막혔습니다

0

19

3

74. 데이터 캐시 - 1 (이론) 강의 영상 누락

0

21

1

Agent team / subagent 생성시 재사용 가능 여부

0

25

2

shirimp task manager는 프로젝트 처음 시작 단계에서도 쓴는 것 과 관련해서 질문

0

19

2

MCP 서버 내용 변경

0

24

2

설치가 완료되었다고 하는데 왜 확인이 안될까요?ㅠ

0

27

3

맥에서 git이 설치되지 않아요...

0

21

2

ll 명령어 문의

0

19

2

퀴즈 생성

0

27

2

프로젝트 하위 .claude 폴더

0

22

2

클로드코드에서 yes 를 always 로 설정하려면 어떻게 해야하죠?

0

29

2

claude 계정 두개

0

21

1

섹션3 Shadcn/ui 생성 시

0

95

1

섹션2 tailwindcss 퀴즈에 대해서

0

51

2