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

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

ただいまの
回答率

90.50%

  • Linux

    3779questions

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

  • bash

    648questions

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

  • Ansible

    151questions

    Ansibleは、Python で書かれたサーバーの設定を管理するための 構成管理ツールです。

複数台(40~50台前後)Linuxマシンの設定ファイルを横串で確認する方法

受付中

回答 3

投稿

  • 評価
  • クリップ 1
  • VIEW 882

ikeyan_123

score 2

前提・実現したいこと

複数台のLinuxマシン(RHEL6)の設定ファイル(OS・アプリケーション含め)を横串で一括比較したいと思っています。マシン環境はバラバラで、実装されているアプリケーション等は大きく異なります。
手動で1対1の比較をする事はやりましたが、全台での比較となると非常に工数が掛かる為、もっと効率の良い方法が無いかと考えています。
比較した結果として、一致している箇所、一致していない箇所が一覧で見られれば最高です。
ナレッジをお持ちの方、お知恵をお貸しください。

発生している問題・エラーメッセージ

特になし

該当のソースコード

特になし

試したこと

「diff」コマンドや「WinMerge」を利用して、2台程度の比較は出来ましたが、全台を順番に比較していくのは大変工数が掛かる為、別の方法を検討しています。

補足情報(言語/FW/ツール等のバージョンなど)

一括管理用のマシンとして、ansibleがインストールされた環境はありますので、設定ファイルを全マシンから抽出することは容易です。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • mukkun

    2017/01/17 13:22

    50台比較した際に、何を持って「一致している箇所、一致していない箇所」を抽出するのでしょう。統計で一番多い設定を基準とするのでしょうか。

    キャンセル

  • ikeyan_123

    2017/01/17 15:09

    失礼しました。そこも含めて(一致している・一致していないを判断するやり方)の質問でした。本来は基準となる設定一覧を作成し、それと比較するの良いとは思っていますが。。。

    キャンセル

回答 3

+3

対象ファイルが管理マシンに抽出されているのであれば、diffコマンドを順次実行する
バッチ(Shell)ファイルを作成してはどうでしょうか。
ファイルを保存するディレクトリ構成ルールと比較時の基準となるファイルを決めて
しまえば比較結果を取得することは容易です。
余力があればdiff結果を編集してマシン名やファイル名、変更箇所を見やすく出力
することもできると思います。

いきなり100%自動化を考えると難しくなるので、まずはdiffコマンド羅列で比較結果を
ファイルに保存することぐらいから始めてはどうでしょうか。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/01/17 15:20

    回答ありがとうございます。Shellを作りこめばある程度自動化できることはなんとなく分かっていたのですが、そこを作っている時間もスキルも無く(涙)。これを参考にすると良いというようなサンプル等ご存知ありませんでしょうか?教えてちゃんで本当に申し訳ありません。

    キャンセル

  • 2017/01/17 15:47

    Shellは作りこまなくても単純なコマンド列挙で動作します。
    スキルが無く時間がないなら力技で全コマンド書いた方が早いです。
    (ある程度コピペで作れると思いますが)
    単純自動化後に徐々に理想のスクリプトにすればよいと思います。

    「力技も嫌だ」というのであればどうしようもないですが・・・

    キャンセル

+1

こんな回答は期待してないかもしれませんが…

  • 全ての鯖の設定ファイルを集めて、初期状態の設定ファイルとのレーベンシュタイン距離などの文字列間の距離を求める
  • gitに最初に初期状態の設定ファイルをコミットし、続いて同じ名前で距離の近い順にコミットしていく(コミットメッセージにはサーバの名前、ファイルの最終変更日時などを入れる)
  • gitリポジトリを見やすいツールで鑑賞する(git gui, tig blame, tig showなど)

ただ思いついただけなのでうまくいくかはわかりませが、人によってはdiffと格闘するより楽めると思います。距離順にしなくても、git/hg/svnなどのツールにぶち込むだけでもだいぶ違うかと。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/01/17 15:17

    ありがとうございます。gitを使った方法を一度試してみたいと思います。

    >人によってはdiffと格闘するより楽めると思います
    はい、仰る通りで、diffの結果と格闘すれば良い事は分かっているのですが、とてもモチベーションが上がりません。。。なんとか自動化できればなぁというのが今回の質問の本質です。

    キャンセル

+1

(OS・アプリケーション含め)を横串で一括比較したいと思っています。
マシン環境はバラバラで、実装されているアプリケーション等は大きく異なります。 

自分だったらPythonやRubyなどのスクリプト言語で、
正規表現を用いてバージョンなど必要な情報を抜き出し、
hash型でメモリに情報を格納していき、
50台全部取得し終わったら、
マークアップ形式に変換して、htmlファイルを作成します。

2017/01/01 10.1.1.1(RHEL6) 10.1.1.2(RHEL7) 10.1.1.3(RHEL6)
perl Ver1.1 - Ver2.2
ruby - Ver2.2 Ver2.3
python - - Ver2.4

余力や知識があるなら、
htmlファイルの作成ではなく、jsonを出力し、
可視化ツールを別途作成して、
ソート(perlVer1.1に一致するものを表示)やグラフ化、
などの機能を追加していくとより管理しやすいかなと思います。

と書きましたが、
プログラムの知識がないならsharowさんの回答と同様ですが、
gitやsvnで管理するぐらいかなと思います。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 90.50%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

  • 受付中

    sudoの読み方

    まだまだプログラミング始めたての初心者です。 質問なんですが、みなさん「sudo」はなんと発音してますか? どうでもいいことかも知れませんが、自信を持って会話するために教えてく

  • 受付中

    NFSについて教えて欲しいです。

    NFSに関して教えて欲しいです。 1つのサーバーにNFSで複数のサーバーをマウントさせて現在利用しています。 しかし、たまにマウントがうまくされていない時があります。 解除され

  • 解決済

    サーバーのファイルを簡単に更新したい

    イントラネットワーク内にWebサーバーとしてLinux(CentOS7)を立てました。 作業しているパソコン(Windows)からPHP等のファイルを更新していちいちFTPで

  • 受付中

    i386 と 現在のCPU, 各種ソースコード

    Linuxカーネルのソースコードや、GNU binutilsのソースコードを見てみると、 必ず、i386のフォルダーがあるのが時々疑問になるのですが・・・ i386のフォル

  • 受付中

    Azureサーバーに構築したOSの複製方法

    Azureサーバーにて一つ目のサーバーを構築いたしました。 そして、そのサーバーと全く同じ内容のサーバーをコピーする方法があるそうなのですが、調べてみてもわかりませんでした。

  • 受付中

    エンジニア未経験で勉強が理解出来ません。

    エンジニア未経験 勉強方 私はエンジニア未経験で今CCNAやLinuxが理解出来ずにいます。 周りも未経験とは言っていますが、できる人が多い気がして気持ちばかりがあせってしまう毎日

  • 解決済

    VMware Playerでのライブラリからの削除、ディスクからの削除のそれぞれざっくりとした意味を...

    前提・実現したいこと VMware Playerでのライブラリからの削除、ディスクからの削除のそれぞれざっくりとした意味を教えてください 発生している問題・エラーメッセージ エ

  • 解決済

    HULFTの受信側も何かすることがありますか?

    HULFTについての質問です。 あるシステムのリニューアル案件を見積しております。 基幹システムが1日1回マスタデータをHULFTでファイル送信するようですが、 受信サーバ

同じタグがついた質問を見る

  • Linux

    3779questions

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

  • bash

    648questions

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

  • Ansible

    151questions

    Ansibleは、Python で書かれたサーバーの設定を管理するための 構成管理ツールです。