linux查看当前用户信息及其用户切换[通俗易懂]

linux查看当前用户信息及其用户切换[通俗易懂]linux查看当前用户信息及其用户切换一、查看用户信息作为系统管理员,你可能经常会(在某个时候)需要查看系统中有哪些用户正在活动。有些时候,你甚至需要知道他(她)们正在做什么。本文为我们总结了4种查看系统用户信息(通过编号(ID))的方法。使用w命令查看登录用户正在使用的进程信息w命令用于显示已经登录系统的用户的名称,以及他们正在做的事。该命令所使用的信息来源于/var/run/utmp…

大家好,又见面了,我是你们的朋友全栈君。

linux查看当前用户信息及其用户切换

一、查看用户信息

作为系统管理员,你可能经常会(在某个时候)需要查看系统中有哪些用户正在活动。有些时候,你甚至需要知道他(她)们正在做什么。本文为我们总结了4种查看系统用户信息(通过编号(ID))的方法。

  1. 使用w命令查看登录用户正在使用的进程信息
    w命令用于显示已经登录系统的用户的名称,以及他们正在做的事。该命令所使用的信息来源于/var/run/utmp文件。w命令输出的信息包括:
    用户名称
    用户的机器名称或tty号
    远程主机地址
    用户登录系统的时间
    空闲时间(作用不大)
    附加到tty(终端)的进程所用的时间(JCPU时间)
    当前进程所用时间(PCPU时间)
    用户当前正在使用的命令
    w命令还可以使用以下选项
    -h忽略头文件信息
    -u显示结果的加载时间
    -s不显示JCPU, PCPU, 登录时间
[root@localhost /]# w
 11:29:48 up  3:37,  3 users,  load average: 0.00, 0.00, 0.00
USER     TTY      FROM              LOGIN@   IDLE   JCPU   PCPU WHAT
root     tty1     :0               07:55    3:37m  2.14s  2.14s /usr/bin/Xorg :0 -nr -verb
root     pts/0    192.168.19.1     09:42    0.00s  0.38s  0.00s w
root     pts/1    192.168.19.1     09:48    3:31   0.08s  0.08s -bash
[root@localhost /]# w -h
root     tty1     :0               07:55    3:37m  2.14s  2.14s /usr/bin/Xorg :0 -nr -verb
root     pts/0    192.168.19.1     09:42    0.00s  0.38s  0.00s w -h
root     pts/1    192.168.19.1     09:48    3:35   0.08s  0.08s -bash
[root@localhost /]# w -u
 11:29:56 up  3:38,  3 users,  load average: 0.00, 0.00, 0.00
USER     TTY      FROM              LOGIN@   IDLE   JCPU   PCPU WHAT
root     tty1     :0               07:55    3:37m  2.14s  2.14s /usr/bin/Xorg :0 -nr -verb
root     pts/0    192.168.19.1     09:42    0.00s  0.38s  0.00s w -u
root     pts/1    192.168.19.1     09:48    3:39   0.08s  0.08s -bash
[root@localhost /]# w -s
 11:29:59 up  3:38,  3 users,  load average: 0.00, 0.00, 0.00
USER     TTY      FROM               IDLE WHAT
root     tty1     :0                3:37m /usr/bin/Xorg :0 -nr -verbose -audit 4 -auth /
root     pts/0    192.168.19.1      0.00s w -s
root     pts/1    192.168.19.1      3:42  -bash
[root@localhost /]#
  1. 使用who命令查看(登录)用户名称及所启动的进程
    who命令用于列举出当前已登录系统的用户名称。其输出为:用户名、tty号、时间日期、主机地址。
[root@localhost /]# who
root     tty1         2017-11-12 07:55 (:0)
root     pts/0        2017-11-12 09:42 (192.168.19.1)
root     pts/1        2017-11-12 09:48 (192.168.19.1)
[root@localhost /]# 

如果只希望列出用户,可以使用如下语句:

[root@localhost /]# who | cut -d ' ' -f1 | sort
root
root
root
[root@localhost /]# who | cut -d ' ' -f1 | sort | uniq
root
[root@localhost /]#

补充:users命令,可用于打印输出登录服务器的用户名称。该命令除了有help和version选项外,再没有其他选项。如果某用户使用了多个终端,则相应的会显示多个重复的用户名。

[root@localhost /]# users
root root root
[root@localhost /]#
  1. 使用whoami命令查看你所使用的登录名称
    whoami命令用于显示登入的用户名。
[root@localhost /]# whoami
root
[root@localhost /]# who am i
root     pts/0        2017-11-12 09:42 (192.168.19.1)
[root@localhost /]# 

whoami命令的执行效果和id -un的效果完全一样,例如:

[root@localhost /]# id -un
root
[root@localhost /]#

whoami命令能显示当前登入的用户名称,以及当前所使用的tty信息。该命令的输出结果包括如下内容:用户名、tty名、当前时间日期,同时还包括用户登录系统所使用的链接地址。

[root@localhost /]# who am i
root     pts/0        2017-11-12 09:42 (192.168.19.1)
[root@localhost /]# who mom likes
root     pts/0        2017-11-12 09:42 (192.168.19.1)
[root@localhost /]# 

当然,如果你使用su命令改变用户,则该命令(whoami)所显示的结果将随之改变。
4. ** 随时查看系统的历史信息(曾经使用过系统的用户信息)**
last命令可用于显示特定用户登录系统的历史记录。如果没有指定任何参数,则显示所有用户的历史信息。在默认情况下,这些信息(所显示的信息)将来源于/var/log/wtmp文件。该命令的输出结果包含以下几列信息:
用户名称
tty设备号
历史登录时间日期
登出时间日期
总工作时间

