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

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

新規登録して質問してみよう
ただいま回答率
85.34%
bash

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

シェルスクリプト

シェルスクリプトは、UNIX系のOSもしくはコマンドラインインタプリタ向けに記述されたスクリプト。bash/zshといったシェルによって実行されるため、このように呼ばれています。バッチ処理などに使用されており、テキストファイルに書かれた命令を順に実行します。

コマンド

コマンドとは特定のタスクを行う為に、コンピュータープログラムへ提示する指示文です。多くの場合、コマンドはShellやcmdようなコマンドラインインターフェイスに対する指示文を指します。

パスワード

パスワードは主に情報にアクセスする際に扱われます。主に、アクセス可能なユーザーを限定する手段として使われます。

Q&A

解決済

2回答

4366閲覧

sudoに自動でパスワードを与える処理をパイプの途中に入れたい

akira_kano1101

総合スコア25

bash

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

シェルスクリプト

シェルスクリプトは、UNIX系のOSもしくはコマンドラインインタプリタ向けに記述されたスクリプト。bash/zshといったシェルによって実行されるため、このように呼ばれています。バッチ処理などに使用されており、テキストファイルに書かれた命令を順に実行します。

コマンド

コマンドとは特定のタスクを行う為に、コンピュータープログラムへ提示する指示文です。多くの場合、コマンドはShellやcmdようなコマンドラインインターフェイスに対する指示文を指します。

パスワード

パスワードは主に情報にアクセスする際に扱われます。主に、アクセス可能なユーザーを限定する手段として使われます。

0グッド

1クリップ

投稿2023/03/09 00:48

編集2023/03/10 23:06

実現したいこと

1. こちらはパスワードも求められないが動作しない(sudoなし)

console

1% ps aux | grep "watch" | grep -v grep | awk '{ print "kill -9", $2 }' | sh 2sh: line 1: kill: (128) - Operation not permitted
2. パスワードを求められるが動作する(sudoあり)

console

1% ps aux | grep "watch" | grep -v grep | awk '{ print "kill -9", $2 }' | sudo sh 2Password:

上記の2. のような処理を自動化するためにスクリプトに入れたいです。

解決したいこと

cargo lambda watchコマンドをバックグラウンド実行していて、このプロセスをスクリプト内でkill -9する方法についてです。

パスワードが必要となるsudoコマンドをスクリプト内で使用したいです。echosudo -Sを使えばいけるという記述が多くWeb上に情報として出回っていますが、今回の私のような処理ではawkなどの処理をパイプで繋いでいるため途中にechoを挟めないと思っています。

こうやれば良いようですが

console

1% PASSWORD=*** 2% echo $PASSWORD | sudo -S sh
こうしても動作するものですか?

console

1% PASSWORD=*** 2% ps aux | grep "watch" | grep -v grep | awk '{ print "kill -9", $2 }' | echo $PASSWORD | sudo -S sh
もしかしてこれで動きますか?

bash

1PASSWORD=*** 2echo $PASSWORD | sudo -S echo 'ログイン' 3ps aux | grep "watch" | grep -v grep | awk '{ print "kill -9", $2 }' | sudo sh

まとめ

スクリプト内でパイプで繋いだ処理の途中のsudoにパスワードを自動で与える方法についてベストプラクティスを助言お願いしたいです。

拙い質問ですが、ご存知の方いらっしゃいましたらご回答のほどよろしくお願いします。

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

melian

2023/03/09 01:14 編集

pkill コマンドがインストールされているのであれば、以下の様にするとよいかもしれません。 echo "$PASSWORD" | sudo -S pkill -f -KILL watch
akira_kano1101

2023/03/09 03:46

コメントありがとうございます。 提示いただいたコマンドを私の環境で実行してみましたが Password:pkill: illegal option -- K usage: pkill [-signal] [-ILfilnovx] [-F pidfile] [-G gid] [-P ppid] [-U uid] [-g pgrp] [-t tty] [-u euid] pattern ... と出て実行できませんでした。usageは表示されたのでインストールはされていると思いますが… また、書き忘れていましたが今回は複数人がチェックアウトして使うスクリプトにしたいと思っているので、環境依存の形はできるだけ避けたいとは思っています。 ともかくそういう方法もあるのだと知れてよかったです。また機会があればよろしくお願いします。
melian

2023/03/09 03:51

そのエラーメッセージから察すると、以下の様にするのかと思います。ご参考までに。。。 echo "$PASSWORD" | sudo -S pkill -f -9 watch
akira_kano1101

2023/03/09 04:22

melian様 ありがとうございます。 新しく提示くださったものも試してみました。なんだか上手くいかないぞと、色々試してみたところ echo "$PASSWORD" | sudo -S pkill -f watch これで動作してくれました! 参考についてお知らせいただき嬉しく思います。 また機会がありましたらお願いしますね!
guest

