この記事では、シェルによる自動対話を実現するためのexpectコマンドについて、ループや判定などの簡単な制御フロー機能をシェル経由で実装できる例を交えて説明します。以下の記事では、シェルの自動対話を実現するための Expect コマンドの使用に関する関連情報を中心に、サンプルコードを通じて詳しく紹介しています。必要な方は一緒に参照してください。
背景
Linux スクリプトには、リモート ログイン ssh、リモート コピー scp、ファイル転送 sftp など、リモート操作のための多くのシナリオがあります。これらのコマンドにはセキュリティ パスワードの入力が必要です。コマンドを通常に使用するには、パスワードを手動で入力し、セキュリティ検証を受け入れる必要があります。自動化されたリモート操作を実現するために、expect の機能を借用できます。
expect は、人間の介入なしで通信するための自動化された対話型タスクを実装するために使用される無料のプログラミング ツール言語です。 Expect は時間の経過とともに常に進化しており、その機能はますます強力になり、システム管理者の強力なアシスタントとなっています。 Expect をシステム上で実行するには、まず Tcl プログラミング言語のサポートが必要です。
expectのインストール
expectはTclに基づいて作成されているため、expectをインストールする前にTclをインストールする必要があります。
(1) Tclのインストール
ホームページ: http://www.tcl.tk
ダウンロードアドレス: http://www.tcl.tk/software/tcltk/downloadnow84.tml
1.ソース コード パッケージをダウンロードします
wget http://nchc.dl.sourceforge.net/sourceforge/tcl/tcl8.4.11-src.tar.gz
2. ソース コード パッケージを解凍します
tar xfvz tcl8.4.11-src.tar.gz
3. インストールと設定
1. インストールが完了したら、tcl ソース コードのルート ディレクトリに移動し、tclUnixPort をコピーします。サブディレクトリ unix の下の .h をサブディレクトリ generic にコピーします。
2. tcl ソース コードは、予期されるインストール プロセスにまだ必要であるため、まだ削除しないでください。
(2) インストールを期待します (Tcl ライブラリが必要です)
ホームページ: http://expect.nist.gov/
1. ソースコードパッケージをダウンロードします
cd tcl8.4.11/unix ./configure --prefix=/usr/tcl --enable-shared make make install
2. ソースコードパッケージを解凍します
wget http://sourceforge.net/projects/expect/files/Expect/5.45/expect5.45.tar.gz/download
3. インストールと設定
tar xzvf expect5.45.tar.gz
expect
expect のコアは、spawn、expect、send、set です。
spawn は実行するコマンドを呼び出します
- expect コマンドプロンプト情報が表示されるのを待ちます。つまり、ユーザー入力のプロンプトをキャプチャします。
- send は対話を必要とする値を送信し、ユーザーマニュアルを置き換えますinput
- set は変数 value
- interact を設定します。実行完了後、対話状態が維持され、制御がコンソールに渡されます。このとき、手動操作を実行できます。このような文がない場合は、リモート端末に留まらず、ログイン完了後に終了します。
- expect eof を追加する必要があります。これは、if....endif
- expect スクリプトと同様に、キャプチャ端末の出力情報が終了することを意味します。通常、expect eof は、次のようになります。自動化されたタスクを実行するのに十分です。
その他の設定
- タイムアウトを期待しないように設定しますタイムアウトを-1に設定します
- タイムアウトを期待する300秒を設定します。300秒を超えても期待されるコンテンツが表示されない場合は、終了しますタイムアウトを300に設定します
- 構文を期待する
expect は tcl 構文を使用します
- Tcl コマンドはスペースで区切られた単語で構成され、最初の単語はコマンド名で、残りはコマンドパラメータです
- cmd arg arg arg
- $foo
たとえば、あるコマンドの結果を引数として別のコマンドに渡す場合、角括弧は入れ子になったコマンドを実行します。コマンドの場合は、記号 [cmd arg] -
を使用します。二重引用符は、フレーズをコマンドの引数としてマークします。「$」記号と角かっこは、引き続き二重引用符内で解釈されます。 中括弧は、コマンドのパラメータとしてマークされたフレーズも示します。ただし、中括弧内の他の記号は解釈されません -
バックスラッシュ記号は、特殊記号を引用するために使用されます。例: n は、を表します。バックスラッシュ記号も使用されます。「$」記号、引用符、角括弧、中括弧の特別な意味を閉じるために使用されます -
例 -
login.expは、リモートログイン、ショートカットメソッド専用です。 :login.exp "exclude" "${remote_ip} " "${remote_user}" "${remote_passwd}" "${remote_command}"
cd expect5.45 ./configure --prefix=/usr/expect --with-tcl=/usr/tcl/lib --with-tclinclude=../tcl8.4.11/generic make make install ln -s /usr/tcl/bin/expect /usr/expect/bin/expect
もう学びましたか?この記事を読んで、シェル自動化の相互作用についてより深く理解していただければ幸いです。
日付に従ってファイルをダウンロードする Linux シェルの FTP メソッド
以上がシェルの自動対話を実装するための Expect コマンドを説明する例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

