Class: RailsPerformance::Utils
- Inherits:
-
Object
- Object
- RailsPerformance::Utils
- Defined in:
- lib/rails_performance/utils.rb
Class Method Summary collapse
-
.cache_key(now = Date.today) ⇒ Object
date key in redis store.
- .days(duration = RailsPerformance.duration) ⇒ Object
- .fetch_from_redis(query) ⇒ Object
-
.field_key(now = RailsPerformance::Utils.time) ⇒ Object
write to current slot time - date -minute.
- .from_datetimei(datetimei) ⇒ Object
- .median(array) ⇒ Object
- .percentile(values, percentile) ⇒ Object
- .save_to_redis(key, value, expire = RailsPerformance.duration.to_i) ⇒ Object
- .time ⇒ Object
Class Method Details
.cache_key(now = Date.today) ⇒ Object
date key in redis store
12 13 14 |
# File 'lib/rails_performance/utils.rb', line 12 def self.cache_key(now = Date.today) "date-#{now}" end |
.days(duration = RailsPerformance.duration) ⇒ Object
43 44 45 |
# File 'lib/rails_performance/utils.rb', line 43 def self.days(duration = RailsPerformance.duration) (duration / 1.day) + 1 end |
.fetch_from_redis(query) ⇒ Object
22 23 24 25 26 27 28 29 30 31 32 |
# File 'lib/rails_performance/utils.rb', line 22 def self.fetch_from_redis(query) RailsPerformance.log "\n\n [REDIS QUERY] --> #{query}\n\n" keys = RailsPerformance.redis.keys(query) return [] if keys.blank? values = RailsPerformance.redis.mget(keys) RailsPerformance.log "\n\n [FOUND] --> #{values.size}\n\n" [keys, values] end |
.field_key(now = RailsPerformance::Utils.time) ⇒ Object
write to current slot time - date -minute
18 19 20 |
# File 'lib/rails_performance/utils.rb', line 18 def self.field_key(now = RailsPerformance::Utils.time) now.strftime("%H:%M") end |
.from_datetimei(datetimei) ⇒ Object
7 8 9 |
# File 'lib/rails_performance/utils.rb', line 7 def self.from_datetimei(datetimei) Time.at(datetimei, in: "+00:00") end |
.median(array) ⇒ Object
47 48 49 50 51 52 53 54 55 56 57 58 59 |
# File 'lib/rails_performance/utils.rb', line 47 def self.median(array) sorted = array.sort size = sorted.size center = size / 2 if size == 0 nil elsif size.even? (sorted[center - 1] + sorted[center]) / 2.0 else sorted[center] end end |
.percentile(values, percentile) ⇒ Object
61 62 63 64 65 66 67 68 69 70 |
# File 'lib/rails_performance/utils.rb', line 61 def self.percentile(values, percentile) return nil if values.empty? sorted = values.sort rank = (percentile.to_f / 100) * (sorted.size - 1) lower = sorted[rank.floor] upper = sorted[rank.ceil] lower + (upper - lower) * (rank - rank.floor) end |
.save_to_redis(key, value, expire = RailsPerformance.duration.to_i) ⇒ Object
34 35 36 37 38 39 40 41 |
# File 'lib/rails_performance/utils.rb', line 34 def self.save_to_redis(key, value, expire = RailsPerformance.duration.to_i) # TODO think here if add return # return if value.empty? RailsPerformance.log " [SAVE] key ---> #{key}\n" RailsPerformance.log " [SAVE] value ---> #{value.to_json}\n\n" RailsPerformance.redis.set(key, value.to_json, ex: expire.to_i) end |
.time ⇒ Object
3 4 5 |
# File 'lib/rails_performance/utils.rb', line 3 def self.time Time.now.utc end |