回答2

0

ベストアンサー

sudoのパスワードは一定時間記憶(デフォルトで5分)されますので、やってみればわかりますが、

もしかしてこれで動きますか?

のコードで出来るはずです。タイプミスなのか、変な文字が入ってるので、それを削除してからですが。

sh

1PASSWORD=*** 2echo $PASSWORD | sudo -S echo 'ログイン' 3ps aux | grep "watch" | grep -v grep | awk '{ print "kill -9", $2 }' | sudo sh

パスワードを平文でファイル中に書く是非はさておきます。

あるいは、

sh

1PASSWORD=*** 2echo $PASSWORD | sudo -S sh -c "ps aux | grep watch | grep -v grep | awk '{ print \"kill -9\", \$2 }' "

のように実行するコマンドをsh -cでコマンドラインで与える方法もあります。

sudoへのパイプの先頭にパスワードを入れるというのありますが、パスワードが記憶されいている時間内に実行すると、それがパスワードとみなされません。shに与えるとパスワードをコマンドと見なして実行しますので、良くてcommand not foundのエラー。もし、パスワードがrm *という文字列だったら大変。

sh

1(echo パスワード; ~~~~~) | sudo -S sh

cronで1分ごとに↑を動かすとかであれば、パスワードを記憶しない設定にする必要があります(手動でsudoするときに面倒ですが)。もしくはパスワードがコマンドと解釈されても大丈夫な場合。

ただ、sudoの一般論でなく、この目的に特化して考えると、コメントが付いているように専用のコマンドを使うほうがいいでしょうね。

なお、kill -9というのは、対象プロセスが用意している終了処理をすっ飛ばしてプロセスを殺すと言うことなので、作業用のファイルが消えずに残ったり、ネットワークの通信先がいつまでも待ちになったり、場合によっては共有メモリ上にゴミが残ったりする可能性があるので、普通は「ハングアップしており、killでは終了しない」場合にだけ使います。
パソコンの電源オフアイコンをクリックしたり、電源ボタンを長押ししても電源が切れないので、電源ケーブルをコンセントから抜くイメージ。

投稿2023/03/09 03:25

otn

総合スコア85994

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

akira_kano1101

2023/03/09 04:05

otn様 ご回答ありがとうございます。 申し訳ありません。それはタイプミスです。修正しておきます。 本当ですね、何度も繰り返し実行するとcommand not foundでパスワードがその度に画面に表示されてしまうこともわかるのでセキュリティ的にここは問題ですね。 なるほど、`kill -9`コマンドは適切なコマンドではないのですね。 私もなんとなくその認識はありましたが、本来の`cargo lambda watch`のバックグラウンド処理の切り方を知らないのでこうやっていました。 お手数おかけしますが、もしよろしければこちらの方法も知りたいです。 お手隙の時で結構ですので、ご教示いただけたらと思います。 よろしくお願いします。
otn

2023/03/09 04:23

> お手数おかけしますが、もしよろしければこちらの方法も知りたいです。 回答に書いたつもりでしたが、一般的には kill です。 cargo lambda watch 専用の終了手順があるのであれば別ですが(そのあたりの知識が無いのでなんとも)。
akira_kano1101

2023/03/09 04:27

otn様 たびたびありがとうございます。 `kill`だけのコマンドが正しいのですね。文意が上手く読み取れていませんでした。 わかりました。また`cargo lambda watch`コマンドも色々と調べてみる必要がありそうですね。 大変参考になりました。 また機会がありましたらよろしくお願いいたします。 今回はより詳しい知識に触れることができましたのでこちらをベストアンサーとさせていただきます。 ありがとうございました。
guest

0

サブシェルを使って、最初にパスワードを echo しておくのはどうでしょう。
繰り返して実行したときに、sudoでパスワードが聞かれなくなって、パスワード部分がエラーになるので -k を追加しています。

sh

1PASSWORD=*** 2(echo $PASSWORD; ps aux | grep "watch" | grep -v grep | awk '{ print "kill -9", $2 }' ) | sudo -k -S sh

キャッシュされている間は、パスワードが聞かれなくなることを利用するなら、事前にダミーのコマンドを実行するというのでもよいかもしれません。

sh

1PASSWORD=*** 2echo $PASSWORD | sudo -S true 3ps aux | grep "watch" | grep -v grep | awk '{ print "kill -9", $2 }' | sudo sh

投稿2023/03/09 01:59

bsdfan

総合スコア4818

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

akira_kano1101

2023/03/09 03:57

bsdfan様 回答ありがとうございます。 二つ提示していただきましたが、どちらの方法とも綺麗で上手くいきそうです! 個人的に二つ目が好きなのでこちらで行こうかと思います。ありがとうございました。 また機会がありましたらよろしくお願いします。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.34%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問