Home » FreeBSD » FreeBSD Disk Array Check Tool (Tag: , )

Drive Network では現在 radserv をメインに使用しています。

RAID カードに Adaptec RAID 2405 または 5405 が搭載されていますが、Adaptec から FreeBSD 向けの CUI ツール arcconf が提供されているため、ステータスやリビルドの進捗等も確認出来て重宝しています。

レンタルサーバ (ホスティングサービス) では、特に共有サービスの場合は書き込み頻度も高いのでディスク障害には敏感にならざるを得ません。

Drive Network では、ディスク監視ツールを自製しており、毎分ディスクアレイの状態を監視、不具合が見つかると同時に警告メールが技術者に通知しています。

現在は hp DL360 G5 も一部使用しているため、どちらの機器で動作しても RAID カードを検出して動作する様に作成しています。

#!/usr/bin/perl -w

use strict;

#// -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
#// Controller
#// -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=

    #// ----------------------------------------------------------
    #// Option Parse
    #// ----------------------------------------------------------

    my @basename = split(/\//, $0);
    my $basename = pop(@basename);

    #// ----------------------------------------------------------
    #// Item Set
    #// ----------------------------------------------------------

    my $item = {
        mkdir    => '/bin/mkdir',
        cat      => '/bin/cat',
        chmod    => '/bin/chmod',
        ps       => '/bin/ps',
        hostname => '/bin/hostname',
        mail     => '/usr/bin/mail',
        awk      => '/usr/bin/awk',
        grep     => '/usr/bin/grep',
        chown    => '/usr/sbin/chown',

        aac      => '/dev/aac0',
        arcconf  => '/sbin/arcconf',

        ciss     => '/dev/ciss0',
        camctrl  => '/sbin/camcontrol inquiry da0 -D',
        target   => '/var/log/messages',

        maddr    => 'trouble@example.jp',

        base     => $basename,
        file     => '/tmp/.' . $basename
    };

    #// ----------------------------------------------------------
    #// Start
    #// ----------------------------------------------------------

    #// List

    if ( -e $item->{aac} )  { check_aac($item); }

    if ( -e $item->{ciss} ) { check_ciss($item); }

#// -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
#// Model
#// -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=

sub check_aac {
    my ($item) = @_;

    my @line = `$item->{arcconf} getconfig 1`;

    my $level   = 0;
    my $stat_cl = '';
    my $stat_ld = '';
    my $stat    = {};
    my $stat_sg = {};
    my $stat_dv = {};
    my $num_dv  = '';

    foreach (@line) {
        chomp;

        $_ =~ s/(\s+)/ /g;
        $_ =~ s/^ //g;

        if ($_ =~ /^Controller Status : (.+)/) {
            $stat_cl = 'Controller Status : ' . $1 . "\n";

            $stat->{cl} = ($_ =~ /Optimal/) ? 2 : 1;
        }

        if ($_ =~ /^Status of logical device : (.+)/) {
            $stat_ld = 'Status of logical device : ' . $1 . "\n";

            $stat->{ld} = ($_ =~ /Optimal/) ? 2 : 1;
        }

        if ($_ =~ /^RAID level : (.+)/) {
            $level = 'RAID level : ' . $1 . "\n";
            next;
        }

        if ($_ =~ /^Segment (\d+) : (.+)/) {
            my $seg = 'Segment ' . $1;

            $stat_sg->{$seg} = $2;
        }

        if ($_ =~ /^Device \#(\d+)/) {
            $num_dv = '#' . $1;
            next;
        }

        if ($_ =~ /^State : (.+)/) {
            $stat_dv->{$num_dv} = $1;
        }
    }

    my $body = $stat_cl . $stat_ld . "\n" . $level;

    foreach (sort keys %$stat_sg) {
        next unless ($stat_sg->{$_});

        $body .= "$_  : " . $stat_sg->{$_} . "\n";
    }

    foreach (sort keys %$stat_dv) {
        next unless ($stat_dv->{$_});

        $body .= "Device $_  : " . $stat_dv->{$_} . "\n";
    }

    if ( -e $item->{file} ) {
        if ($stat->{cl} == 2 && $stat->{ld} == 2) {
            report($item, $body, 2);
        }

    } else {
        if ($stat->{cl} == 1 || $stat->{ld} == 1) {
            report($item, $body, 1);
        }
    }
}

sub check_ciss {
    my ($item) = @_;

    my $stat = 0;
    my $line = `$item->{camctrl} | $item->{grep} 'VOLUME OK'`;

    if ($line) {
        $stat = 1;

        unless ( -e $item->{file} ) { return undef; }
    }

    my @line = `$item->{cat} $item->{target} | $item->{grep} ciss0:`;

    my $body = '';

    foreach (@line) {
        next if ($_ =~ /HP Smart Array/ || $_ =~ /ITHREAD/);   #// boot msg

        $body .= $_;
    }

    if ( -e $item->{file} ) {
        if ($stat == 1) {
            report($item, $body, 2);
        }

    } else {
        report($item, $body, 1);
    }
}

sub report {
    my ($item, $body, $flag) = @_;

    my $host = `$item->{hostname}`; chomp $host;
    my $file = $item->{file};

    my $subj = "Disk Array: ($host)";
    if ($flag == 2) { $subj = "Info: Disk Array ($host)"; }

    open  FILE, "+>$file";
    print FILE $body;
    close FILE;

    `$item->{mail} -s "$subj" $item->{maddr} < $file`;

    if ($flag == 2) { unlink($file); }
}

障害発生時 通知メール本文サンプル:

Controller Status : Optimal
Status of logical device : Degraded

RAID level : 1
Segment 0  : Present (0,0) 3NP3RY3P00009943XLP6
Segment 1  : Missing
Device #0  : Online

障害復旧時 通知メール本文サンプル:

Controller Status : Optimal
Status of logical device : Optimal

RAID level : 1
Segment 0  : Present (0,0) 3NP3RY3P00009943XLP6
Segment 1  : Present (0,1) 3NP3JCEL00009920JP8D
Device #0  : Online
Device #1  : Online

arcconf は OS に依存しない出力結果のため、コマンドのパスや動作を事前確認すれば CentOS 等にも転用出来るでしょう。

Random Select

神田カレーグランプリ 2013 (2)
欧風カレー ボンディ (神保町本店) を後にし、東京名物神田古本まつり 開催の一部でもある神田すずらん通り商店街をゆったり散歩しつつ 神田カレーグランプリ の開催場所まで移動しました。まるで神田カレー
My Select (2013/05/31)
沖縄出張 (No. 21 ? てぃーだ社員食堂 Part 1) の続きです。05/20 から 2 週間の沖縄出張で、ランチ時に社食をいただいたのは 4 回でした。Part 1 に引き続いて残り 3 回
どなん (1)
先日の出張 (05/27 ? 06/09) でついに初めて飲みました。飲みましたというより、なめました。景色 (久高島) でも触れましたが、与那国島好きな私としては一度は試してみたい泡盛でした。沖縄本
Herb
記事を書くに際し、"褒める" と "ほめる" でどちらが検索エンジンにヒットするか調べた時に、褒めるトレーニングだとか、褒める技術の様なタイトルを目にしました。
新開発 ! 超クリーミー泡サーバー (18)
新開発 ! 超クリーミー泡サーバー (Part 2) で、ともあれ 20 点分 (応募台紙 1 枚分) はあたりました。そして発送先の登録完了後、1 ヶ月弱程で郵便物が届きましたが、20 点分が郵送さ
ちゃんぷる?そば (1)
沖縄本島 (No. 49 – 波ぬ花) の続きです。沖縄入り 3 日目からは会社関連の友達と出かける予定を立てていました。私以外はうちなんちゅですが、私しか行ったことのない久高島を訪れます
純生讃岐うどん (6)
1 ヶ月程前に香川の友達から差し入れをいただきました。 うどん本陣 山田家 という地元では有名店の通販のセットで、"一日、四千人が行列をつくる讃岐うどんの老舗" だそうです。開封し
しょうぶ沼公園 (2)
8 ヶ月ぶりの沖縄旅行の翌週は、自宅近所の しょうぶ沼公園 を散策しました。ちょうど しょうぶまつり が開催されていた時期で、今までも開催自体は知っていましたが訪れたことはありませんでした。お祭り広場
飲み比べ ビアぐらすセット
年末年始の休暇に、ようやく先日いただいた贈り物をゆっくり試すことが出来ました。ビール好きと知っての心遣いだと思いますが、想い起こせば 20 代前半はビールはほぼ飲みませんでした。ダイニングバーでカクテ
三鷹の森ジブリ美術館 (4)
三鷹の森ジブリ美術館 は 10 年程前に一度訪れていますが、今回連休中に再び訪れる機会がありました。まずは JR 三鷹駅まで電車の旅で、南口に降りるとコミュニティバスがあると聞いていました。てっきり無
Valid HTML5 Valid CSS3 Another HTML Lint