gitlab-org--gitlab-foss/lib/tasks/gitlab/backup.rake

258 lines
8.2 KiB
Ruby
Raw Normal View History

require 'active_record/fixtures'
namespace :gitlab do
namespace :backup do
2012-09-26 07:18:10 -04:00
# Create backup of GitLab system
desc "GitLab | Create a backup of the GitLab system"
task create: :gitlab_environment do
2012-12-23 15:15:25 -05:00
warn_user_is_not_gitlab
Rake::Task["gitlab:backup:db:create"].invoke
Rake::Task["gitlab:backup:repo:create"].invoke
2013-04-10 08:41:47 -04:00
Rake::Task["gitlab:backup:uploads:create"].invoke
Rake::Task["gitlab:backup:builds:create"].invoke
Rake::Task["gitlab:backup:artifacts:create"].invoke
Rake::Task["gitlab:backup:pages:create"].invoke
2015-11-18 05:39:26 -05:00
Rake::Task["gitlab:backup:lfs:create"].invoke
2016-05-16 18:17:57 -04:00
Rake::Task["gitlab:backup:registry:create"].invoke
backup = Backup::Manager.new(progress)
backup.pack
backup.cleanup
backup.remove_old
puts "Warning: Your gitlab.rb and gitlab-secrets.json files contain sensitive data \n" \
"and are not included in this backup. You will need these files to restore a backup.\n" \
"Please back them up manually.".color(:red)
puts "Backup task is done."
end
2012-09-26 07:18:10 -04:00
# Restore backup of GitLab system
desc 'GitLab | Restore a previously created backup'
task restore: :gitlab_environment do
2012-12-23 15:15:25 -05:00
warn_user_is_not_gitlab
backup = Backup::Manager.new(progress)
backup.unpack
unless backup.skipped?('db')
begin
unless ENV['force'] == 'yes'
warning = <<-MSG.strip_heredoc
Before restoring the database, we will remove all existing
tables to avoid future upgrade problems. Be aware that if you have
custom tables in the GitLab database these tables and all data will be
removed.
MSG
puts warning.color(:red)
ask_to_continue
puts 'Removing all tables. Press `Ctrl-C` within 5 seconds to abort'.color(:yellow)
sleep(5)
end
# Drop all tables Load the schema to ensure we don't have any newer tables
# hanging out from a failed upgrade
puts_time 'Cleaning the database ... '.color(:blue)
Rake::Task['gitlab:db:drop_tables'].invoke
puts_time 'done'.color(:green)
Rake::Task['gitlab:backup:db:restore'].invoke
rescue Gitlab::TaskAbortedByUserError
puts "Quitting...".color(:red)
exit 1
end
end
Rake::Task['gitlab:backup:repo:restore'].invoke unless backup.skipped?('repositories')
Rake::Task['gitlab:backup:uploads:restore'].invoke unless backup.skipped?('uploads')
Rake::Task['gitlab:backup:builds:restore'].invoke unless backup.skipped?('builds')
Rake::Task['gitlab:backup:artifacts:restore'].invoke unless backup.skipped?('artifacts')
Rake::Task['gitlab:backup:pages:restore'].invoke unless backup.skipped?('pages')
Rake::Task['gitlab:backup:lfs:restore'].invoke unless backup.skipped?('lfs')
2016-05-16 18:17:57 -04:00
Rake::Task['gitlab:backup:registry:restore'].invoke unless backup.skipped?('registry')
Rake::Task['gitlab:shell:setup'].invoke
Rake::Task['cache:clear'].invoke
backup.cleanup
puts "Warning: Your gitlab.rb and gitlab-secrets.json files contain sensitive data \n" \
"and are not included in this backup. You will need to restore these files manually.".color(:red)
puts "Restore task is done."
end
namespace :repo do
task create: :gitlab_environment do
puts_time "Dumping repositories ...".color(:blue)
2015-03-27 09:18:59 -04:00
if ENV["SKIP"] && ENV["SKIP"].include?("repositories")
puts_time "[SKIPPED]".color(:cyan)
2015-03-27 09:18:59 -04:00
else
Backup::Repository.new(progress).dump
puts_time "done".color(:green)
2015-03-27 09:18:59 -04:00
end
end
task restore: :gitlab_environment do
puts_time "Restoring repositories ...".color(:blue)
Backup::Repository.new(progress).restore
puts_time "done".color(:green)
end
end
namespace :db do
task create: :gitlab_environment do
puts_time "Dumping database ... ".color(:blue)
2015-03-27 09:18:59 -04:00
if ENV["SKIP"] && ENV["SKIP"].include?("db")
puts_time "[SKIPPED]".color(:cyan)
2015-03-27 09:18:59 -04:00
else
Backup::Database.new(progress).dump
puts_time "done".color(:green)
2015-03-27 09:18:59 -04:00
end
end
task restore: :gitlab_environment do
puts_time "Restoring database ... ".color(:blue)
Backup::Database.new(progress).restore
puts_time "done".color(:green)
end
end
2013-04-10 08:41:47 -04:00
namespace :builds do
task create: :gitlab_environment do
puts_time "Dumping builds ... ".color(:blue)
if ENV["SKIP"] && ENV["SKIP"].include?("builds")
puts_time "[SKIPPED]".color(:cyan)
else
Backup::Builds.new(progress).dump
puts_time "done".color(:green)
end
end
task restore: :gitlab_environment do
puts_time "Restoring builds ... ".color(:blue)
Backup::Builds.new(progress).restore
puts_time "done".color(:green)
end
end
2013-04-10 08:41:47 -04:00
namespace :uploads do
task create: :gitlab_environment do
puts_time "Dumping uploads ... ".color(:blue)
2015-03-27 09:18:59 -04:00
if ENV["SKIP"] && ENV["SKIP"].include?("uploads")
puts_time "[SKIPPED]".color(:cyan)
2015-03-27 09:18:59 -04:00
else
Backup::Uploads.new(progress).dump
puts_time "done".color(:green)
2015-03-27 09:18:59 -04:00
end
2013-04-10 08:41:47 -04:00
end
task restore: :gitlab_environment do
puts_time "Restoring uploads ... ".color(:blue)
Backup::Uploads.new(progress).restore
puts_time "done".color(:green)
end
end
namespace :artifacts do
task create: :gitlab_environment do
puts_time "Dumping artifacts ... ".color(:blue)
if ENV["SKIP"] && ENV["SKIP"].include?("artifacts")
puts_time "[SKIPPED]".color(:cyan)
else
Backup::Artifacts.new(progress).dump
puts_time "done".color(:green)
end
end
task restore: :gitlab_environment do
puts_time "Restoring artifacts ... ".color(:blue)
Backup::Artifacts.new(progress).restore
puts_time "done".color(:green)
end
end
namespace :pages do
task create: :gitlab_environment do
puts_time "Dumping pages ... ".color(:blue)
if ENV["SKIP"] && ENV["SKIP"].include?("pages")
puts_time "[SKIPPED]".color(:cyan)
else
Backup::Pages.new(progress).dump
puts_time "done".color(:green)
end
end
task restore: :gitlab_environment do
puts_time "Restoring pages ... ".color(:blue)
Backup::Pages.new(progress).restore
puts_time "done".color(:green)
end
end
2015-11-18 05:39:26 -05:00
namespace :lfs do
task create: :gitlab_environment do
puts_time "Dumping lfs objects ... ".color(:blue)
2015-11-18 05:39:26 -05:00
if ENV["SKIP"] && ENV["SKIP"].include?("lfs")
puts_time "[SKIPPED]".color(:cyan)
2015-11-18 05:39:26 -05:00
else
Backup::Lfs.new(progress).dump
puts_time "done".color(:green)
2015-11-18 05:39:26 -05:00
end
end
task restore: :gitlab_environment do
puts_time "Restoring lfs objects ... ".color(:blue)
Backup::Lfs.new(progress).restore
puts_time "done".color(:green)
2015-11-18 05:39:26 -05:00
end
end
2016-05-16 18:17:57 -04:00
namespace :registry do
task create: :gitlab_environment do
puts_time "Dumping container registry images ... ".color(:blue)
2016-05-16 18:17:57 -04:00
2016-05-23 11:17:07 -04:00
if Gitlab.config.registry.enabled
if ENV["SKIP"] && ENV["SKIP"].include?("registry")
puts_time "[SKIPPED]".color(:cyan)
2016-05-23 11:17:07 -04:00
else
Backup::Registry.new(progress).dump
puts_time "done".color(:green)
2016-05-23 11:17:07 -04:00
end
2016-05-16 18:17:57 -04:00
else
puts_time "[DISABLED]".color(:cyan)
2016-05-16 18:17:57 -04:00
end
end
task restore: :gitlab_environment do
puts_time "Restoring container registry images ... ".color(:blue)
2016-05-23 11:17:07 -04:00
if Gitlab.config.registry.enabled
Backup::Registry.new(progress).restore
puts_time "done".color(:green)
2016-05-23 11:17:07 -04:00
else
puts_time "[DISABLED]".color(:cyan)
2016-05-23 11:17:07 -04:00
end
2016-05-16 18:17:57 -04:00
end
end
def puts_time(msg)
progress.puts "#{Time.now} -- #{msg}"
end
def progress
if ENV['CRON']
2014-11-20 09:54:39 -05:00
# We need an object we can say 'puts' and 'print' to; let's use a
# StringIO.
require 'stringio'
StringIO.new
else
$stdout
2013-04-10 08:41:47 -04:00
end
end
end # namespace end: backup
end # namespace end: gitlab