Commit e2305519 authored by Dmitriy Zaporozhets's avatar Dmitriy Zaporozhets

backup/restore uploads

parent 1d03fa2e
...@@ -10,6 +10,8 @@ v 5.1.0 ...@@ -10,6 +10,8 @@ v 5.1.0
- Backup/Restore refactored. Backup dump project wiki too now - Backup/Restore refactored. Backup dump project wiki too now
- Restyled Issues list. Show milestone version in issue row - Restyled Issues list. Show milestone version in issue row
- Restyled Merge Request list - Restyled Merge Request list
- Backup now dump/restore uploads
- Improved perfomance of dashboard
v 5.0.0 v 5.0.0
- Replaced gitolite with gitlab-shell - Replaced gitolite with gitlab-shell
......
module Backup
class Uploads
attr_reader :app_uploads_dir, :backup_uploads_dir, :backup_dir
def initialize
@app_uploads_dir = Rails.root.join('public', 'uploads')
@backup_dir = Gitlab.config.backup.path
@backup_uploads_dir = File.join(Gitlab.config.backup.path, 'uploads')
end
# Copy uploads from public/uploads to backup/uploads
def dump
FileUtils.mkdir_p(backup_uploads_dir)
FileUtils.cp_r(app_uploads_dir, backup_dir)
end
def restore
if File.exists?(app_uploads_dir)
FileUtils.mv(app_uploads_dir, Rails.root.join('public', "uploads.#{Time.now.to_i}"))
end
FileUtils.cp_r(backup_uploads_dir, app_uploads_dir)
end
end
end
...@@ -9,6 +9,7 @@ namespace :gitlab do ...@@ -9,6 +9,7 @@ namespace :gitlab do
Rake::Task["gitlab:backup:db:create"].invoke Rake::Task["gitlab:backup:db:create"].invoke
Rake::Task["gitlab:backup:repo:create"].invoke Rake::Task["gitlab:backup:repo:create"].invoke
Rake::Task["gitlab:backup:uploads:create"].invoke
Dir.chdir(Gitlab.config.backup.path) Dir.chdir(Gitlab.config.backup.path)
...@@ -25,7 +26,7 @@ namespace :gitlab do ...@@ -25,7 +26,7 @@ namespace :gitlab do
# create archive # create archive
print "Creating backup archive: #{Time.now.to_i}_gitlab_backup.tar ... " print "Creating backup archive: #{Time.now.to_i}_gitlab_backup.tar ... "
if Kernel.system("tar -cf #{Time.now.to_i}_gitlab_backup.tar repositories/ db/ backup_information.yml") if Kernel.system("tar -cf #{Time.now.to_i}_gitlab_backup.tar repositories/ db/ uploads/ backup_information.yml")
puts "done".green puts "done".green
else else
puts "failed".red puts "failed".red
...@@ -33,7 +34,7 @@ namespace :gitlab do ...@@ -33,7 +34,7 @@ namespace :gitlab do
# cleanup: remove tmp files # cleanup: remove tmp files
print "Deleting tmp directories ... " print "Deleting tmp directories ... "
if Kernel.system("rm -rf repositories/ db/ backup_information.yml") if Kernel.system("rm -rf repositories/ db/ uploads/ backup_information.yml")
puts "done".green puts "done".green
else else
puts "failed".red puts "failed".red
...@@ -99,10 +100,11 @@ namespace :gitlab do ...@@ -99,10 +100,11 @@ namespace :gitlab do
Rake::Task["gitlab:backup:db:restore"].invoke Rake::Task["gitlab:backup:db:restore"].invoke
Rake::Task["gitlab:backup:repo:restore"].invoke Rake::Task["gitlab:backup:repo:restore"].invoke
Rake::Task["gitlab:backup:uploads:restore"].invoke
# cleanup: remove tmp files # cleanup: remove tmp files
print "Deleting tmp directories ... " print "Deleting tmp directories ... "
if Kernel.system("rm -rf repositories/ db/ backup_information.yml") if Kernel.system("rm -rf repositories/ db/ uploads/ backup_information.yml")
puts "done".green puts "done".green
else else
puts "failed".red puts "failed".red
...@@ -136,5 +138,19 @@ namespace :gitlab do ...@@ -136,5 +138,19 @@ namespace :gitlab do
puts "done".green puts "done".green
end end
end end
namespace :uploads do
task :create => :environment do
puts "Dumping uploads ... ".blue
Backup::Uploads.new.dump
puts "done".green
end
task :restore => :environment do
puts "Restoring uploads ... ".blue
Backup::Uploads.new.restore
puts "done".green
end
end
end # namespace end: backup end # namespace end: backup
end # namespace end: gitlab end # namespace end: gitlab
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment