Saltstack-remote-execution
SaltStack-リモート実行
Saltのコアコンセプトの1つは、リモート実行です。 Saltは、数千のシステムで数秒でコマンドを実行できます。 Saltは、独自のコマンドを使用してこの機能を実行します。 この章でリモート実行のためのさまざまなSaltコマンドを理解しましょう。
ソルトコマンド
Saltコマンドにより、Saltマスターは1つ以上の* Saltミニオン*と通信できます。 基本的な構文は次のとおりです。
上記のコマンド構文は、次の3つの主要コンポーネントで構成されています。
- target -コマンドによって適用されるシステムを決定します。
- module.function -これはコマンドです。 コマンドはモジュールと機能で構成されています。
- 引数-関数の呼び出しに必要な追加データ。
各コンポーネントを詳細に理解しましょう。
ターゲットコンポーネントとは何ですか?
ターゲットはコンポーネントであり、これにより、ミニオン(管理対象システム)をフィルタリングして機能を実行できます。 ターゲットコンポーネントを使用する簡単なコマンドを以下に定義します。
次の output が生成されます-
ここで、ターゲット* ’’ *はすべての管理対象システムを表します。 ここの「*テスト」はモジュールであり、「 ping 」は関数です。 これは、リモートシステムでpingサービスをテストするために使用されます。 さまざまなモジュールとその機能については、後続の章で学習します。
ID(ミニオン)を使用するターゲット
ターゲットの id を使用して、特定のミニオンにコマンドを送信できます。 * *を使用する代わりに、 *minion id を使用して置き換えることができます。 以下に定義されています。
次の output が生成されます-
正規表現を使用したターゲット
ターゲットは、特定の正規表現でフィルタリングできます。 以下に定義されています。
次の output が生成されます-
リストを使用したターゲット
ターゲットはリストで明示的に指定できます。 次のコードブロックで定義されています。
次の output が生成されます-
条件によるターゲット
以下のコードブロックに示すように、ターゲットを1つのコマンドに組み合わせることができます。
次の output が生成されます-
モジュールと関数(module.function)
Saltはシェルコマンドを実行できます。すべての管理対象システムでパッケージを更新し、ファイルなどを同時に配布します。 Saltはモジュールを使用してこれらの操作を行います。 Saltには、利用可能なすべての機能のための特別なモジュールがあります。 この章の簡単な例を使用して、さまざまなSaltモジュールを理解しましょう。
シェルコマンド
Saltは、 cmd.run コマンドを使用して、複数のシステムにわたってシェルコマンドをリモートで実行します。 cmd はメインモジュールで、 run は cmd モジュールで使用可能な機能の1つです。 run 関数を使用すると、以下のコードブロックに示すように、リモートシステムでシェルコマンドを実行できます。
次の output が生成されます-
ディスク使用量を表示
Saltは、管理対象システムの完全なディスク詳細を取得するための特別なモジュール disk を提供します。 diskmodule には、詳細を照会する usage 関数があります。
次の output が生成されます-
ネットワークインターフェース
Saltは、管理対象システムに関するネットワークインターフェイス情報を照会するために、モジュール内の個別のモジュール、ネットワーク、機能、インターフェイスを提供します。
次の output が生成されます-
sys.doc実行モジュール
ソルト関数は、 sys.doc 実行モジュールに送信できます。 これは、コマンドラインからモジュールの詳細を直接取得するために使用されます。 Salt関数は自己文書化されています。 すべての関数ドキュメントは、下で定義されているsys.doc()関数を介してミニオンから取得できます。
関数呼び出しの引数
引数は、関数呼び出しに追加データを提供するために使用されます。 簡単な引数の例を以下に示します。
ここで、引数 pkg.install は特定のパッケージをインストールするモジュールです。
Python関数
引数は、関数に対するスペース区切りのパラメーターです。 以下に示すように、Pythonコードを引数として渡すことができます。
次の output が生成されます-
同様に、オプションのキーワードと YAML 形式も使用できます。