通过使用/etc/passwd
文件,getent
命令,compgen
命令这三种方法查看系统中用户的信息。
linux 系统中用户信息存放在/etc/passwd
文件中。
这是一个包含每个用户基本信息的文本文件。当我们在系统中创建一个用户,新用户的详细信息就会被添加到这个文件中。
/etc/passwd
文件将每个用户的基本信息记录为文件中的一行,一行中包含 7 个字段。
/etc/passwd
文件的一行代表一个单独的用户。该文件将用户的信息分为 3 个部分。
* 第 1 部分:`root` 用户信息* 第 2 部分:系统定义的账号信息* 第 3 部分:真实用户的账户信息
第一部分是 root 账户,这代表管理员账户,对系统的每个方面都有完全的权力。
第二部分是系统定义的群组和账户,这些群组和账号是正确安装和更新系统软件所必需的。
第三部分在最后,代表一个使用系统的真实用户。
在创建新用户时,将修改以下 4 个文件。
* `/etc/passwd`: 用户账户的详细信息在此文件中更新。* `/etc/shadow`: 用户账户密码在此文件中更新。* `/etc/group`: 新用户群组的详细信息在此文件中更新。* `/etc/gshadow`: 新用户群组密码在此文件中更新。
方法 1 :使用 /etc/passwd 文件
使用任何一个像cat
、more
、less
等文件 *** 作命令来打印 linux 系统上创建的用户列表。
/etc/passwd
是一个文本文件,其中包含了登录 linux 系统所必需的每个用户的信息。它保存用户的有用信息,如用户名、密码、用户 ID、群组 ID、用户 ID 信息、用户的家目录和 Shell 。
/etc/passwd
文件将每个用户的详细信息写为一行,其中包含七个字段,每个字段之间用冒号 : 分隔:
# cat /etc/passwdroot:x:0:0:root:/root:/bin/bashbin:x:1:1:bin:/bin:/sbin/nologindaemon:x:2:2:daemon:/sbin:/sbin/nologinadm:x:3:4:adm:/var/adm:/sbin/nologinlp:x:4:7:lp:/var/spool/lpd:/sbin/nologinsync:x:5:0:sync:/sbin:/bin/syncshutdown:x:6:0:shutdown:/sbin:/sbin/shutdownhalt:x:7:0:halt:/sbin:/sbin/haltmail:x:8:12:mail:/var/spool/mail:/sbin/nologinftp:x:14:50:FTP User:/var/ftp:/sbin/nologinpostfix:x:89:89::/var/spool/postfix:/sbin/nologinsshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologintcpdump:x:72:72::/:/sbin/nologin2gadmin:x:500:10::/home/viadmin:/bin/bashapache:x:48:48:Apache:/var/www:/sbin/nologinzabbix:x:498:499:Zabbix Monitoring System:/var/lib/zabbix:/sbin/nologinMysqL:x:497:502::/home/MysqL:/bin/bashZend:x:502:503::/u01/Zend/Zend/gui/lighttpd:/sbin/nologinrpc:x:32:32:Rpcbind Daemon:/var/cache/rpcbind:/sbin/nologin2daygeek:x:503:504::/home/2daygeek:/bin/bashnamed:x:25:25:named:/var/named:/sbin/nologinmageshm:x:506:507:2g admin - Magesh M:/home/mageshm:/bin/bash
7 个字段的详细信息如下。
**用户名 (magesh): 已创建用户的用户名,字符长度 1 个到 12 个字符。**密码(x):代表加密密码保存在 `/etc/shadow 文件中。**用户 ID(506):代表用户的 ID 号,每个用户都要有一个唯一的 ID 。UID 号为 0 的是为 root 用户保留的,UID 号 1 到 99 是为系统用户保留的,UID 号 100-999 是为系统账户和群组保留的。**群组 ID (507):代表群组的 ID 号,每个群组都要有一个唯一的 GID ,保存在 /etc/group文件中。**用户信息(2g admin - Magesh M):代表描述字段,可以用来描述用户的信息(LCTT 译注:此处原文疑有误)。**家目录(/home/mageshm):代表用户的家目录。**Shell(/bin/bash):代表用户使用的 shell 类型。
你可以使用 awk 或 cut 命令仅打印出 linux 系统中所有用户的用户名列表。显示的结果是相同的。
# awk -F‘:‘ ‘{ print }‘ /etc/passwdor# cut -d: -f1 /etc/passwdrootbindaemonadmlpsyncshutdownhaltmailftppostfixsshdtcpdump2gadminapachezabbixMysqLZendrpc2daygeeknamedmageshm
方法 2 :使用 getent 命令
getent
命令显示name Service Switch
库支持的数据库中的条目。这些库的配置文件为/etc/nsswitch.conf
。
getent
命令显示类似于/etc/passwd
文件的用户详细信息,它将每个用户详细信息显示为包含七个字段的单行。
# getent passwdroot:x:0:0:root:/root:/bin/bashbin:x:1:1:bin:/bin:/sbin/nologindaemon:x:2:2:daemon:/sbin:/sbin/nologinadm:x:3:4:adm:/var/adm:/sbin/nologinlp:x:4:7:lp:/var/spool/lpd:/sbin/nologinsync:x:5:0:sync:/sbin:/bin/syncshutdown:x:6:0:shutdown:/sbin:/sbin/shutdownhalt:x:7:0:halt:/sbin:/sbin/haltmail:x:8:12:mail:/var/spool/mail:/sbin/nologinftp:x:14:50:FTP User:/var/ftp:/sbin/nologinpostfix:x:89:89::/var/spool/postfix:/sbin/nologinsshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologintcpdump:x:72:72::/:/sbin/nologin2gadmin:x:500:10::/home/viadmin:/bin/bashapache:x:48:48:Apache:/var/www:/sbin/nologinzabbix:x:498:499:Zabbix Monitoring System:/var/lib/zabbix:/sbin/nologinMysqL:x:497:502::/home/MysqL:/bin/bashZend:x:502:503::/u01/Zend/Zend/gui/lighttpd:/sbin/nologinrpc:x:32:32:Rpcbind Daemon:/var/cache/rpcbind:/sbin/nologin2daygeek:x:503:504::/home/2daygeek:/bin/bashnamed:x:25:25:named:/var/named:/sbin/nologinmageshm:x:506:507:2g admin - Magesh M:/home/mageshm:/bin/bash
7 个字段的详细信息如上所述。
你同样可以使用 awk
或 cut
命令仅打印出 linux 系统中所有用户的用户名列表。显示的结果是相同的。
方法 3 :使用 compgen 命令
compgen 是 bash 的内置命令,它将显示所有可用的命令,别名和函数。
# compgen -urootbindaemonadmlpsyncshutdownhaltmailftppostfixsshdtcpdump2gadminapachezabbixMysqLZendrpc2daygeeknamedmageshm
总结 以上是内存溢出为你收集整理的查看linux中所有用户的三种方式全部内容,希望文章能够帮你解决查看linux中所有用户的三种方式所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)