Linux 下如何知道是否有人在使坏?

Stella981
• 阅读 328

 在 Linux 下查看用户的行为,不仅仅是网管要做的事,也是开发人员所应该具备的基本技能之一。为什么呢?因为有时其他同事在做一些很消耗资源的事情,比如在编译大型程序,可能会导致服务器变得很慢,从而影响我们的正常操作。这个时候,我们就可以通过本文所介绍的方法,揪出那个同事,将他暴打一顿,就可以恢复服务器的正常使用了。

  ** 我是谁?**

  「我是谁?我从哪里来?我要去哪里?」哲学经典三大问题。同样,在工作中,有时候我们会经常进行账号切换,有时切着都忘了切到哪个用户了。这时,需要知道当前登录的用户是啥。我们可以用 whoami 来进行查看。

   [alvin@VM_0_16_centos ~]$ whoami

  alvin

  目前都有谁登录到系统里?

  一个公司里通常只有少数几台服务器,程序猿们一般都在这几台服务器里工作。我们可以用 who命令来查看当前登录到服务器的用户有哪一些。

[alvin@VM_0_16_centos ~]$ who

  alvin    pts/0        2018-12-09 07:25 (116.199.***.***)

  root     pts/1        2018-12-09 11:05 (116.199.***.***)

  alvin    pts/2        2018-12-09 11:05 (116.199.***.***)

  harry    pts/3        2018-12-09 11:06 (116.199.***.***)

  kate     pts/4        2018-12-09 11:08 (116.199.***.***)

  alvin    pts/5        2018-12-09 11:53 (116.199.***.***)

  在显示结果里,第一列是用户名;第二列是连接的终端,tty 表示显示器,pts 表示远程连接;第三列是登陆时间。

  这里信息稍微多一些,但如果我们只想知道谁在线要怎么操作?只需用 users 命令来查看即可。

   [alvin@VM_0_16_centos ~]$ users

  alvin alvin alvin harry kate root

  那些登录到系统里的人都在干什么?

  知道了谁登录到系统里,我们就可以进一步调查他们在做什么。w 命令用于显示已经登录系统的用户的名称,以及他们正在做的事。该命令所使用的信息来源于/var/run/utmp文件。

   [alvin@VM_0_16_centos ~]$ w

  16:25:54 up 29 days,  6:05,  6 users,  load average: 0.00, 0.01, 0.05

  USER     TTY      FROM             LOGIN@   IDLE   JCPU   PCPU WHAT

  alvin    pts/0    116.199.***.**   07:25    2.00s  0.11s  0.00s w

  root     pts/1    116.199.***.**   11:05    5:20m  0.02s  0.02s -bash

  alvin    pts/2    116.199.***.**   11:05    5:20m  0.04s  0.05s sshd: alvin [priv]

  harry    pts/3    116.199.***.**   11:06    4:33m 18.08s 18.06s watch date

  kate     pts/4    116.199.***.**   11:08    4:33m 10.51s 10.48s top

  alvin    pts/5    116.199.***.**   11:53    4:32m  0.02s  0.02s -bash

  第一行其实与 uptime 命令出来的结果一样,依次表示:当前时间、系统运行时间、当前系统登录用户数、平均负载。

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

  • USER:显示登陆用户帐号名。用户重复登陆,该帐号也会重复出现。
  • TTY:用户登陆所用的终端。
  • FROM:显示用户在何处登陆系统。
  • LOGIN@:是LOGIN AT的意思,表示登陆进入系统的时间。
  • IDLE:用户空闲时间,从用户上一次任务结束后,开始记时。
  • JCPU:一终端代号来区分,表示在某段时间内,所有与该终端相关的进程任务所耗费的CPU时间。
  • PCPU:指WHAT域的任务执行后耗费的CPU时间。
  • WHAT:表示当前执行的任务

  如果说我们只想查看某个用户当前的行为,我们可以直接在 w 后跟上该用户名:

  [alvin@VM_0_16_centos ~]$ w alvin

  16:34:21 up 29 days,  6:14,  6 users,  load average: 0.00, 0.01, 0.05

  USER     TTY      FROM             LOGIN@   IDLE   JCPU   PCPU WHAT

  alvin    pts/0    116.199.***.**   07:25    5.00s  0.12s  0.06s sshd: alvin [priv]

  alvin    pts/2    116.199.***.**   11:05    5:28m  0.04s  0.05s sshd: alvin [priv]

  alvin    pts/5    116.199.***.**   11:53    4:40m  0.02s  0.02s -bash

   如何知道当前与过去登录系统的用户的信息?

  有些人比较狡猾,做了坏事拒不承认。但是,在 Linux 里,每个用户的登录信息都会 记录起来,这样查找相关人员的责任就有所依据。

  last命令可用于显示特定用户登录系统的历史记录。如果没有指定任何参数,则显示所有用户的历史信息。在默认情况下,这些信息(所显示的信息)将来源于/var/log/wtmp文件。该命令的输出结果包含以下几列信息:

  •   用户名称
  •   tty设备号
  •   历史登录时间日期
  •   登出时间日期
  •   总工作时间

   [alvin@VM_0_16_centos ~]$ last

  alvin    pts/5        116.199.***.**   Sun Dec  9 11:53   still logged in

  kate     pts/4        116.199.***.**   Sun Dec  9 11:08   still logged in

  harry    pts/3        116.199.***.**   Sun Dec  9 11:06   still logged in

  alvin    pts/2        116.199.***.**   Sun Dec  9 11:05   still logged in

  root     pts/1        116.199.***.**   Sun Dec  9 11:05   still logged in

  alvin    pts/0        116.199.***.**   Sun Dec  9 07:25   still logged in

  alvin    pts/0        116.199.***.**   Sat Dec  8 20:42 - 23:10  (02:28)

  alvin    pts/0        119.33.***.**    Mon Dec  3 20:50 - 23:51 (1+03:01)

  alvin    pts/0        119.33.***.**    Thu Nov 29 20:20 - 22:45  (02:24)

  alvin    pts/0        223.104.***.**   Thu Nov 29 06:46 - 07:00  (00:14)

  alvin    pts/0        223.104.***.**   Wed Nov 28 20:45 - 22:27  (01:42)

  alvin    pts/1        14.25.***.***    Sun Nov 25 19:50 - 21:09  (01:18)

  alvin    pts/0        119.33.***.**    Sun Nov 25 16:32 - 21:40  (05:07)

  如果我们只想看某个人的历史记录,则在last后跟上对应的用户名即可:

 [alvin@VM_0_16_centos ~]$ last alvin

  alvin    pts/5        116.199.***.**   Sun Dec  9 11:53   still logged in

  alvin    pts/2        116.199.***.**   Sun Dec  9 11:05   still logged in

  alvin    pts/0        116.199.***.**   Sun Dec  9 07:25   still logged in

  alvin    pts/0        116.199.***.**   Sat Dec  8 20:42 - 23:10  (02:28)

  alvin    pts/0        119.33.***.**    Mon Dec  3 20:50 - 23:51 (1+03:01)

  alvin    pts/0        119.33.***.**    Thu Nov 29 20:20 - 22:45  (02:24)

  alvin    pts/0        223.104.***.**   Thu Nov 29 06:46 - 07:00  (00:14)

  alvin    pts/0        223.104.***.**   Wed Nov 28 20:45 - 22:27  (01:42)

  ** 踢除使坏人员**

  通过以上几个命令,我们可以大概知道某些用户的行为。如果我们想要踢除使坏的人员,可以使用 pkill -u 命令。

 pkill -u alvin

  但这个命令相当危险,有可能导致系统重启,所以不推荐使用这个命令。比较安全的做法是使用 pkill 命令。

  [alvin@VM_0_16_centos ~]$ sudo pkill -kill -t pts/3

  #harry用户已经被踢除了

  [alvin@VM_0_16_centos ~]$ w

  17:04:37 up 29 days,  6:44,  5 users,  load average: 0.00, 0.01, 0.05

  USER     TTY      FROM             LOGIN@   IDLE   JCPU   PCPU WHAT

  alvin    pts/0    116.199.102.65   07:25    5.00s  0.12s  0.00s w

  root     pts/1    116.199.102.65   11:05    5:59m  0.02s  0.02s -bash

  alvin    pts/2    116.199.102.65   11:05    5:59m  0.04s  0.05s sshd: alvin [priv]

  kate     pts/4    116.199.102.65   11:08    5:12m 11.94s 11.91s top

  alvin    pts/5    116.199.102.65   11:53    5:10m  0.02s  0.02s -bash

