harumaki.net

インフラ屋の覚書や、ラーメン食べある記とか。

bash GNU/Linux メモ

script​/標準入力の判定(case文)

投稿日:2006年10月29日

ホスト名を標準入力にて引数として追加し、ホストグループを判定する勉強用スクリプト。

ホスト名の先頭にweb、db、app、mailがあった場合はホストグループとサーバールートを出力、
ホスト名が対象外、あるいは引数が無い場合は"該当しない"旨のメッセージを出力。

  • スクリプト
    test.sh

    #!/bin/sh
    
    HOST=$1
    TARGETDATE=`date -d '1days ago' +%Y%m%d`;
    TMPDIR='/home/backup/tmp/logs'
    SERVERROOT='/home/backup/web/logs'
    
    case $1 in
        web*)
            echo "hostgroup is apache web servers"
            SERVERROOT='/usr/local/apache'
            ;;
        db*)
            echo "hostgroup is mysql db servers"
            SERVERROOT='/usr/local/mysql'
            ;;
        app)
            echo "hostgroup is java application servers"
            SERVERROOT='/usr/local/tomcat'
            ;;
        mail*)
            echo "hostgroup is postfix mail servers"
            SERVERROOT='/usr/local/postfix'
            ;;
        *)
            echo "This host doesn't belong to any group or no stdin. "
            ;;
    esac
    echo "SERVERROOT=$SERVERROOT" 
    
    exit 0
  • 実行例
    標準入力をつけた場合は以下の通りとなる。

    $ sh test.sh web001
    hostgroup is apache web servers
    SERVERROOT=/usr/local/apache

    標準入力が対象外のホスト、あるいは入力が無い場合は以下の通りとなる。

    $ sh test.sh
    This host doesn't belong to any group.
    BACKUPDIR=none
  • 備考
    最後のecho "SERVERROOT=$SERVERROOT"は条件式毎にいれてもよい。

-bash, GNU/Linux, メモ

執筆者:


comment

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

CAPTCHA


関連記事

no image

[メモ]ディレクトリ”/srv”の使いみち

WebサーバーやDBサーバーをセットアップする際、RedHat、Fedora、CentOSなどでRPMパッケージでセットアップする場合は /var/wwwや/var/lib/mysqlなどあらかじめ用 …

no image

LinkStation rootアカウントのリセットとtelnetログイン

職場のLinkStationが不調になったとの連絡があり、フォルダにアクセスできなくなったり、起動してしばらくするとエクスプローラーからの応答が無くなったり、管理画面へのアクセスもタイムアウトする始末 …

no image

インフラ運用の心得:最低限やっておくこと

インフラ運用に最低限やっておくこと 1)ドキュメント作成 2)ログ 3)バックアップ/データ 4)バックアップ/ハード 5)バックアップ/ネットワーク機器 6)監視 /トラブルシュート 7)ネットワー …

no image

rsyncの帯域制限オプション(bwlimit)を試す

出向先のLAN環境にて、でかいバックアップファイルをrsyncで別ホストに転送しようとしたら、イントラ用Webサービスのレスポンスが全体的に低下してしまった~。 中断して調べたところ、100base- …

[メモ]mysql​/ステータス確認

参考URL お世話になっております! http://allabout.co.jp/gm/gc/47473/ テーブルの確認方法 † ストレージエンジンも確認できる。 書式 show cr …