inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

AI 다루는 백엔드 설계 기본 - SpringBoot SNS 편

세션 로그인 ▶︎ 구현과 동작

강의를 듣던 중 궁금한 점 있어요

해결된 질문

93

SPRING

작성한 질문수 4

1

수업 챕터

14. 세션 로그인 ︎ 구현과 동작

에서 6분 35초쯤에

 

Docker 에서 Redis Container 로 진입하시고

/data # redis-cli

명령을 작성하실 때,

 

원래는 이런 명령어를 사용하시면 안된다고 하시는데

그럼 원래는 무슨 명령어를 사용하는지 궁금하네요

 

 

postgresql spring-boot dbms/rdbms redis s3

답변 1

1

한조각

안녕하세요 SPRING 님!

 

redis-cli 에서 사용한 keys * 명령어를 사용하시면 안된다고 말씀드린 부분입니다. (다시 들어보니 말하는 타이밍이 조금 오해가 있을 수 있을 것 같습니다! 영상 이해에 방해가 되었다면 죄송합니다.)

추가로 설명드리면,
keys * 는 모든 키를 전부 스캔해서 결과를 한 번에 반환하는 명령입니다.
위 명령어를 사용하시게 되면 redis 는 대부분 명령을 단일 스레드로 처리하기 때문에 키가 수천만개 이상 아주 많은 경우, 다른 모든 요청이 대기하는 상태가 되게 됩니다.
트래픽이 많은 경우 타임아웃, 커넥션 끊어짐, 장애 전파 등으로 이어질 수 있습니다.
또한 반환되는 키가 많으면 네트워크 패킷 크기도 커서 받는 서버입장도 부하가 커지겠죠.

그래서 keys 대신 scan 을 많이 이용하기도 합니다. 스캔은 한 번에 조금씩만 조회하고 바로 제어권을 반환하는 방식으로 구성되어있어서, redis 가 다른 요청도 계속 처리할 수 있는 장점이 있습니다.

 

질문 주셔서 감사합니다.

드랍 테이블로 지운 ordes에 대해서 질문

0

20

1

실무 내용 문의드려요

0

21

2

문제 풀이 1번 질문

0

26

1

코드 질문

0

25

1

To-Do App

0

27

1

twitterdb 연결이 안돼요

1

26

2

Kafka Cluster 구성도 질문

0

22

1

시큐리티 필터 설정 질문입니다!

2

43

1

강의가 싱크가 안맞는것 같아요..

0

29

1

질문 드립니다!

0

89

1

프론트 API 작업

1

99

2

agents와 commands에 대해 궁금한 점이 있습니다!

1

114

2

.claude 폴더 규칙 생성 방법

1

168

2

강의를 어떻게 보면 좋을 까요?

1

132

2

SKILLS.md나 agents 작성 문의

1

144

1

CSRF 관련 궁금한게 있어요

1

79

1

안녕하세요 강사님 데이터베이스 선택 질문있습니다!!

1

109

2

안녕하세요 질문있습니다.

1

103

1

클로드 대신 제미나이 사용해도

1

711

2

claude 동작 결과값이 다를 경우 어떻게 해나가야 될지 모르겠습니다.

2

163

2

hooks가 동작하기 위한 내용이 없는 것 같아서 추가가 필요하지 않을까 싶습니다.

1

128

3

.claude폴더를 복붙해서 넣긴 넣었는데 궁금한 점이 생겼어요.

1

192

2

터미널에서 claude 입력 과정

1

89

1

.claude 안에 폴더 및 파일은 어떻게 생성하죠?

2

229

1