From 5546d6df5ddf6a4b9b5175b188ec9035469dd2a4 Mon Sep 17 00:00:00 2001 From: Emi Matchu Date: Mon, 16 Dec 2024 13:19:58 -0800 Subject: [PATCH] Use new `DTIRequests.load_many` helper in `SwfAsset.preload_manifests` --- app/models/swf_asset.rb | 24 +++--------------------- 1 file changed, 3 insertions(+), 21 deletions(-) diff --git a/app/models/swf_asset.rb b/app/models/swf_asset.rb index d2a6a9608..0f2ff7850 100644 --- a/app/models/swf_asset.rb +++ b/app/models/swf_asset.rb @@ -1,7 +1,4 @@ require 'addressable/template' -require 'async' -require 'async/barrier' -require 'async/semaphore' class SwfAsset < ApplicationRecord # We use the `type` column to mean something other than what Rails means! @@ -335,19 +332,9 @@ class SwfAsset < ApplicationRecord # Given a list of SWF assets, ensure all of their manifests are loaded, with # fast concurrent execution! def self.preload_manifests(swf_assets) - # Blocks all tasks beneath it. - barrier = Async::Barrier.new - - Sync do - # Only allow 10 manifests to be loaded at a time. - semaphore = Async::Semaphore.new(10, parent: barrier) - - # Load all the manifests in async tasks. This will load them 10 at a time - # rather than all at once (because of the semaphore), and the - # NeopetsMediaArchive will share a pool of persistent connections for - # them. - swf_assets.map do |swf_asset| - semaphore.async do + DTIRequests.load_many(max_at_once: 10) do |task| + swf_assets.each do |swf_asset| + task.async do begin # Don't save changes in this big async situation; we'll do it all # in one batch after, to avoid too much database concurrency! @@ -358,11 +345,6 @@ class SwfAsset < ApplicationRecord end end end - - # Wait until all tasks are done. - barrier.wait - ensure - barrier.stop # If something goes wrong, clean up all tasks. end SwfAsset.transaction do