Merge branch 'git-archive-improvements-2' into 'master'
Clear archive cache asynchronously See merge request !1651
This commit is contained in:
commit
9769a8704c
6 changed files with 20 additions and 53 deletions
|
@ -79,6 +79,7 @@ v 8.1.0 (unreleased)
|
||||||
- Only render 404 page from /public
|
- Only render 404 page from /public
|
||||||
- Hide passwords from services API (Alex Lossent)
|
- Hide passwords from services API (Alex Lossent)
|
||||||
- Fix: Images cannot show when projects' path was changed
|
- Fix: Images cannot show when projects' path was changed
|
||||||
|
- Let gitlab-git-http-server generate and serve 'git archive' downloads
|
||||||
- Optimize query when filtering on issuables (Zeger-Jan van de Weg)
|
- Optimize query when filtering on issuables (Zeger-Jan van de Weg)
|
||||||
- Fix padding of outdated discussion item.
|
- Fix padding of outdated discussion item.
|
||||||
|
|
||||||
|
|
|
@ -8,6 +8,14 @@ class Repository
|
||||||
|
|
||||||
attr_accessor :raw_repository, :path_with_namespace, :project
|
attr_accessor :raw_repository, :path_with_namespace, :project
|
||||||
|
|
||||||
|
def self.clean_old_archives
|
||||||
|
repository_downloads_path = Gitlab.config.gitlab.repository_downloads_path
|
||||||
|
|
||||||
|
return unless File.directory?(repository_downloads_path)
|
||||||
|
|
||||||
|
Gitlab::Popen.popen(%W(find #{repository_downloads_path} -not -path #{repository_downloads_path} -mmin +120 -delete))
|
||||||
|
end
|
||||||
|
|
||||||
def initialize(path_with_namespace, default_branch = nil, project = nil)
|
def initialize(path_with_namespace, default_branch = nil, project = nil)
|
||||||
@path_with_namespace = path_with_namespace
|
@path_with_namespace = path_with_namespace
|
||||||
@project = project
|
@project = project
|
||||||
|
@ -269,14 +277,6 @@ class Repository
|
||||||
end
|
end
|
||||||
|
|
||||||
# Remove archives older than 2 hours
|
# Remove archives older than 2 hours
|
||||||
def clean_old_archives
|
|
||||||
repository_downloads_path = Gitlab.config.gitlab.repository_downloads_path
|
|
||||||
|
|
||||||
return unless File.directory?(repository_downloads_path)
|
|
||||||
|
|
||||||
Gitlab::Popen.popen(%W(find #{repository_downloads_path} -not -path #{repository_downloads_path} -mmin +120 -delete))
|
|
||||||
end
|
|
||||||
|
|
||||||
def branches_sorted_by(value)
|
def branches_sorted_by(value)
|
||||||
case value
|
case value
|
||||||
when 'recently_updated'
|
when 'recently_updated'
|
||||||
|
|
|
@ -7,7 +7,7 @@ class ArchiveRepositoryService
|
||||||
end
|
end
|
||||||
|
|
||||||
def execute(options = {})
|
def execute(options = {})
|
||||||
project.repository.clean_old_archives
|
RepositoryArchiveCacheWorker.perform_async
|
||||||
|
|
||||||
metadata = project.repository.archive_metadata(ref, storage_path, format)
|
metadata = project.repository.archive_metadata(ref, storage_path, format)
|
||||||
raise "Repository or ref not found" if metadata.empty?
|
raise "Repository or ref not found" if metadata.empty?
|
||||||
|
|
9
app/workers/repository_archive_cache_worker.rb
Normal file
9
app/workers/repository_archive_cache_worker.rb
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
class RepositoryArchiveCacheWorker
|
||||||
|
include Sidekiq::Worker
|
||||||
|
|
||||||
|
sidekiq_options queue: :default
|
||||||
|
|
||||||
|
def perform
|
||||||
|
Repository.clean_old_archives
|
||||||
|
end
|
||||||
|
end
|
|
@ -1,43 +0,0 @@
|
||||||
class RepositoryArchiveWorker
|
|
||||||
include Sidekiq::Worker
|
|
||||||
|
|
||||||
sidekiq_options queue: :archive_repo
|
|
||||||
|
|
||||||
attr_accessor :project, :ref, :format
|
|
||||||
|
|
||||||
def perform(project_id, ref, format)
|
|
||||||
@project = Project.find(project_id)
|
|
||||||
@ref, @format = ref, format.downcase
|
|
||||||
|
|
||||||
repository = project.repository
|
|
||||||
|
|
||||||
repository.clean_old_archives
|
|
||||||
|
|
||||||
return unless file_path
|
|
||||||
return if archived? || archiving?
|
|
||||||
|
|
||||||
repository.archive_repo(ref, storage_path, format)
|
|
||||||
end
|
|
||||||
|
|
||||||
private
|
|
||||||
|
|
||||||
def storage_path
|
|
||||||
Gitlab.config.gitlab.repository_downloads_path
|
|
||||||
end
|
|
||||||
|
|
||||||
def file_path
|
|
||||||
@file_path ||= project.repository.archive_file_path(ref, storage_path, format)
|
|
||||||
end
|
|
||||||
|
|
||||||
def pid_file_path
|
|
||||||
@pid_file_path ||= project.repository.archive_pid_file_path(ref, storage_path, format)
|
|
||||||
end
|
|
||||||
|
|
||||||
def archived?
|
|
||||||
File.exist?(file_path)
|
|
||||||
end
|
|
||||||
|
|
||||||
def archiving?
|
|
||||||
File.exist?(pid_file_path)
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -6,7 +6,7 @@ describe ArchiveRepositoryService do
|
||||||
|
|
||||||
describe "#execute" do
|
describe "#execute" do
|
||||||
it "cleans old archives" do
|
it "cleans old archives" do
|
||||||
expect(project.repository).to receive(:clean_old_archives)
|
expect(RepositoryArchiveCacheWorker).to receive(:perform_async)
|
||||||
|
|
||||||
subject.execute(timeout: 0.0)
|
subject.execute(timeout: 0.0)
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue