データベース内のデータをバックアップするための rake タスクはありますか?
-
09-06-2019 - |
質問
データベース内のデータをバックアップするための rake タスクはありますか?
スキーマはすでにバックアップされていますが、データのバックアップを作成したいと考えています。これは小さな MySQL データベースです。
解決
以下のスクリプトは、以下から抜粋した簡略版です。 アイキャップ, 、特にから このファイル.
set :dbuser "user"
set :dbhost "host"
set :database "db"
namespace :db do
desc "Get the database password from user"
task :get_password do
set(:dbpass) do
Capistrano::CLI.ui.ask "Enter mysql password: "
end
end
task :backup_name, :only => { :primary => true } do
now = Time.now
run "mkdir -p #{shared_path}/db_backups"
backup_time = [now.year,now.month,now.day,now.hour,now.min,now.sec].join('-')
set :backup_file, "#{shared_path}/db_backups/#{database}-snapshot-#{backup_time}.sql"
end
desc "Dump database to backup file"
task :dump, :roles => :db, :only => {:primary => true} do
backup_name
run "mysqldump --add-drop-table -u #{dbuser} -h #{dbhost} -p#{dbpass} #{database} | bzip2 -c > #{backup_file}.bz2"
end
end
編集:そうですね、キャピストラーノ タスクではなくレイク タスクを探しているという点を見逃していたようですが、申し訳ありませんが、手元にレイク タスクがありません。
他のヒント
MySQL データベースをバックアップするための rake タスクはありませんが、WordPress DB に対してそれを行うためのスクリプトを Ruby で書きました。
filename = 'wp-config.php'
def get_db_info(file)
username = nil
password = nil
db_name = nil
file.each { |line|
if line =~ /'DB_(USER|PASSWORD|NAME)', '([[:alnum:]]*)'/
if $1 == "USER"
username = $2
elsif $1 == "PASSWORD"
password = $2
elsif $1 == "NAME"
db_name = $2
end
end
}
if username.nil? || password.nil? || db_name.nil?
puts "[backup_db][bad] couldn't get all needed info"
exit
end
return username, password, db_name
end
begin
config_file = open("#{filename}")
rescue Errno::ENOENT
puts "[backup_db][bad] File '#{filename}' didn't exist"
exit
else
puts "[backup_db][good] File '#{filename}' existed"
end
username, password, db_name = get_db_info(config_file)
sql_dump_info = `mysqldump --user=#{username} --password=#{password} #{dbname}`
puts sql_dump_info
これを利用して、ユーザー名/パスワード/データベース名を入力して軽度のプルーニングを行って、起動して機能させることができるはずです。これを毎日実行するために crontab に入れています。これはすでに Ruby コードなので、これを rake タスクとして実行するように変換するのはそれほど手間ではありません (良い学習演習になるかもしれません)。
様子を教えてください!
がある ある 少し ソリューション すでにGoogle上にあります。あなたは orm として activerecord を使用していると思いますか?
Rails を実行している場合は、 uby\lib uby\gems\1.8\gems ails-2.0.2-\lib asks\database.rake で activerecord に使用される Rakefile を確認できます。これにより、汎用 Rakefile を拡張する方法について多くの情報が得られました。
キャピストラーノのタスクを実行することもできます。 セルズディー を提供し、それを rake ファイルに追加します。次に、データベースへの activerecord 接続を使用するように少し変更します。
「mysql タスク」と呼ばれるプラグインがありますので、グーグルで検索してください。これはただの rakefile です -- とても使いやすいと思います。
人々がまだソリューションを探している場合に備えて、現在、ar_fixtures プラグインを使用してデータベースとソリューションの一部をバックアップしています。
熊手を提供します db:fixtures:dump
タスク。これにより、YAML 内のすべてがテスト/フィクスチャに吐き出されるため、次を使用して再度ロードできます。 db:fixtures:load
.
これを使用して、すべての機能を本番環境にプッシュする前にバックアップします。これは、sqlite3 から Postgres に移行するときにも使用しました。これは、SQL 言語間の非互換性がほとんどの場合隠されているため、非常に便利です。
頑張ってください、D
データベースにストアド プロシージャがある場合は、それらもバックアップされるように、必ず「--routines」パラメータを mysqldump に追加してください。
mysql をバックアップし、バックアップを周期的にローテーションするための rake タスクがあります。
#encoding: utf-8
#require 'fileutils'
namespace :mls do
desc 'Create of realty_dev database backup'
task :backup => :environment do
backup_max_records = 4
datestamp = Time.now.strftime("%Y-%m-%d_%H-%M")
backup_dir = File.join(Rails.root, ENV['DIR'] || 'backups', 'db')
backup_file_name = "#{datestamp}_#{Rails.env}_dump.sql"
backup_file_path = File.join(backup_dir, "#{backup_file_name}")
FileUtils.mkdir_p(backup_dir)
#database processing
db_config = ActiveRecord::Base.configurations[Rails.env]
system "mysqldump -u#{db_config['username']} -p#{db_config['password']} -i -c -q #{db_config['database']} > #{backup_file_path}"
raise 'Unable to make DB backup!' if ($?.to_i > 0)
# sql dump file compression
system "gzip -9 #{backup_file_path}"
# backup rotation
dir = Dir.new(backup_dir)
backup_all_records = dir.entries.sort[2..-1].reverse
puts "Created backup: #{backup_file_name}.gz"
#redundant records
backup_del_records = backup_all_records[backup_max_records..-1] || []
# backup deleting too old records
for backup_del_record in backup_del_records
FileUtils.rm_rf(File.join(backup_dir, backup_del_record))
end
puts "Deleted #{backup_del_records.length} old backups, #{backup_all_records.length - backup_del_records.length} backups available"
puts "Backup passed"
end
end
=begin
run by this command: " rake db:backup RAILS_ENV="development" "
=end