제품 클릭을 처리하는 방법

WBOY
풀어 주다: 2023-03-01 18:52:01
원래의
1367명이 탐색했습니다.

동일한 사용자가 특정 상품을 몇 번이나 클릭하더라도 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의 작은 메모리와 뛰어난 활용성

얼마나 클 수 있나요? 인앤아웃은 정말 없는거 아닌가요?

출금시에는 데이터를 데이터베이스에 브러시하여 숫자를 저장하는 동시에 사용자의 제품 클릭 관계를 저장하고 다음 외출시 확인할 수 있습니다.

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