查看是否存在被锁定账号

//查看所有账号
$cat /etc/passwd
//查看xxx账户状态,是否被锁定
$passwd -S xxx
//锁定xxx账号
$usermod -L xxx

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Wesley13 Wesley13
2年前
java将前端的json数组字符串转换为列表
记录下在前端通过ajax提交了一个json数组的字符串,在后端如何转换为列表。前端数据转化与请求varcontracts{id:'1',name:'yanggb合同1'},{id:'2',name:'yanggb合同2'},{id:'3',name:'yang
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Easter79 Easter79
2年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Wesley13 Wesley13
2年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Stella981 Stella981
2年前
JOptionPane修改图标
1.在Linux平台下.JOptionPane会显示Java默认的图标,在window平台不显示图标,如何替换这个图标了?2JOptionPane.setIcon(Icon)修改的是内容区域的icon,而不是左上角的Icon.所以需要通过修改Jdialog/Frame的图标来达到修改默认图标的问题.3.代码:if(JOptio
为什么mysql不推荐使用雪花ID作为主键
作者:毛辰飞背景在mysql中设计表的时候,mysql官方推荐不要使用uuid或者不连续不重复的雪花id(long形且唯一),而是推荐连续自增的主键id,官方的推荐是auto_increment,那么为什么不建议采用uuid,使用uuid究
Python进阶者 Python进阶者
4个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这