Linuxオペレーティングシステムの5つのコアコンポーネントは次のとおりです。1。Kernel、2。Systemライブラリ、3。SystemTools、4。SystemServices、5。FileSystem。これらのコンポーネントは、システムの安定した効率的な動作を確保するために連携し、一緒に強力で柔軟なオペレーティングシステムを形成します。

Linuxの5つのコア要素は、1。Kernel、2。CommandLineインターフェイス、3。ファイルシステム、4。パッケージ管理、5。コミュニティおよびオープンソースです。一緒に、これらの要素はLinuxの性質と機能を定義します。

Linuxユーザー管理とセキュリティは、次の手順を通じて達成できます。1。sudouseradd-m-gdevelopers-s/bin/bashjohnなどのコマンドを使用して、ユーザーとグループを作成します。 2. bulkly forループとchpasswdコマンドを使用して、ユーザーを作成し、パスワードポリシーを設定します。 3.一般的なエラー、ホームディレクトリ、シェル設定を確認して修正します。 4.強力な暗号化ポリシー、定期的な監査、最低限の権限の原則などのベストプラクティスを実装します。 5.パフォーマンスを最適化し、SUDOを使用し、PAMモジュールの構成を調整します。これらの方法により、ユーザーを効果的に管理でき、システムセキュリティを改善できます。

Linuxファイルシステムとプロセス管理のコア操作には、ファイルシステム管理とプロセス制御が含まれます。 1)ファイルシステム操作には、MKDIR、RMDIR、CP、MVなどのコマンドを使用したファイルまたはディレクトリの作成、削除、コピー、および移動が含まれます。 2)プロセス管理には、./my_script.sh&、top、killなどのコマンドを使用して、プロセスの開始、監視、殺害が含まれます。

シェルスクリプトは、Linuxシステムでコマンドを自動実行するための強力なツールです。 1)シェルスクリプトは、通訳を介して行ごとにコマンドを実行して、可変置換と条件付き判断を処理します。 2)基本的な使用法には、TARコマンドを使用してディレクトリをバックアップするなど、バックアップ操作が含まれます。 3)高度な使用には、サービスを管理するための機能とケースステートメントの使用が含まれます。 4)デバッグスキルには、セットXを使用してデバッグモードを有効にし、コマンドが故障したときにセットEを終了することが含まれます。 5)サブシェル、使用、最適化ループを避けるために、パフォーマンスの最適化をお勧めします。

Linuxは、UNIXベースのマルチユーザーのマルチタスクオペレーティングシステムで、シンプルさ、モジュール性、オープン性を強調しています。そのコア機能には、ファイルシステム:ツリー構造で整理され、Ext4、XFS、BTRFSなどの複数のファイルシステムをサポートし、DF-Tを使用してファイルシステムタイプを表示します。プロセス管理:PSコマンドを使用してプロセスを表示し、優先度の設定と信号処理を含むPIDを使用してプロセスを管理します。ネットワーク構成:IPアドレスの柔軟な設定とネットワークサービスの管理、およびsudoipaddraddを使用してIPを構成します。これらの機能は、基本的なコマンドと高度なスクリプト自動化を通じて実際の操作に適用され、効率を向上させ、エラーを削減します。

Linuxメンテナンスモードに入る方法には次のものがあります。1。grub構成ファイルを編集し、「シングル」または「1」パラメーターを追加し、Grub構成を更新します。 2。GRUBメニューでスタートアップパラメーターを編集し、「シングル」または「1」を追加します。終了メンテナンスモードでは、システムを再起動する必要があります。これらの手順を使用すると、必要に応じてメンテナンスモードをすばやく入力して安全に終了し、システムの安定性とセキュリティを確保できます。

Linuxのコアコンポーネントには、カーネル、シェル、ファイルシステム、プロセス管理、メモリ管理が含まれます。 1)カーネル管理システムリソース、2)シェルはユーザーインタラクションインターフェイスを提供します。3)ファイルシステムは複数の形式をサポートします。4)プロセス管理は、フォークなどのシステムコールを通じて実装され、5)メモリ管理は仮想メモリテクノロジーを使用します。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。
