IN-IT프로젝트에 좋아요와 같은 기능을 추가하고자 고민을 하다가 Redis를 사용하게 되었다.
실은 사용하게 되었다 라기 보단.. 사용해보고 싶었다!
안해봤으니까 새로운건 (조금 빡쳐두) 재밌으니까!
Redis를 왜 사용해보고 싶었냐면,
1. 캐싱서버를 이용해 데이터를 저장해보고 싶었다. (굳이 db를 여러 종류로 쓰면서 까지 효율적인가 궁금했었다)
2. 흔히 쓰는 mysql과는 다른 저장방식이라 궁금했다.
등등 여러 이유가 있었다.
일단 사용하기 위해선 Redis가 무엇인지 정확히 아는 것이 중요하다고 생각했다.
Redis는 in-memory 데이터 구조 저장소이며, 매우 빠른 속도가 높은성능을 제고아고, 다른 데이터 베이스와 비교하여 더 적은 리소스를 사용하는 장점을 지닌다.
Redis는 문자열, 해시, 목록, 집합, 정렬된 집합 등 다양한 데이터 형식을 지원하기 때문에 따라서, 다양한 언어와 프레임워크에서 사용할 수 있다.
마지막으로 Redis는 다양한 용도로 사용할 수 있다. 예를 들어, Redis는 세션 저장소로 사용될 수 있으며, 대용량 데이터를 처리하는 데 사용될 수 있다. Redis는 또한 데이터베이스, 캐시 및 메시지 브로커로 사용될 수 있으며, 다른 용도로도 사용할 수 있다.
→ 한마디로, 동전지갑 같은 느낌? 간단한데, 이것저것 다 담을수 있고, 여기저기 쓰이는 그런 것으로 보인다.
redis에는 다양한 캐싱전략이 존재한다.
이 전략들의 특징을 알고, 적절하게 써야 프로젝트의 퍼포먼스를 전반적으로 향상시킬 수 있다.
참고한 사이트 ⬇️
1. https://www.alibabacloud.com/blog/struggling-with-poor-responsiveness-unlock-the-power-of-caching_596214
2. https://www.codepedia.org/vladmihalcea/a-beginners-guide-to-cache-synchronization-strategies/
프로젝트에 사용하기 위해서 여러 캐싱 전략 조합을 생각해보았다.
Cache aside + Write around
: 캐시에 요청을 보내고, miss날 경우, db에서 가져온다. write는 db에만 주로 실행되므로, cache 용량의 걱정을 덜 수 있다.
Read-Through + Write around
: write를 통해 db에 데이터를 저장해두면, 캐시를 통해 읽어올 때, miss가 날 경우 db를 항상 들리므로, 데이터 정합성의 문제를 줄 일 수 있다.
3. Read-Through + Write Through
: 데이터 쓸 때 캐시 → DB / 읽을 때도, 캐시 → DB로 실행방향이 똑같아서, 가장 안정적인 퍼포먼스를 보여준다.
그 외는, 영구적인 데이터 손실을 우려해서 조합을 생각하지 않았다.
결국 선택한 방법은 3번!!
그 이유는,
일단 좋아요라는 특성이 단순히 보여지는 것 뿐만 아니라, 그 좋아요 순으로 글을 순서화하게 되는 기능이 존재하기 때문에, 데이터 유실이 일어나면 안되고, 또한 데이터 정합성도 중요하다고 판단했기 때문에, 3번을 선택하게 되었다.
이거 이해하고, 어떤 전략으로 짤지 고민하는 데 엄청 오래 걸렸다.
나름 뿌듯하지만.. 너무 졸렸다는...ㅠ
이제 코드 작성해야한다.
실은 지금 코드는 어느정도 짜여있는데, 너무 많이 다듬어야해서 거의 새로 짜는 급.. 헤헤
어쨋든 마무리 잘해봐야겠다.