mirror of
https://github.com/discourse/discourse.git
synced 2025-03-26 07:05:40 +08:00
FIX: Optimize query and avoid bloating memory in Jobs::MigrateUploadScheme
.
This commit is contained in:
parent
df7f37f10a
commit
6d0e8821f8
@ -10,7 +10,10 @@ module Jobs
|
|||||||
# clean up failed uploads
|
# clean up failed uploads
|
||||||
Upload.where("created_at < ?", 1.hour.ago)
|
Upload.where("created_at < ?", 1.hour.ago)
|
||||||
.where("LENGTH(COALESCE(url, '')) = 0")
|
.where("LENGTH(COALESCE(url, '')) = 0")
|
||||||
.destroy_all
|
.find_each do |upload|
|
||||||
|
|
||||||
|
upload.destroy!
|
||||||
|
end
|
||||||
|
|
||||||
# migrate uploads to new scheme
|
# migrate uploads to new scheme
|
||||||
problems = Upload.migrate_to_new_scheme(50)
|
problems = Upload.migrate_to_new_scheme(50)
|
||||||
@ -21,9 +24,21 @@ module Jobs
|
|||||||
end
|
end
|
||||||
|
|
||||||
# clean up failed optimized images
|
# clean up failed optimized images
|
||||||
OptimizedImage.where("LENGTH(COALESCE(url, '')) = 0").destroy_all
|
OptimizedImage
|
||||||
|
.where("LENGTH(COALESCE(url, '')) = 0")
|
||||||
|
.find_each do |optimized_image|
|
||||||
|
|
||||||
|
optimized_image.destroy!
|
||||||
|
end
|
||||||
|
|
||||||
# Clean up orphan optimized images
|
# Clean up orphan optimized images
|
||||||
OptimizedImage.where("upload_id NOT IN (SELECT id FROM uploads)").destroy_all
|
OptimizedImage
|
||||||
|
.joins("LEFT JOIN uploads ON optimized_images.upload_id = uploads.id")
|
||||||
|
.where("uploads.id IS NULL")
|
||||||
|
.find_each do |optimized_image|
|
||||||
|
|
||||||
|
optimized_image.destroy!
|
||||||
|
end
|
||||||
|
|
||||||
# Clean up optimized images that needs to be regenerated
|
# Clean up optimized images that needs to be regenerated
|
||||||
OptimizedImage.joins(:upload)
|
OptimizedImage.joins(:upload)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user