Nice mysqldump in the backup script.
This commit is contained in:
parent
f385eef851
commit
d517ce90fa
1 changed files with 26 additions and 23 deletions
|
|
@ -7,39 +7,42 @@ namespace :backup do
|
||||||
NUMBER_OF_DAYS = 3
|
NUMBER_OF_DAYS = 3
|
||||||
puts("event=backup status=start type=mysql")
|
puts("event=backup status=start type=mysql")
|
||||||
db = YAML::load(File.open(File.join(File.dirname(__FILE__), '..','..', 'config', 'database.yml')))
|
db = YAML::load(File.open(File.join(File.dirname(__FILE__), '..','..', 'config', 'database.yml')))
|
||||||
user = db['production']['user']
|
user = db['production']['username']
|
||||||
password = db['production']['password']
|
password = db['production']['password']
|
||||||
database = db['production']['database']
|
database = db['production']['database']
|
||||||
if AppConfig[:cloudfiles_username] && AppConfig[:cloudfiles_api_key] && !user.blank?
|
unless AppConfig[:cloudfiles_username] && AppConfig[:cloudfiles_api_key] && !user.blank?
|
||||||
puts "Logging into Cloud Files"
|
puts "Cloudfiles username needed" unless AppConfig[:cloudfiles_username]
|
||||||
|
puts "Cloudfiles api_key needed" unless AppConfig[:cloudfiles_api_key]
|
||||||
|
puts "DB auth data needed" if user.blank?
|
||||||
|
Process.exit
|
||||||
|
end
|
||||||
|
|
||||||
cf = CloudFiles::Connection.new(:username => AppConfig[:cloudfiles_username], :api_key => AppConfig[:cloudfiles_api_key])
|
puts "Logging into Cloud Files"
|
||||||
mysql_container = cf.container("MySQL Backup")
|
|
||||||
|
|
||||||
puts "Dumping Mysql"
|
cf = CloudFiles::Connection.new(:username => AppConfig[:cloudfiles_username], :api_key => AppConfig[:cloudfiles_api_key])
|
||||||
`mkdir -p /tmp/backup/mysql`
|
mysql_container = cf.container("MySQL Backup")
|
||||||
`mysqldump --user=#{user} --password=#{password} #{database} >> /tmp/backup/mysql/backup.txt `
|
|
||||||
|
|
||||||
tar_name = "mysql_#{Time.now.to_i}.tar"
|
puts "Dumping Mysql"
|
||||||
`tar cfPz /tmp/backup/#{tar_name} /tmp/backup/mysql`
|
`mkdir -p /tmp/backup/mysql`
|
||||||
|
`nice mysqldump --user=#{user} --password=#{password} #{database} >> /tmp/backup/mysql/backup.txt `
|
||||||
|
|
||||||
file = mysql_container.create_object(tar_name)
|
tar_name = "mysql_#{Time.now.to_i}.tar"
|
||||||
|
`tar cfPz /tmp/backup/#{tar_name} /tmp/backup/mysql`
|
||||||
|
|
||||||
if file.write File.open("/tmp/backup/" + tar_name)
|
file = mysql_container.create_object(tar_name)
|
||||||
puts("event=backup status=success type=mysql")
|
|
||||||
`rm /tmp/backup/#{tar_name}`
|
|
||||||
`rm -rf /tmp/backup/mysql/`
|
|
||||||
|
|
||||||
files = mysql_container.objects
|
if file.write File.open("/tmp/backup/" + tar_name)
|
||||||
files.sort!.pop(NUMBER_OF_DAYS * 24)
|
puts("event=backup status=success type=mysql")
|
||||||
files.each do |file|
|
`rm /tmp/backup/#{tar_name}`
|
||||||
mysql_container.delete_object(file)
|
`rm -rf /tmp/backup/mysql/`
|
||||||
end
|
|
||||||
else
|
files = mysql_container.objects
|
||||||
puts("event=backup status=failure type=mysql")
|
files.sort!.pop(NUMBER_OF_DAYS * 24)
|
||||||
|
files.each do |file|
|
||||||
|
mysql_container.delete_object(file)
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
puts "Cloudfiles username and api key needed"
|
puts("event=backup status=failure type=mysql")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue