ユーザーとしてサーバーを停止/再起動する機能

ユーザーとしてサーバーを停止/再起動する機能

ユーザーとしてAWS EC2サーバーを停止できる必要があります。私が見つけたhttps://www.cyberciti.biz/tips/howto-linux-allow-users-to-shutdown-server.htmlただし、AWS EC2インスタンスでこれを使用する必要があるため、静的ホスト名がないため、次のことを試してください。

ubuntu ALL=(ALL:ALL) ALL=/sbin/halt /sbin/reboot

しかし、これは私に次のことを与えます:

>>> /etc/sudoers: syntax error near line 21 <<<
What now?     
Options are:
  (e)dit sudoers file again
  e(x)it without saving changes to sudoers file
  (Q)uit and save changes to sudoers file (DANGER!)

この問題をどのように正しく解決できますか?

答え1

私はあなたが探していると思います:

ubuntu ALL=/sbin/halt, /sbin/reboot

これは次のとおりです。

ubuntu ALL=(ALL:ALL) /sbin/halt, /sbin/reboot

通常、ファイルを最終位置に配置する前にファイルの構文チェックを実行するので、常に構成を編集する必要がありvisudoます。sudoers

sudoers(5)ロングロギングの例のリストを含む完全なドキュメントについては、マニュアルページを参照してください。


質問が「この状況からどのように回復するのですか」で直接ログインできない場合は、root最良のオプションはEC2インスタンスを削除して新しいインスタンスを作成することです。

答え2

使用する場合AWS CLIユーザーはインスタンス自体で次の操作を実行できます。

aws ec2 reboot-instances --instance-ids $(curl -s http://instance-data/latest/meta-data/instance-id)

これを見て議論するインスタンス自体からEC2 IDを取得します。

実行する前に必要な権限があるかどうかをテストするには、次の--dry-runフラグを含めてみてください。

--dry-run | --no-dry-run(ブール)

実際に要求せずに操作に必要な権限があることを確認し、エラー応答を提供します。必要な権限がある場合、エラー応答はDryRunOperationです。それ以外の場合は UnauthorizedOperation です。

文脈についてはこれを参照してください議論するhaltshutdown、等rebootの違いについて

関連情報