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

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

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

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

cron

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

シェル

シェル(shell)はUnix や Linux 系のOSで使用されるコマンドインタプリタを指します。

Q&A

解決済

2回答

3028閲覧

pingの状況によってサービスを停止させるシェルスクリプトについて

ssall

総合スコア30

CentOS

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

cron

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

シェル

シェル(shell)はUnix や Linux 系のOSで使用されるコマンドインタプリタを指します。

1グッド

1クリップ

投稿2017/03/28 02:02

■ご質問概要
下記のシェルスクリプトをcrontab -eで1分おきに実行するようにしたのですが、実際にコマンド実行するとうまくいくものの、cronで実行されるとうまくいきません。シェルスクリプトの書き方をようやく昨日知ったばかりの素人なので大事なことが抜けているかもしれないのですが何か解決方法をご教示頂けませんでしょうか。

シェルスクリプト内容

#!/bin/sh IP_ADDR_ARRAY=("192.168.10.10"); NUM=0 for IP in ${IP_ADDR_ARRAY[@]} do ping ${IP} -c 1 >> /dev/null if [ $? == 0 ] ; then echo "" else echo "${IP} : NG" command1="service keepalived stop" eval $command1 command2="service pound stop" eval $command2 fi NUM=`expr ${NUM} + 1` done ```※IPは適当なものを記載しています。 crontab -e 内容

LOCALE=C
*/1 * * * * cd /etc/keepalived/script && ./ping.sh

■コードの内容 冗長化先のサーバのIPアドレスへpingを飛ばして、うまくいかなければkeepalived及びpoundというサービスを止めたい。 ■背景 CentOS6のサーバにpoundを入れてロードバランサーとして利用しようとしているのですが、障害対策でもう一台同じ内容のサーバを作成してkeepalivedというサービスを利用してVIPを付与して、マスターのサーバが落ちたときにスレーブ側がVIPを引き継ぐようにしました。 サービス、サーバが落ちたときはこれで大丈夫なのですが、サーバ間の通信が切れてしまった場合にどちらも生きているにもかかわらず、相互に落ちているという認識になりどちらもVIPが付与されてしまう状態になりました。 そのため、ホスト側からスレーブ側に定期的にpingを飛ばして、飛ばなくなったらホスト側のサービスを停止してスレーブが生きている状態にしようとしております。 以上です。 基本的な部分で何か間違っていて本質とは違う部分からミスがありましたら申し訳ありません。 宜しくお願い致します。
退会済みユーザー👍を押しています

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

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

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

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

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

guest

回答2

0

ベストアンサー

これは、cron使う上で良くぶち当たる問題ですね。

crond実行時は、普段読み込んでいるパスの設定を読み込まないため、
evalがどこにあるかわからない状態であるためです。

以下に変更してください。

sh

1PATH=/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/bin # ← ご自身のPATHに変更してください 2LOCALE=C 3#*/1 * * * * cd /etc/keepalived/script && ./ping.sh 4* * * * * sh /etc/keepalived/script/ping.sh # ← 絶対PATHにしてください

もしくは /etc/crontab のヘッダーを変更してください。

尚、「*/1 * * * 」のところは、1分間隔の場合「 * * * *」で良いです。

投稿2017/03/28 04:47

編集2017/03/28 04:53
lazhuward

総合スコア1294

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

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

ssall

2017/03/28 04:58

lazhuward様 ご回答いただき有難うございます。 cronの中身をご教示頂いたものに変更したら期待通りに動作しました!有難うございます! なるほど、パスの設定が必要なのですね。もう少し調べて勉強します。 解決の答えとなる回答を頂けたのでベストアンサーとさせて頂きます。 s.t.様含めご回答頂き有難うございました。
guest

0

/var/log/cron
でクロンのログを見てみてください。
エラーとか出てないでしょうか?

*/1 * * * * sh /etc/keepalibed/script/ping.sh >>/tmp/ping.log 2>>/tmp/ping-err.log

とかで設定すれば、どこでエラーが出ているかがわかるかもしれません。

投稿2017/03/28 02:36

編集2017/03/28 02:42
s.t.

総合スコア2021

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

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

ssall

2017/03/28 04:09

s.t.様 ご回答有難うございます。 ご教示頂いた内容にcrontabの中身を書き換えてみたのですが、ping-err.logに下記のように表示されております。 ./ping.sh: line 14: service: command not found ./ping.sh: line 16: service: command not found なお、/var/log/cron内にはエラーログは吐かれていませんでした。 ping.logには下記のように記述されていました。 192.168.10.10 : NG コマンド実行時には質問欄にて記載のシェルをそのまま実行すればうまくいったのですが、エラー内容をみるとcommand not foundと出てしまうようです。
s.t.

2017/03/28 04:25

service keepalived stopなどのコマンドを利用できる権限をもったアカウントで crontab -eを編集してますでしょうか? /var/spool/cron/にcrontabで編集するファイルがあります。 アカウントによってファイルが異なります。
ssall

2017/03/28 04:52

[root@localhost ~]# crontab -e で実行しているためrootで実行していると思うのですが、、、rootでも権限はないのでしょうか。 /var/spool/cron内にはrootというファイルが一つだけありました。 確かに中身はcrontab -eで触っていたものと同じものでした。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問