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

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

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

bash(Bourne-again-Shell)は sh(Bourne Shell)のインプリメンテーションに様々な機能が追加されたシェルです。LinuxやMac OS XではBashはデフォルトで導入されています。

Linux

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

シェル

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

sh

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

Q&A

解決済

1回答

3697閲覧

ログの出力方法と条件分岐について

natsu25

総合スコア46

bash

bash(Bourne-again-Shell)は sh(Bourne Shell)のインプリメンテーションに様々な機能が追加されたシェルです。LinuxやMac OS XではBashはデフォルトで導入されています。

Linux

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

シェル

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

sh

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

0グッド

0クリップ

投稿2016/06/09 06:38

編集2016/06/09 08:29

・cronで1hおきに動きサーバの異常を検知するシェルスクリプトhoge.shがあります
・チェック内容(ssh接続の可否・ヘルスチェックのsuccessかfailure・ロードバランサとの疎通確認)
・異常があった場合ssh.txt health.txt LB.txtに異常のあったサーバ出力されます。

今の状態だとログの出力がないので処理を追加したいです。

追加したい処理
・異常がある際はまとめて1行に出力したい(例:YYYY-MM-DD hh:mm:ss sshNG:xxx-xxx-xxx,xxx-xxx-xxx healthNG:xxx-xxx-xxx LBNG:xxx-xxx-xxx,xxx-xxx-xxx)

・(ssh.txt health.txt LB.txt)に異常サーバが出力された場合のみ$logfileに出力し異常が書き出されたtxt全てを反映するようにしたい。(自分で作ったものだとそれぞれのtxtに1台ずつ出力された場合、最初のif文しか出力されない。)

・各txtに異常なサーバが複数台あった場合はカンマ区切りで出力させたい

・echo -n で改行を抑止しているが次のcronが動く時は改行したい

どなたかお知恵をお借りできませんでしょうか。

bash

1if [ -s /home/ssh.txt ]; then 2 echo -n "`date "+%Y-%m-%d %H:%M:%S"` sshNG:`cat /home/ssh.txt`" >> $logfile 3 elif [ -s /home/health.txt ]; then 4 echo -n "`date "+%Y-%m-%d %H:%M:%S"` healthNG:`cat /home/health.txt`" >> $logfile 5 elif [ -s /home/LB.txt ]; then 6 echo -n "`date "+%Y-%m-%d %H:%M:%S"` LBNG:`cat /home/LB.txt`" >> $logfile 7fi

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

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

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

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

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

kei344

2016/06/09 08:26

タイトルに入っているURLは本文とは無関係ではないでしょうか。
guest

回答1

0

ベストアンサー

こんな感じでどうでしょうか?
やっつけ仕事で作ったのでもっときれいなやり方があると思いますが・・・。

#!/bin/bash MSG=`date "+%Y-%m-%d %H:%M:%S"` ERR=0 chkerror () { if [ -s $2 ]; then MSG="$MSG $1NG "`tr '\n' ',' < $2` ERR=1 fi } chkerror ssh /home/ssh.txt chkerror health /home/health.txt chkerror LB /home/LB.txt if [ $ERR -eq 1 ]; then echo $MSG >> $logfile fi

投稿2016/06/09 08:44

yourill

総合スコア73

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問