質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
CentOS

CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

cron

cronは、Unix系OS上でデーモンプロセスとして動作する、スクリプトの自動実行が可能なジョブスケジューラです。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

sh

shは、UNIX系OSのシェル操作の1つであり、最も基本的なシェルのことです。

Q&A

解決済

3回答

5778閲覧

crontabで実行したmysqldumpの結果が0Byteになる

退会済みユーザー

退会済みユーザー

総合スコア0

CentOS

CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

cron

cronは、Unix系OS上でデーモンプロセスとして動作する、スクリプトの自動実行が可能なジョブスケジューラです。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

sh

shは、UNIX系OSのシェル操作の1つであり、最も基本的なシェルのことです。

0グッド

0クリップ

投稿2016/09/08 00:33

お世話になっております。
今回はsh、crontabについてです。よろしくお願いいたします。

運営しているサービスのバックアップを取ろうと思い、crontabを使って深夜に
バックアップを取ることにしたのですが、mysqldumpの結果が0Byteになります。

/backup/backupdb.shを作成し、以下のように記述しました。
パーミッションは755です。

sh

1#!/bin/sh 2 3# バックアップの保存期間(日) 4period=7 5 6# バックアップ保存用ディレクトリ 7dirpath='/backup/db' 8 9filename=`date +%y%m%d` 10 11# 本来はdatebaseにデータベース名、userにユーザー名、passwordにパスワードが入っています。 12mysqldump datebase --single-transaction --host=127.0.0.1 --user=user --password=password > $dirpath/$filename.sql 13 14chmod 700 $dirpath/$filename.sql 15 16oldfile=`date --date "$period days ago" +%y%m%d` 17 18rm -f $dirpath/$oldfile.sql

これをコンソールで実行すると、/backup/db/160905.sqlのような形で保存されるのを確認しました。
内容も問題ありませんでしたので、これをcrontabに登録しました。

cron

100 1 * * * /backup/backupdb.sh

このように設定すると、午前1時にファイルは作成されますが中身が空になってしまいました。
何か記述がおかしな所はありますでしょうか?

ご回答よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

解決したようですが、アドバイスとしては、Cron Daemon(root) から来るエラーメールを見ると言うことでしょう。なんらかの理由でrootからのメールが読めない環境なら、

00 1 * * * /backup/backupdb.sh >/tmp/cron-backup.stdout 2>/tmp/cron-backup.stderr

としておけば、エラーメッセージが後で読めます。

「cronからだとうまく動かない」のほとんどは環境変数の問題です。

投稿2016/09/08 01:19

編集2016/09/08 04:51
otn

総合スコア84421

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2016/09/08 01:21

ご回答ありがとうございます。 次回からエラーメッセージを吐くようにします!
guest

0

ベストアンサー

backupdb.shに、mysqldumpをフルパスで記述するか環境変数PATHを設定してください。
cronはログインユーザーではないのでログインユーザーとPATHの設定が異なります。

投稿2016/09/08 00:38

imutakaoru

総合スコア356

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2016/09/08 00:43

ご回答ありがとうございます。 今書き換えてみました。
退会済みユーザー

退会済みユーザー

2016/09/08 01:02

無事にdumpできていました! 回答の早かったimutakaoruさんをBAにしましたが、maisumakunさんもありがとうございました!
guest

0

cronから実行すると、対話的なコンソールと$PATHが違っていて、必要なコマンドが見つからないことがあります(特に、mysqldumpのような、Unix標準でないコマンドの場合)。

crontabが動かないのは$PATHのせいかもしれない

投稿2016/09/08 00:39

maisumakun

総合スコア145121

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2016/09/08 00:43

ご回答ありがとうございます。 $PATHの設定を行ってみました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問