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

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

ただいまの
回答率

90.33%

  • CentOS

    2835questions

    CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

  • シェル

    261questions

    シェル(shell)はUnix や Linux 系のOSで使用されるコマンドインタプリタを指します。

centosでのexpectの利用について

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 2,239

TakakiKuwabara

score 12

CentOSでexpectを使用して諸々の設定の自動化を行おうとしています。
その中で、おそらくメタ文字でコマンドが正しく認識されない問題が起きているため、お分かりになる方のアドバイスをいただきたく存じます。

例えば下記のコマンドをspawnで認識ができません。

expect -c "
spawn cat /var/log/mysqld.log | grep 'password is generated'
expect \".*\"
send \"tes\n\"
expect eof
"

下記のようなエラーが表示されます。

cat: |: そのようなファイルやディレクトリはありません
cat: grep: そのようなファイルやディレクトリはありません
cat: 'password: そのようなファイルやディレクトリはありません
cat: is: そのようなファイルやディレクトリはありません
cat: generated': そのようなファイルやディレクトリはありません

そこでメタ文字を下記のように編集しました。

expect -c "
spawn\ cat\ /var/log/mysqld.log\ \|\ grep\ \'password\ is\ generated\'
expect \".*\"
send \"tes\n\"
expect eof
"

すると下記のようなエラーとなり、実行されません。

invalid command name "spawn cat /var/log/mysqld.log | grep 'password is generated'"
    while executing
"spawn\ cat\ /var/log/mysqld.log\ \|\ grep\ \'password\ is\ generated\'"
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

checkベストアンサー

+2

spawnでの実行はシェルを介さないので、パイプなどを認識しません。パイプやバッククォートを扱うためにはシェル経由にします。

expect -c "
spawn sh -c \"cat /var/log/mysqld.log | grep 'password is generated'\"
expect \".*\"
send \"tes\n\"
expect eof
"


質問のものは意味不明な例なので、本当にやりたいことを書いた方が良いですよ。

追記

他回答へのコメントと前後しました。なるほど、途中まで書いただけですか。

一般に、各種プログラミング言語や、各種ツールから「外部コマンドを実行できる」という機能には2種類あります。
・直接OSの機能を呼び出す
・シェルにコマンドラインを渡してあとはシェルに任せる

expextのspawnは前者なので、シェルの機能(シェル組み込みコマンド、リダイレクト、パイプ、変数置換、コマンド置換、ファイル名展開など)は使えません。

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

0

サンプルスクリプトの中でやりたいことの趣旨が今ひとつ見えない
のですが、もし

/var/log/mysqld.log の中に 'password is generated' があれば
"tes\n" と表示したい

ということであれば、そもそも expect を使うというアプローチ自体が
誤っている気がします。上記のことをコマンドで実行するには、たとえば
以下のようにします。

$ chmod +x a.sh
$ cat a.sh
#!/bin/bash
if grep 'password is generated' /var/log/mysqld.log >& /dev/null
then
  echo found
else
  echo not found
fi
$ echo 'password is not generated' > /var/log/mysqld.log
$ ./a.sh
not found
$ echo 'password is generated' > /var/log/mysqld.log
$ ./a.sh
found

expect は、たとえば passwd コマンドや ssh/telnet ログイン時の
ように、キーボード入力待ちで処理が止まっているときに、手入力の
代行をさせて先に進ませるためのコマンドのようです。

やりたいことの想定が誤っている場合は、希望する処理を記載して
ください。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2017/03/05 19:53

    失礼しました。説明に不足がありました。

    /var/log/mysqld.log の中にある初期パスワードを拾い、次の処理につなげることが目的です。
    パスワード表示後の処理はまだ作っていないため、省きました。
    他の方法があることはわかっておりますが、メタ文字のために意図する動作をしない、ということが後々のexpectを使用したシェルに関わってくる可能性があるため、投稿した次第でございます。

    よろしくお願いします。

    キャンセル

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

  • CentOS

    2835questions

    CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

  • シェル

    261questions

    シェル(shell)はUnix や Linux 系のOSで使用されるコマンドインタプリタを指します。