![sshdで未使用のセッションのタイムアウトを定義する方法は? [コピー]](https://linux33.com/image/129416/sshd%E3%81%A7%E6%9C%AA%E4%BD%BF%E7%94%A8%E3%81%AE%E3%82%BB%E3%83%83%E3%82%B7%E3%83%A7%E3%83%B3%E3%81%AE%E3%82%BF%E3%82%A4%E3%83%A0%E3%82%A2%E3%82%A6%E3%83%88%E3%82%92%E5%AE%9A%E7%BE%A9%E3%81%99%E3%82%8B%E6%96%B9%E6%B3%95%E3%81%AF%EF%BC%9F%20%5B%E3%82%B3%E3%83%94%E3%83%BC%5D.png)
sshd
私はUbuntu 16.4 LTEでsshdを使用しており、ユーザーが何もせずに長すぎる場合は、sshサーバーによって切断されるようにシステムを設定しようとしています。
答え1
また、/etc/ssh/sshd_configから次のパラメータのコメントを削除してください。
ClientAliveInterval 900
ClientAliveCountMax 0
そうしないと、接続が切断される可能性があります。 (変更はsshdを再起動した後に適用され、その後に開かれたセッションにのみ適用されます。)
答え2
SSHDではなくShellでこれを行うことをお勧めします。
高度なBashスクリプトガイド、セクション9.1からの抜粋。内部変数:
$TMOUT
If the $TMOUT environmental variable is set to a non-zero
value time, then the shell prompt will time out after time
seconds. This will cause a logout.
ユーザーがこの変数を無効にするのを難しくするには、システム全体のログインスクリプトで読み取り専用に設定できますreadonly TMOUT=900
。
SSHセッションのタイムアウトのみが必要な場合は、条件付きに設定してください。たとえば、ディストリビューションにある場合は、/etc/profile.d
次の場所に配置できます/etc/profile.d/ssh-timeout.sh
。
if [ "$SSH_CONNECTION" != "" ]; then
readonly TMOUT=900 # a 15-minute timeout for SSH connections only
fi