동일한 사용자가 특정 상품을 몇 번이나 클릭하더라도 1번으로만 집계되며, 해당 상품의 클릭 횟수는 실시간으로 집계됩니다.
최적의 솔루션을 달성하는 방법. 이 상황
지금 생각나는 건 그냥 redis
set
데이터 형식을 사용하고, 클릭할 때마다 redis
을 사용하여 저장하는 것입니다. set
은 반복할 수 없기 때문에 SCARD
과 총계가 계산된 후 일정 시간이 지나면 데이터베이스에 저장됩니다. 하지만 나중에 데이터 양이 많아지면 메모리를 많이 차지하게 됩니다.
기다려주세요!!!
동일한 사용자가 특정 상품을 몇 번이나 클릭하더라도 1번으로만 집계되며, 해당 상품의 클릭 횟수는 실시간으로 집계됩니다.
최적의 솔루션을 달성하는 방법. 이 상황
지금 생각나는 건 그냥 redis
set
데이터 형식을 사용하고, 클릭할 때마다 redis
을 사용하여 저장하는 것입니다. set
은 반복할 수 없기 때문에 SCARD
과 총계가 계산된 후 일정 시간이 지나면 데이터베이스에 저장됩니다. 하지만 나중에 데이터 양이 많아지면 메모리를 많이 차지하게 됩니다.
기다려주세요!!!
매우 정확할 필요가 없고 어떤 사용자가 제품을 탐색했는지 알 필요가 없다면 HyperLogLog를 고려해 볼 수 있습니다
pfadd shop:{$good_id} user:{$user_id}
또한 phpredis 확장 프로그램을 2.2.7로 업데이트해야 사용할 수 있습니다
<code class="php">$redis->pfadd("key", array( $element1, $element2, ..., $elementN) );</code>
관련 참고 자료: Redis 카디널리티 통계 - HyperLogLog의 작은 메모리와 뛰어난 활용성
얼마나 클 수 있나요? 인앤아웃은 정말 없는거 아닌가요?
출금시에는 데이터를 데이터베이스에 브러시하여 숫자를 저장하는 동시에 사용자의 제품 클릭 관계를 저장하고 다음 외출시 확인할 수 있습니다.