经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » Linux/Shell » 查看文章
Linux系统查看所有用户命令
来源:cnblogs  作者:码农先锋  时间:2021/1/18 16:19:11  对本文有异议

使用过 Linux 系统的同学都知道,Windows 系统跟 Linux 系统是有很大差别的,就拿本篇文章即将要说的查看系统用户来说,在 Windows 系统中查看用户直接鼠标右击电脑属性,然后会有用户和用户组。而 Linux 是纯命令行的,怎么查找用户呢?这就是本文需要说明的。

看过之前文章的朋友都是知道有专门说过 useradd 这个命令,这个命令就是专门新建用户的。当我们使用 useradd 这个命令新建用户之后,/etc/passwd 就会存有这个用户的相关信息,并且还有 /etc/shadow 这个文件会存放用户密码相关的信息。

image-20201128050226812

可以看到,这两个文件都是存放有用户信息的,但是除了用户信息之外还有一些其他的内容,如果我们只想了解用户名该怎么处理,那么这就需要用到组合命令了,如下:

  1. $ cat /etc/passwd | head -5 | cut -f1 -d:

image-20201128050715273

在上面的示例中, head 这个命令就是提取 /etc/passwd 文件的前五行内容。| 这个符号我们把它叫做管道符,它的作用就是将前一个命令的输出作为后一个命令的输入,这样就很好理解上面的命令为什么只显示前五行。之后我们又用了 cut 这个命令,这个命令的作用就是截取的意思,-d 选项指定分隔符,这里以 : 作为分割,-f 指定列,也就是以冒号为分隔符,截取第一列的内容,这一长串命令结合起来,就拿到了当前系统中所有已经创建的用户名。

我们作为 Linux 系统管理员,可能很多时候都需要查看当前系统中的活动用户。甚至有时候需要知道这些用户在做什么,以下四种方法分享给大家:

1. w

是的,这是一个字母但同时也是一个命令,w 这个命令的作用就是显示当前已经登录到系统中的用户的名称,以及目前有的操作。

  1. $ w
  2. 07:16:05 up 3 days, 19:00, 2 users, load average: 0.01, 0.08, 0.08
  3. USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT
  4. root pts/0 123.139.156.117 Thu22 0.00s 0.27s 0.00s w
  5. root pts/1 123.139.156.117 21:29 8:23m 0.02s 0.02s -bash

w 这个命令输出的信息都是来自 /var/run/utmp 这个文件的。该命令的输出信息可以看到有很多列,分别是:

USER:表示用户的名称

TTY:表示计算机终端设备

FROM:表示远程主机的地址

LOGIN@:系统登陆的时间

IDLE:登陆系统的空闲时间

WHAT:表示用户正在使用的命令

2. who

这个命令从名字就可以看出来它的作用,即打印当前登录的用户。

  1. $ who
  2. root pts/0 2020-11-26 22:12 (123.139.156.117)
  3. root pts/1 2020-11-27 21:29 (123.139.156.117)

who 命令的输出分别为:登录的用户名、设备号、登录的时间日期以及主机地址。同样的,如果指向查看用户列,那么:

  1. $ who | cut -d' ' -f1
  2. root
  3. root

有了开头的相关介绍,相信这个组合命令大家也很好理解。

3. whoami

这个命令是不是看起来更直接,它的作用就是打印出当前正在登录系统的用户,只会显示用户名,没有任何多余的输出。

  1. $ whoami
  2. root

image-20201128073949576

4. last

这个命令就比较厉害了,它可以打印出曾经登陆或使用系统的用户信息。如果不指定参数,默认会显示所有登录的历史信息,一般这些信息所显示的内容都来自 /var/log/wtmp 这个文件。

  1. [user5@VM-4-10-centos ~]$ last
  2. root pts/1 123.139.156.117 Fri Nov 27 21:29 still logged in
  3. root pts/0 123.139.156.117 Thu Nov 26 22:12 still logged in
  4. reboot system boot 4.14.105-19-0016 Tue Nov 24 12:15 - 07:45 (3+19:29)
  5. root pts/0 111.206.145.26 Thu Sep 24 18:11 - 18:11 (00:00)
  6. root pts/0 111.206.145.26 Thu Sep 24 18:09 - 18:10 (00:01)
  7. reboot system boot 4.14.105-19-0016 Thu Sep 24 18:07 - 18:25 (00:18)
  8. reboot system boot 4.14.105-19-0016 Thu Sep 24 18:06 - 18:25 (00:19)
  9. root pts/0 111.206.145.26 Thu Sep 24 17:13 - crash (00:52)

可以看到,这个信息的输出还是蛮多列的,不用每一列都进行关注,可以将重点放到第一列登录的用户上,还有远程的地址以及登陆时间,还有最后两列分别是登出的日期时间跟总共的一个工作时间,还有当前状态的显示,就比如我开了两个终端且都是使用 root 用户在登录,因此在一直没有登出的情况就会题示 "still logged in" 的状态。

本篇文章主要以查看 Linux 系统的用户为重点进行展开说明,Linux 系统一般都是用作服务器的,上面运行着比较重要的业务,一定保证其安全可靠,所以定期查看以下当前用户登录以及操作的情况是很有必要的。

本文由博客一文多发平台 OpenWrite 发布!

原文链接:http://www.cnblogs.com/manongxianfeng/p/14284714.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号