さくらインターネットでCronからmysqldumpすると0バイトのファイルが生成される
2024/01/16
さくらインターネットのレンタルサーバでmysqldumpした結果をファイルとして出力するバックアップシステムをCronで実行したところ、0バイトのファイルが生成された。ブラウザから開くと正常にバックアップされたファイルが生成される。以下に対応方法をメモ。
楽な方法
ブラウザから開くと問題無いのでバックアップシステムをbackup.phpとすると、別途以下のようなリクエスト用ファイルを作成しこちらをCronで叩く方法。
$backup = file_get_contents('backup.php');
正常に動くんだけどURLがばれると第三者も実行できてしまうので微妙。
別の方法
<?php
//MySQL情報
$dbHost = "";
$dbUser = "";
$dbPass = "";
$dbName = "";
//保存先ディレクトリ
$filePath = "";
//ファイル名
$fileName = date('Ymd') . '.sql';
//ファイル保存
$command = "/usr/local/bin/mysqldump -h ${dbHost} -u ${dbUser} -p${dbPass} ${dbName} > ${filePath}${fileName}";
system($command);
上記ファイルをCronで実行する。
参考サイト
https://www.saluteweb.net/~oss_sakuramysql.html
所感
動かなかった原因は恐らくだけど/usr/local/bin/mysqldump部分っぽい。ここは元々はmysqldumpのみ書いていた。Cronで動かすファイルでincludeとかする際は絶対パスで書かないとダメみたいなことを覚えが記憶があるが、コマンドのパスについてもちゃんと書かないといけないらしい。
関連記事
-
-
WordPressでデータベース接続確立エラー発生時の対応方法
WordPressで「データベース接続確立エラー」というエラー表示がされた。大抵 ...
-
-
MySQLでIPアドレスを数値として入れると変な値になる場合の対処方法
MySQLでIPアドレスをINET_ATON関数を用いてINT型に変換し格納する ...
-
-
MySQLで開始~終了日時の間隔を計算し分に変換して出力する方法
MySQLで「開始日時」「終了日時」のdatetime型カラムがあり、開始から終 ...
-
-
mysqldumpが使えないレンタルサーバでMySQLのバックアップ
mysqldumpが使えないレンタルサーバで開発を行うことがあり、尚且つ他社に使 ...
-
-
異なるVPS間でMySQLの接続を行う方法
異なるVPS間でMySQL接続を行った際のメモ。 目次1 対応方法 ...