勉強したことのメモ

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のintのカラムで2147483647の値

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

MySQLでIPを整数値としてカラムに格納する

MySQLでIPを整数値としてカラムに格納しているケースがあった。今までIPが必 ...

MySQLでカラム数の異なるテーブルを結合する(UNION)

MySQLでカラム数の異なるテーブル同士をUNIONで結合させたかった。ただ、何 ...

SQLで同じ値を複数のレコードに対してUPDATE

やりたかった事は、複数のレコードに対して 同じ値に更新したいというもの。 $sq ...

MySQLでグループ化したものを条件で絞る(HAVING)

正規化したテーブルがあってその中には idとtagのカラムがある。 でtagの方 ...