让我们想象这么一个场景。你有一台服务器经常被网络中各系统的很多个用户访问。有可能出现某些用户忘记登出会话让会话保持会话处于连接状态。我们都知道留下一个处于连接状态的用户会话是一件多么危险的事情。有些用户可能会借此故意做一些损坏系统的事情。而你,作为一名系统管理员,会去每个系统上都检查一遍用户是否有登出吗?其实这完全没必要的。而且若网络中有成百上千台机器,这也太耗时了。不过,你可以让用户在本机或 SSH 会话上超过一定时间不活跃的情况下自动登出。本教程就将教你如何在类 Unix 系统上实现这一点。一点都不难。跟我做。
在 Linux 上实现一段时间后自动登出非活动用户
有三种实现方法。让我们先来看第一种方法。
方法 1:
编辑 ~/.bashrc 或 ~/.bash_profile 文件:
$ vi ~/.bashrc
或,
$ vi ~/.bash_profile
将下面行加入其中:
TMOUT=100
这会让用户在停止动作 100 秒后自动登出。你可以根据需要定义这个值。保存并关闭文件。
运行下面命令让更改生效:
$ source ~/.bashrc
或,
$ source ~/.bash_profile
现在让会话闲置 100 秒。100 秒不活动后,你会看到下面这段信息,并且用户会自动退出会话。
timed out waiting for input: auto-logout Connection to 192.168.43.2 closed.
该设置可以轻易地被用户所修改。因为,~/.bashrc 文件被用户自己所拥有。
要修改或者删除超时设置,只需要删掉上面添加的行然后执行 source ~/.bashrc 命令让修改生效。
此外,用户也可以运行下面命令来禁止超时:
$ export TMOUT=0
或,
$ unset TMOUT
若你想阻止用户修改该设置,使用下面方法代替。
方法 2:
以 root 用户登录。
创建一个名为 autologout.sh 的新文件。
# vi /etc/profile.d/autologout.sh
加入下面内容:
TMOUT=100 readonly TMOUT export TMOUT
保存并退出该文件。
为它添加可执行权限:
# chmod +x /etc/profile.d/autologout.sh
现在,登出或者重启系统。非活动用户就会在 100 秒后自动登出了。普通用户即使想保留会话连接但也无法修改该配置了。他们会在 100 秒后强制退出。
这两种方法对本地会话和远程会话都适用(即本地登录的用户和远程系统上通过 SSH 登录的用户)。下面让我们来看看如何实现只自动登出非活动的 SSH 会话,而不自动登出本地会话。
方法 3:
这种方法,我们只会让 SSH 会话用户在一段时间不活动后自动登出。
编辑 /etc/ssh/sshd_config 文件:
$ sudo vi /etc/ssh/sshd_config
添加/修改下面行:
ClientAliveInterval 100 ClientAliveCountMax 0
保存并退出该文件。重启 sshd 服务让改动生效。
$ sudo systemctl restart sshd
现在,在远程系统通过 ssh 登录该系统。100 秒后,ssh 会话就会自动关闭了,你也会看到下面消息:
$ Connection to 192.168.43.2 closed by remote host. Connection to 192.168.43.2 closed.
现在,任何人从远程系统通过 SSH 登录本系统,都会在 100 秒不活动后自动登出了。
以上就是分享给大家关于Linux 上让一段时间不活动的用户自动登出方法介绍的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
相关文章:
1. 测试版用户终于能反悔了: Win11新功能允许退回正式版系统2. linux sed 多行处理详细总结3. linux 删除换行符的方法小结4. Linux如何通过命令查看日志文件的某几行(中间几行或最后几行)5. 苹果电脑怎么关闭用户界面声音效果? mac设置不要播放用户界面声音技巧6. The Linux+DOS+Win95 mini-HOWTO7. 部分苹果 macOS Monterey 用户遇到“内存泄漏”问题,应用后台运行消耗上百 GB 内存8. 被黑客利用植入勒索软件!微软敦促Win10/11用户尽快升级9. Win10 用户反馈安装 3 月更新出现问题,包括安装失败、蓝屏、风扇全功率运转等10. window10怎么禁止用户改密码? Win10用户不能私自更改密码的技巧