Linux踢出其他正在SSH登陆用户


在一些生产平台或者做安全审计的时候往往看到一大堆的用户SSH连接到同一台服务器,或者连接后没有正常关闭进程还驻留在系统内。限制SSH连接数与手动断开空闲连接也有必要之举,这里写出手动剔出其他用户的过程。

1、查看系统在线用户

[root@apache ~]# w 

14:15:41 up 42 days, 56 min,  2 users,  load average: 0.07, 0.02, 0.00 

USER     TTY      FROM              LOGIN@   IDLE   JCPU   PCPU WHAT 

root     pts/0    116.204.64.165   14:15    0.00s  0.06s  0.04s w 

root     pts/1    116.204.64.165   14:15    2.00s  0.02s  0.02s –bash

2、查看当前自己占用终端,别把自己干掉了

[root@apache ~]# who am i 

root     pts/0        2013-01-16 14:15 (116.204.64.165)

3、用pkill 命令剔除对方

[root@apache ~]# pkill -kill -t pts/1

4、用w命令在看看干掉没。

[root@apache ~]# w 

14:19:47 up 42 days,  1:00,  1 user,  load average: 0.00, 0.00, 0.00 

USER     TTY      FROM              LOGIN@   IDLE   JCPU   PCPU WHAT 

root     pts/0    116.204.64.165   14:15    0.00s  0.03s  0.00s w

 

后记:

如果最后查看还是没有干掉,建议加上-9 强制杀死。

[root@apache ~]# pkill -9 -t pts/1

 

 

#

###

 



​Linux 系统下查看已经登录用户并踢出的方法​

博客分类:


​linux​


 


  Linux 是个多用户系统,一旦连接到网络中,它可以同时为多个登录用户提供服务。系统管理员可以随时了解系统中有那些用户,用户都在进行什么操作。 


查看用户的操作 


  系统管理员若想知道某一时刻用户的行为,只需要输入命令W 即可,在SHELL终端中输入如下命令: 


【转载】Linux踢出其他正在SSH登陆用户_apache


可以看到执行W命令及显示结果。 


命令信息含义 


上述显示的信息分别表示如下: 

第一行显示系统的汇总信息,字段分别表示系统当前时间、系统运行时间、登陆哟内用户总数及系统平均负载信息。对于上述中的几个显示数据意义为: 


15:59:27 表示执行W的时间。 

up 1:01 表示系统运行时间。 

4 USERS 表示当前系统登陆用户总数。 

LOAD AVERAGE 与后面的数字一起表示系统在过去1,5,10分钟内的负载程度,数值越小,系统负载越轻。 


从第二行开始构成一个表格,共有8个栏目,分别显示各个用户正在做的事情及该用户所占用的系统资料。 


USER:显示登陆用户帐号名。用户重复登陆,该帐号也会重复出现。 

TTY:用户登陆所用的终端。 

FROM:显示用户在何处登陆系统。 

LOGIN@:是LOGIN AT的意思,表示登陆进入系统的时间。 

IDLE:用户空闲时间,从用户上一次任务结束后,开会记时。 

JCPU:一终端代号来区分,表示在摸段时间内,所有与该终端相关的进程任务所耗费的CPU时间。 

PCPU:指WHAT域的任务执行后耗费的CPU时间。 

WHAT:表示当前执行的任务。 


查看某用户 


  当登陆系统用户很多的时候,可以在W后面加上某个用户名,则会查看该用户执行任务的情况。 


【转载】Linux踢出其他正在SSH登陆用户_运行时间_02 


  默认情况下,系统会显示上述所有的信息,如果只关心某一方面,可以只使用相关的选项。 


查看登陆用户 


  同样,系统管理员若想知道某一时刻登陆的用户,可以使用系统提供的who命令,该命令可以查看当前登陆到系统的用户及其他信息: 


【转载】Linux踢出其他正在SSH登陆用户_系统管理员_03 


  可以看出上述信息与 W 命令非常相似。如果想让列表更详细一些,可以加上选项-HIT等,就可以得到该用户是否愿意接受其他用户信息(-T)还可以显示空闲时间(-I)及标题栏(-H)。如果某各用户愿意接受信息,会在MESG栏中显示一个“+”,这是还可以使用命令MESG给用户发从信息。 


查看登陆用户历史 


  系统管理员若想知道系统中用户登陆的历史行为,还可以察看用户曾经登陆到系统。使用LAST 命令可以查询曾经登陆用户的信息: 


【转载】Linux踢出其他正在SSH登陆用户_用户登陆_04


  使用LAST 命令时,列出的文件内容会非常多,根本看不清楚。此时可以使用前面介绍的管理方式来观看,例如/LAST/ LESS,则可以查看前后内容。同查看用户情况一样,想查看那某个用户的登陆情况,也可以在LAST命令后加上用户名,则系统只会显示该用户登陆系统情况。 


  执行last命令其实是显示/var/log/目录下的wtmp文件内容。Wtmp文件是以二进制格式进行存储的,如果直接使用文本编辑器查看,查看的会是一堆乱码。