Commit 02e859a23470d799a77963503687789d4a410a0c
1 parent
af5faaf0
Exists in
master
and in
4 other branches
move backup logic to lib. Fixed removing outdated backups
Showing
3 changed files
with
114 additions
and
95 deletions
Show diff stats
.gitignore
| ... | ... | @@ -0,0 +1,106 @@ |
| 1 | +module Backup | |
| 2 | + class Manager | |
| 3 | + def pack | |
| 4 | + # saving additional informations | |
| 5 | + s = {} | |
| 6 | + s[:db_version] = "#{ActiveRecord::Migrator.current_version}" | |
| 7 | + s[:backup_created_at] = Time.now | |
| 8 | + s[:gitlab_version] = %x{git rev-parse HEAD}.gsub(/\n/,"") | |
| 9 | + s[:tar_version] = %x{tar --version | head -1}.gsub(/\n/,"") | |
| 10 | + | |
| 11 | + Dir.chdir(Gitlab.config.backup.path) | |
| 12 | + | |
| 13 | + File.open("#{Gitlab.config.backup.path}/backup_information.yml", "w+") do |file| | |
| 14 | + file << s.to_yaml.gsub(/^---\n/,'') | |
| 15 | + end | |
| 16 | + | |
| 17 | + # create archive | |
| 18 | + print "Creating backup archive: #{s[:backup_created_at].to_i}_gitlab_backup.tar ... " | |
| 19 | + if Kernel.system("tar -cf #{s[:backup_created_at].to_i}_gitlab_backup.tar repositories/ db/ uploads/ backup_information.yml") | |
| 20 | + puts "done".green | |
| 21 | + else | |
| 22 | + puts "failed".red | |
| 23 | + end | |
| 24 | + end | |
| 25 | + | |
| 26 | + def cleanup | |
| 27 | + print "Deleting tmp directories ... " | |
| 28 | + if Kernel.system("rm -rf repositories/ db/ uploads/ backup_information.yml") | |
| 29 | + puts "done".green | |
| 30 | + else | |
| 31 | + puts "failed".red | |
| 32 | + end | |
| 33 | + end | |
| 34 | + | |
| 35 | + def remove_old | |
| 36 | + # delete backups | |
| 37 | + print "Deleting old backups ... " | |
| 38 | + keep_time = Gitlab.config.backup.keep_time.to_i | |
| 39 | + path = Gitlab.config.backup.path | |
| 40 | + | |
| 41 | + if keep_time > 0 | |
| 42 | + removed = 0 | |
| 43 | + file_list = Dir.glob(Rails.root.join(path, "*_gitlab_backup.tar")) | |
| 44 | + file_list.map! { |f| $1.to_i if f =~ /(\d+)_gitlab_backup.tar/ } | |
| 45 | + file_list.sort.each do |timestamp| | |
| 46 | + if Time.at(timestamp) < (Time.now - keep_time) | |
| 47 | + if system("rm #{timestamp}_gitlab_backup.tar") | |
| 48 | + removed += 1 | |
| 49 | + end | |
| 50 | + end | |
| 51 | + end | |
| 52 | + puts "done. (#{removed} removed)".green | |
| 53 | + else | |
| 54 | + puts "skipping".yellow | |
| 55 | + end | |
| 56 | + end | |
| 57 | + | |
| 58 | + def unpack | |
| 59 | + Dir.chdir(Gitlab.config.backup.path) | |
| 60 | + | |
| 61 | + # check for existing backups in the backup dir | |
| 62 | + file_list = Dir.glob("*_gitlab_backup.tar").each.map { |f| f.split(/_/).first.to_i } | |
| 63 | + puts "no backups found" if file_list.count == 0 | |
| 64 | + if file_list.count > 1 && ENV["BACKUP"].nil? | |
| 65 | + puts "Found more than one backup, please specify which one you want to restore:" | |
| 66 | + puts "rake gitlab:backup:restore BACKUP=timestamp_of_backup" | |
| 67 | + exit 1 | |
| 68 | + end | |
| 69 | + | |
| 70 | + tar_file = ENV["BACKUP"].nil? ? File.join("#{file_list.first}_gitlab_backup.tar") : File.join(ENV["BACKUP"] + "_gitlab_backup.tar") | |
| 71 | + | |
| 72 | + unless File.exists?(tar_file) | |
| 73 | + puts "The specified backup doesn't exist!" | |
| 74 | + exit 1 | |
| 75 | + end | |
| 76 | + | |
| 77 | + print "Unpacking backup ... " | |
| 78 | + unless Kernel.system("tar -xf #{tar_file}") | |
| 79 | + puts "failed".red | |
| 80 | + exit 1 | |
| 81 | + else | |
| 82 | + puts "done".green | |
| 83 | + end | |
| 84 | + | |
| 85 | + settings = YAML.load_file("backup_information.yml") | |
| 86 | + ENV["VERSION"] = "#{settings[:db_version]}" if settings[:db_version].to_i > 0 | |
| 87 | + | |
| 88 | + # backups directory is not always sub of Rails root and able to execute the git rev-parse below | |
| 89 | + begin | |
| 90 | + Dir.chdir(Rails.root) | |
| 91 | + | |
| 92 | + # restoring mismatching backups can lead to unexpected problems | |
| 93 | + if settings[:gitlab_version] != %x{git rev-parse HEAD}.gsub(/\n/, "") | |
| 94 | + puts "GitLab version mismatch:".red | |
| 95 | + puts " Your current HEAD differs from the HEAD in the backup!".red | |
| 96 | + puts " Please switch to the following revision and try again:".red | |
| 97 | + puts " revision: #{settings[:gitlab_version]}".red | |
| 98 | + exit 1 | |
| 99 | + end | |
| 100 | + ensure | |
| 101 | + # chdir back to original intended dir | |
| 102 | + Dir.chdir(Gitlab.config.backup.path) | |
| 103 | + end | |
| 104 | + end | |
| 105 | + end | |
| 106 | +end | ... | ... |
lib/tasks/gitlab/backup.rake
| ... | ... | @@ -11,49 +11,10 @@ namespace :gitlab do |
| 11 | 11 | Rake::Task["gitlab:backup:repo:create"].invoke |
| 12 | 12 | Rake::Task["gitlab:backup:uploads:create"].invoke |
| 13 | 13 | |
| 14 | - | |
| 15 | - # saving additional informations | |
| 16 | - s = {} | |
| 17 | - s[:db_version] = "#{ActiveRecord::Migrator.current_version}" | |
| 18 | - s[:backup_created_at] = Time.now | |
| 19 | - s[:gitlab_version] = %x{git rev-parse HEAD}.gsub(/\n/,"") | |
| 20 | - s[:tar_version] = %x{tar --version | head -1}.gsub(/\n/,"") | |
| 21 | - | |
| 22 | - Dir.chdir(Gitlab.config.backup.path) | |
| 23 | - | |
| 24 | - File.open("#{Gitlab.config.backup.path}/backup_information.yml", "w+") do |file| | |
| 25 | - file << s.to_yaml.gsub(/^---\n/,'') | |
| 26 | - end | |
| 27 | - | |
| 28 | - # create archive | |
| 29 | - print "Creating backup archive: #{s[:backup_created_at].to_i}_gitlab_backup.tar ... " | |
| 30 | - if Kernel.system("tar -cf #{s[:backup_created_at].to_i}_gitlab_backup.tar repositories/ db/ uploads/ backup_information.yml") | |
| 31 | - puts "done".green | |
| 32 | - else | |
| 33 | - puts "failed".red | |
| 34 | - end | |
| 35 | - | |
| 36 | - # cleanup: remove tmp files | |
| 37 | - print "Deleting tmp directories ... " | |
| 38 | - if Kernel.system("rm -rf repositories/ db/ uploads/ backup_information.yml") | |
| 39 | - puts "done".green | |
| 40 | - else | |
| 41 | - puts "failed".red | |
| 42 | - end | |
| 43 | - | |
| 44 | - # delete backups | |
| 45 | - print "Deleting old backups ... " | |
| 46 | - if Gitlab.config.backup.keep_time > 0 | |
| 47 | - file_list = Dir.glob("*_gitlab_backup.tar").map { |f| f.split(/_/).first.to_i } | |
| 48 | - file_list.sort.each do |timestamp| | |
| 49 | - if Time.at(timestamp) < (Time.now - Gitlab.config.backup.keep_time) | |
| 50 | - %x{rm #{timestamp}_gitlab_backup.tar} | |
| 51 | - end | |
| 52 | - end | |
| 53 | - puts "done".green | |
| 54 | - else | |
| 55 | - puts "skipping".yellow | |
| 56 | - end | |
| 14 | + backup = Backup::Manager.new | |
| 15 | + backup.pack | |
| 16 | + backup.cleanup | |
| 17 | + backup.remove_old | |
| 57 | 18 | end |
| 58 | 19 | |
| 59 | 20 | # Restore backup of GitLab system |
| ... | ... | @@ -61,64 +22,15 @@ namespace :gitlab do |
| 61 | 22 | task restore: :environment do |
| 62 | 23 | warn_user_is_not_gitlab |
| 63 | 24 | |
| 64 | - Dir.chdir(Gitlab.config.backup.path) | |
| 65 | - | |
| 66 | - # check for existing backups in the backup dir | |
| 67 | - file_list = Dir.glob("*_gitlab_backup.tar").each.map { |f| f.split(/_/).first.to_i } | |
| 68 | - puts "no backups found" if file_list.count == 0 | |
| 69 | - if file_list.count > 1 && ENV["BACKUP"].nil? | |
| 70 | - puts "Found more than one backup, please specify which one you want to restore:" | |
| 71 | - puts "rake gitlab:backup:restore BACKUP=timestamp_of_backup" | |
| 72 | - exit 1 | |
| 73 | - end | |
| 74 | - | |
| 75 | - tar_file = ENV["BACKUP"].nil? ? File.join("#{file_list.first}_gitlab_backup.tar") : File.join(ENV["BACKUP"] + "_gitlab_backup.tar") | |
| 76 | - | |
| 77 | - unless File.exists?(tar_file) | |
| 78 | - puts "The specified backup doesn't exist!" | |
| 79 | - exit 1 | |
| 80 | - end | |
| 81 | - | |
| 82 | - print "Unpacking backup ... " | |
| 83 | - unless Kernel.system("tar -xf #{tar_file}") | |
| 84 | - puts "failed".red | |
| 85 | - exit 1 | |
| 86 | - else | |
| 87 | - puts "done".green | |
| 88 | - end | |
| 89 | - | |
| 90 | - settings = YAML.load_file("backup_information.yml") | |
| 91 | - ENV["VERSION"] = "#{settings[:db_version]}" if settings[:db_version].to_i > 0 | |
| 92 | - | |
| 93 | - # backups directory is not always sub of Rails root and able to execute the git rev-parse below | |
| 94 | - begin | |
| 95 | - Dir.chdir(Rails.root) | |
| 96 | - | |
| 97 | - # restoring mismatching backups can lead to unexpected problems | |
| 98 | - if settings[:gitlab_version] != %x{git rev-parse HEAD}.gsub(/\n/, "") | |
| 99 | - puts "GitLab version mismatch:".red | |
| 100 | - puts " Your current HEAD differs from the HEAD in the backup!".red | |
| 101 | - puts " Please switch to the following revision and try again:".red | |
| 102 | - puts " revision: #{settings[:gitlab_version]}".red | |
| 103 | - exit 1 | |
| 104 | - end | |
| 105 | - ensure | |
| 106 | - # chdir back to original intended dir | |
| 107 | - Dir.chdir(Gitlab.config.backup.path) | |
| 108 | - end | |
| 25 | + backup = Backup::Manager.new | |
| 26 | + backup.unpack | |
| 109 | 27 | |
| 110 | 28 | Rake::Task["gitlab:backup:db:restore"].invoke |
| 111 | 29 | Rake::Task["gitlab:backup:repo:restore"].invoke |
| 112 | 30 | Rake::Task["gitlab:backup:uploads:restore"].invoke |
| 113 | 31 | Rake::Task["gitlab:shell:setup"].invoke |
| 114 | 32 | |
| 115 | - # cleanup: remove tmp files | |
| 116 | - print "Deleting tmp directories ... " | |
| 117 | - if Kernel.system("rm -rf repositories/ db/ uploads/ backup_information.yml") | |
| 118 | - puts "done".green | |
| 119 | - else | |
| 120 | - puts "failed".red | |
| 121 | - end | |
| 33 | + backup.cleanup | |
| 122 | 34 | end |
| 123 | 35 | |
| 124 | 36 | namespace :repo do | ... | ... |