Commit e8613e19 authored by Marc Shaw's avatar Marc Shaw

Refactor the HLL unique counting of visits and event actions

Merge Request: gitlab.com/gitlab-org/gitlab/-/merge_requests/36583
parent 5d465c31
...@@ -25,26 +25,19 @@ module Gitlab ...@@ -25,26 +25,19 @@ module Gitlab
def track_visit(visitor_id, target_id, time = Time.zone.now) def track_visit(visitor_id, target_id, time = Time.zone.now)
target_key = key(target_id, time) target_key = key(target_id, time)
Gitlab::Redis::SharedState.with do |redis| Gitlab::Redis::HLL.add(key: target_key, value: visitor_id, expiry: KEY_EXPIRY_LENGTH)
redis.multi do |multi|
multi.pfadd(target_key, visitor_id)
multi.expire(target_key, KEY_EXPIRY_LENGTH)
end
end
end end
def weekly_unique_visits_for_target(target_id, week_of: 7.days.ago) def weekly_unique_visits_for_target(target_id, week_of: 7.days.ago)
Gitlab::Redis::SharedState.with do |redis| target_key = key(target_id, week_of)
redis.pfcount(key(target_id, week_of))
end Gitlab::Redis::HLL.count(keys: [target_key])
end end
def weekly_unique_visits_for_any_target(week_of: 7.days.ago) def weekly_unique_visits_for_any_target(week_of: 7.days.ago)
keys = TARGET_IDS.map { |target_id| key(target_id, week_of) } keys = TARGET_IDS.map { |target_id| key(target_id, week_of) }
Gitlab::Redis::SharedState.with do |redis| Gitlab::Redis::HLL.count(keys: keys)
redis.pfcount(*keys)
end
end end
private private
......
# frozen_string_literal: true
module Gitlab
module Redis
class HLL
def self.count(params)
self.new.count(params)
end
def self.add(params)
self.new.add(params)
end
# NOTE: It is important to make sure the keys are in the same hash slot
# https://redis.io/topics/cluster-spec#keys-hash-tags
def count(keys:)
Gitlab::Redis::SharedState.with do |redis|
redis.pfcount(*keys)
end
end
def add(key:, value:, expiry:)
Gitlab::Redis::SharedState.with do |redis|
redis.multi do |multi|
multi.pfadd(key, value)
multi.expire(key, expiry)
end
end
end
end
end
end
...@@ -35,16 +35,15 @@ module Gitlab ...@@ -35,16 +35,15 @@ module Gitlab
transformed_target = transform_target(event_target) transformed_target = transform_target(event_target)
transformed_action = transform_action(event_action, transformed_target) transformed_action = transform_action(event_action, transformed_target)
target_key = key(transformed_action, time)
add_event(transformed_action, author_id, time) Gitlab::Redis::HLL.add(key: target_key, value: author_id, expiry: KEY_EXPIRY_LENGTH)
end end
def count_unique_events(event_action:, date_from:, date_to:) def count_unique_events(event_action:, date_from:, date_to:)
keys = (date_from.to_date..date_to.to_date).map { |date| key(event_action, date) } keys = (date_from.to_date..date_to.to_date).map { |date| key(event_action, date) }
Gitlab::Redis::SharedState.with do |redis| Gitlab::Redis::HLL.count(keys: keys)
redis.pfcount(*keys)
end
end end
private private
...@@ -69,17 +68,6 @@ module Gitlab ...@@ -69,17 +68,6 @@ module Gitlab
year_day = date.strftime('%G-%j') year_day = date.strftime('%G-%j')
"#{year_day}-{#{event_action}}" "#{year_day}-{#{event_action}}"
end end
def add_event(event_action, author_id, date)
target_key = key(event_action, date)
Gitlab::Redis::SharedState.with do |redis|
redis.multi do |multi|
multi.pfadd(target_key, author_id)
multi.expire(target_key, KEY_EXPIRY_LENGTH)
end
end
end
end end
end end
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment