勉強したことのメモ

Webエンジニア / プログラマが勉強したことのメモ。

さくらインターネットでCronからmysqldumpすると0バイトのファイルが生成される

   2024/01/16  MySQL データベース

さくらインターネットのレンタルサーバで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とかする際は絶対パスで書かないとダメみたいなことを覚えが記憶があるが、コマンドのパスについてもちゃんと書かないといけないらしい。

 - MySQL データベース

  関連記事

MySQLで検索した件数の取得

ページングとかで必要になる総件数について、 いつもググってしまっていたのでメモ。 ...

MySQLのintのカラムで2147483647の値

MySQLでintのカラムに数値を入れると「2147483647」という値になっ ...

MySQLでカラム内容によって条件分岐させたい場合の対応方法

MySQLでカラムの内容によって条件を分岐させたかった。またPHPで処理するので ...

MySQLのバックアップファイルを簡単に作成できるライブラリ「myphp-backup」の利用方法

MySQLのバックアップを取る際にadminerとかから手動で対応するのではなく ...

MySQLでストアドプロシージャ戻り値対応版であるストアドファンクションの設定と利用方法

先日MySQLのストアドプロシージャに関するメモを書いたが、今回はストアドファン ...