Reduce number of items in feeds, optimize regeneration worker slightly,
make regeneration worker unique, (only schedule/execute once at a time)
This commit is contained in:
		
							
								
								
									
										2
									
								
								Gemfile
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								Gemfile
									
									
									
									
									
								
							| @@ -46,6 +46,8 @@ gem 'will_paginate' | ||||
| gem 'rack-attack' | ||||
| gem 'rack-cors', require: 'rack/cors' | ||||
| gem 'sidekiq' | ||||
| gem 'sidekiq-unique-jobs' | ||||
| gem 'sidekiq-merger' | ||||
| gem 'rails-settings-cached' | ||||
| gem 'simple-navigation' | ||||
| gem 'statsd-instrument' | ||||
|   | ||||
| @@ -387,6 +387,13 @@ GEM | ||||
|       connection_pool (~> 2.2, >= 2.2.0) | ||||
|       rack-protection (>= 1.5.0) | ||||
|       redis (~> 3.2, >= 3.2.1) | ||||
|     sidekiq-merger (0.0.11) | ||||
|       activesupport (>= 3.2, < 6) | ||||
|       concurrent-ruby (~> 1.0) | ||||
|       sidekiq (>= 3.4, < 5) | ||||
|     sidekiq-unique-jobs (4.0.18) | ||||
|       sidekiq (>= 2.6) | ||||
|       thor | ||||
|     simple-navigation (4.0.3) | ||||
|       activesupport (>= 2.3.2) | ||||
|     simple_form (3.2.1) | ||||
| @@ -510,6 +517,8 @@ DEPENDENCIES | ||||
|   sass-rails (~> 5.0) | ||||
|   sdoc (~> 0.4.0) | ||||
|   sidekiq | ||||
|   sidekiq-merger | ||||
|   sidekiq-unique-jobs | ||||
|   simple-navigation | ||||
|   simple_form | ||||
|   simplecov | ||||
|   | ||||
| @@ -5,7 +5,7 @@ require 'singleton' | ||||
| class FeedManager | ||||
|   include Singleton | ||||
|  | ||||
|   MAX_ITEMS = 800 | ||||
|   MAX_ITEMS = 400 | ||||
|  | ||||
|   def key(type, id) | ||||
|     "feed:#{type}:#{id}" | ||||
| @@ -50,9 +50,9 @@ class FeedManager | ||||
|  | ||||
|   def merge_into_timeline(from_account, into_account) | ||||
|     timeline_key = key(:home, into_account.id) | ||||
|     query        = from_account.statuses.limit(MAX_ITEMS) | ||||
|     query        = from_account.statuses.limit(FeedManager::MAX_ITEMS / 4) | ||||
|  | ||||
|     if redis.zcard(timeline_key) >= FeedManager::MAX_ITEMS | ||||
|     if redis.zcard(timeline_key) >= FeedManager::MAX_ITEMS / 4 | ||||
|       oldest_home_score = redis.zrange(timeline_key, 0, 0, with_scores: true)&.first&.last&.to_i || 0 | ||||
|       query = query.where('id > ?', oldest_home_score) | ||||
|     end | ||||
|   | ||||
| @@ -5,9 +5,11 @@ class PrecomputeFeedService < BaseService | ||||
|   # @param [Symbol] type :home or :mentions | ||||
|   # @param [Account] account | ||||
|   def call(_, account) | ||||
|     Status.as_home_timeline(account).limit(FeedManager::MAX_ITEMS).each do |status| | ||||
|       next if status.direct_visibility? || FeedManager.instance.filter?(:home, status, account) | ||||
|       redis.zadd(FeedManager.instance.key(:home, account.id), status.id, status.reblog? ? status.reblog_of_id : status.id) | ||||
|     redis.pipelined do | ||||
|       Status.as_home_timeline(account).limit(FeedManager::MAX_ITEMS / 4).each do |status| | ||||
|         next if status.direct_visibility? || FeedManager.instance.filter?(:home, status, account) | ||||
|         redis.zadd(FeedManager.instance.key(:home, account.id), status.id, status.reblog? ? status.reblog_of_id : status.id) | ||||
|       end | ||||
|     end | ||||
|   end | ||||
|  | ||||
|   | ||||
| @@ -3,7 +3,7 @@ | ||||
| class RegenerationWorker | ||||
|   include Sidekiq::Worker | ||||
|  | ||||
|   sidekiq_options queue: 'pull', backtrace: true | ||||
|   sidekiq_options queue: 'pull', backtrace: true, unique: :until_executed | ||||
|  | ||||
|   def perform(account_id, _ = :home) | ||||
|     PrecomputeFeedService.new.call(:home, Account.find(account_id)) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user