[root@localhost /]# last root
root     pts/1        192.168.19.1     Sun Nov 12 09:48   still logged in   
root     pts/0        192.168.19.1     Sun Nov 12 09:42   still logged in   
root     pts/0        192.168.19.1     Sun Nov 12 07:56 - 09:42  (01:45)    
root     tty1         :0               Sun Nov 12 07:55   still logged in   
root     pts/1        192.168.19.1     Thu Nov  9 11:02 - 11:28  (00:26)    
root     pts/0        192.168.19.1     Thu Nov  9 10:47 - 11:28  (00:40)    
root     tty1         :0               Thu Nov  9 10:45 - 11:28  (00:42)    
root     pts/1        192.168.19.1     Thu Nov  9 09:57 - down   (00:23)    
root     pts/0        192.168.19.1     Thu Nov  9 08:55 - down   (01:24)    
root     pts/1        192.168.19.1     Thu Nov  9 07:13 - 08:55  (01:41)    
root     pts/0        192.168.19.1     Thu Nov  9 03:56 - 08:28  (04:32)    
root     pts/1        192.168.19.1     Thu Nov  9 03:04 - 03:54  (00:49)    
root     pts/0        192.168.19.1     Thu Nov  9 03:01 - 03:54  (00:52)    
root     pts/1        192.168.19.1     Thu Nov  9 02:59 - 02:59  (00:00)    
root     pts/0        192.168.19.1     Thu Nov  9 02:56 - 02:59  (00:02)    
root     tty1         :0               Thu Nov  9 02:50 - down   (07:30)    

wtmp begins Thu Nov  9 02:47:58 2017

二、 用户切换

su((switch user的缩写)
格式为:su [ – ] username,后面可以跟 – ,也可以不跟, 区别如下:

su - charles_1, 此时用户切换到charles_1后,环境变量也会跟着更改。也就是说:当输入java -version的时候,jdk版本为1.7,而不是1.8。 之所以是1.7,是因为在进行切换用户的时候,su命令后面加了横杠。如果不加横杠,那么当前用户是:charles_1,但环境变量还是root用户的环境变量。

su charles_1, 此时用户切换到charles_1后,环境变量不会跟着改变,还是root用户的环境变量。输入java -version的时候,jdk版本为1.8

》》》博主长期更新学习心得,推荐点赞关注!!!
》》》若有错误之处,请在评论区留言,谢谢!!!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/133398.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 大白话图解:什么是 CDN[通俗易懂]

    大白话图解:什么是 CDN[通俗易懂]  618电商节、双十一购物狂欢节,到底是什么在支撑数以万计的秒杀活动?这就不得不提一直隐姓埋名的CDN了,注意不是CSDN,而是CDN,CDN,CDN!  那到底CDN是什么鬼,这还要从西天取经说起……  1300年前,唐僧师徒取经要跋涉十万八千里,历经九九八十一难,一路打怪升级,最终才能修成正果,悟空加冕“斗战胜佛”。  1300年后,西游互联网已经开通,雷音寺…

    2025年6月9日
    6
  • Redis分布式锁的三种实现方式_分布式锁解决方案

    Redis分布式锁的三种实现方式_分布式锁解决方案总结写在前面:RLockrLock=redissonClient.getLock(“lbhTestLock”);使用tryLock无参方法时,redisson会自动添加一个定时任务,定时刷新锁的失效时间,如果unlock时失败,则会出现该锁一直不释放的情况。而当tryLock传释放时间时,则不会添加这个定时任务。测试如下:1、tryLock无参数@Testp…

    2022年10月15日
    4
  • Spring contextConfigLocation[通俗易懂]

    Spring contextConfigLocation[通俗易懂]SpringcontextConfigLocation  2012-04-0201:20:56|  分类: Spring |  标签:spring工作积累  |字号 订阅spring如何使用多个xml配置文件 1,在web.xml中定义contextConfigLocation参数.spring会使用这个参数加载.所有逗号分割的xml.如果没有这

    2022年6月14日
    30
  • linux访问服务器端口号命令_ssh的端口号

    linux访问服务器端口号命令_ssh的端口号来源:http://blog.csdn.net/u013943420/article/details/65938696大家在学习计算机的时候,对于最常用的几个端口比如80端口肯定有很深的印象,但是对于其他一些不是那么常用的端口可能就没那么了解。所以,在一些使用频率相对较高的端口上,很容易会引发一些由于陌生而出现的错误,或者被黑客利用某些端口进行入侵。对于这件事情,大部分人都很头疼——……

    2025年11月5日
    6
  • 4399积分小游戏大全_4399小游戏大全手机版

    4399积分小游戏大全_4399小游戏大全手机版近日有研究4399的积分小游戏的分数提交规则,但不能太高调的对做类似外挂的东西…写以下代码..仅供分析研究1db=MySql::getInstance();14}1516fu

    2022年8月3日
    6
  • 汇编语言中各种移位指令的区别与联系

    汇编语言中各种移位指令的区别与联系本文转载自:https://blog.csdn.net/richerg85/article/details/27558005SHL、SHR、SAL、SAR:移位指令;SHL(ShiftLeft):   逻辑左移;SHR(ShiftRight):   逻辑右移;SAL(ShiftArithmeticLeft):算术左移;SAR(Shift…

    2022年6月9日
    26

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号