해결된 질문
작성
·
75
0
학습 관련 질문을 최대한 상세히 남겨주세요!
고민 과정도 같이 나열해주셔도 좋습니다.
먼저 유사한 질문이 있었는지 검색해보세요.
인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.
안녕하세요! 강의 잘 들었습니다!
궁금한 점이 있어서 문의 드립니다.
강의에서는 상위 1000건에 대해서 articleId를 기준으로 Redis 캐시를 해두었는데 혹시 키워드(제목, 작성자, 내용등)에 대한 검색 페이징 처리도 캐시가 가능한걸까요?
제가 생각했을 때는 아래와 같은 방법으로 처리가 가능할 것 같은데 보통 대용량 트래픽 환경에서 해당 케이스를 어떻게 처리하는지 궁금합니다!
키워드 검색이 있을 경우 RDB에서 직접 조회
키워드 검색 조건 별로 Redis 캐시
Elasticsearch 도입 후 동기화하여 키워드 검색시 Elasticsearch에서 조회
답변 2
0
alstn9623님, 안녕하세요!
검색의 경우 캐싱이나 대규모 트래픽 처리 전략이 조금 다를 수 있는데요,
여러가지 전략들을 혼합해서 적용할 수 있을 것 같습니다.
자주 검색되는 키워드 캐싱
정규화된 키워드로 캐싱(공백 제거 등)
첫 페이지만 캐싱하거나 특정 고정된 파라미터로 캐싱
질의 서버와 색인 서버 분리
그리고 검색을 위한 인덱싱은 일반적인 RDB 방식과 달리 Inverted Index라는 방식이기 때문에 elasticsearch와 같은 검색 엔진을 사용하는게 좋습니다!
네, 맞습니다!
원본 데이터는 메인 DB(여기서는 rdb)에 저장하고,
Elasticsearch에 복제하는게 일반적입니다.
다만, 검색 문서 색인의 경우 원본 데이터를 그대로 복제할 필요는 없습니다.
결국 검색을 위한 것이므로 색인할 필드만 저장해도 충분합니다.
그러면 검색엔진 검색 결과와 식별자만 뽑아와서 메인 DB와 애플리케이션에서 조인할 수 있고, 색인의 경우 지연이 생길 수도 있기 때문에 실시간성을 같이 챙길 수도 있습니다!
Redis와 최신 게시글은 검색엔진과 별개의 문제인데, 같이 생각할 필요는 없을 것 같네요.
아무튼 말씀하신 전략도 가능합니다.
0
안녕하세요, 인프런 AI 인턴입니다. alstn9623님.
질문 주신 키워드 검색 페이징과 관련한 Redis 캐시 처리에 대해서 설명 드리겠습니다. 키워드 기반 검색은 복잡도가 높은 연산으로, 효율적인 데이터 저장 및 조회를 통해 성능을 최적화할 수 있습니다.
이 내용이 도움이 되셨기를 바라며, 추가적으로 자세한 전략이나 구현에 대해 더 궁금한 점이 있으시면 언제든지 질문해 주세요. 관련된 유사한 질문으로는 “Elasticsearch와 Redis의 통합 활용에 대한 예시”도 참고하실 수 있습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
답변 감사합니다!
말씀해주신 것 처럼 상황에 따라 적용할 수 있는 전략은 다양하겠지만
만약 엘라스틱서치를 도입한다면 게시글 데이터를 저장할때 DB와 Elasticsearch에 모두 저장해준 다음, 최신 게시글 목록을 조회할 경우 Redis에 캐싱된 데이터를 반환해주고 키워드 검색을 통한 조회시 Elasticsearch를 통해 조회하여 반환해주면 되는걸까요?