linux学习之用户管理

这篇博客详细介绍了Linux系统中用户管理的相关操作,包括查看当前用户、登录用户、添加和删除用户、设置用户密码、切换用户、查看用户组、修改文件权限等。通过useradd、passwd、userdel、su、chmod等命令,深入理解Linux用户管理和权限控制。
摘要由CSDN通过智能技术生成

1.查看当前用户 whoami

[root@jira ~]# whoami   #查询当前用户
root
[root@jira ~]# su oracle   #切换用户
[oracle@jira root]$ whoami  #当前用户已切换
oracle

2.查看登录用户: who

who命令用于查看当前所有登录系统的用户信息。

选项含义
-m或am只显示运行who命令的用户名,登录终端和登录时间
-q或–count只显示用户的登录账号和登录用户的数量
-u或–heading显示列标题
[oracle@jira root]$ who #查看登录用户和IP来源
root     pts/1        2020-04-23 17:48 (210.72.241.26)
[oracle@jira root]$ who -m  #只显示运行who命令的这个用户信息
root     pts/1        2020-04-23 17:48 (210.72.241.26)
[oracle@jira root]$ who -q #显示所有用户的登录账号和用户数量
root
# users=1
[oracle@jira root]$ who -u  #跟运行who差不多
root     pts/1        2020-04-23 17:48   .         19566 (210.72.241.26)

3.退出登录: exit

[root@jira ~]# exit 
logout
[root@jira ~]# su oracle  #切换用户
[oracle@jira root]$ who
root     pts/1        2020-04-23 18:09 (210.72.241.26)
[oracle@jira root]$ exit  #退出回到了root用户
exit
[root@jira ~]# 

4.添加用户: useradd

Linux中添加用户账号可以使用useradd命令,useradd命令的使用格式如下: useradd[参数]新建用户账号

参数含义
-d指定用户登录系统时的主目录,如果不使用该参数,系统自动在/home目录下建立与用户名同名目录为主目录
-m自动建立目录
-g指定组名称

注意: Linux每个用户都要有一个主目录,主目录就是第一次登陆系统,用户的默认当前目录(/home/用户); 每一个用户必须有一个主目录,所以用useradd创建用户的时候,一定给用户指定一个主目录; 用户的主目录一般要放到根目录的home目录下,用户的主目录和用户名是相同的; 如果创建用户的时候,不指定组名,那么系统会自动创建一个和用户名一样的组名。

命令含义
useradd -d /home/awen awen -m创建awen用户,如果/home/awen目录不存在,就自动创建这个目录,同时用户属于awen组
useradd -d /home/awen awen -g zhiliao -m创建一个用户名为awen,主目录在/home/awen,如果主目录不存在就创建主目录,同时用户属于zhiliao组
cat /etc/passwd查看当前系统所有的用户
cat /etc/passwd    #查看当前有多少个用户
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
polkitd:x:999:998:User for polkitd:/:/sbin/nologin
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
chrony:x:998:996::/var/lib/chrony:/sbin/nologin
ntp:x:38:38::/etc/ntp:/sbin/nologin
tcpdump:x:72:72::/:/sbin/nologin
nscd:x:28:28:NSCD Daemon:/:/sbin/nologin
jira:x:1000:1000:Atlassian JIRA:/home/jira:/bin/bash
mysql:x:27:27:MySQL Server:/var/lib/mysql:/bin/false
oracle:x:1001:1002::/home/oracle:/bin/bash
tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin
[root@jira ~]# useradd -d /home/xuxu xuxu -m #创建一个用户xuxu,用户组为xuxu
[root@jira ~]# useradd -d /home/aaa zhiliao -m #创建一个用户aaa,用户组为zhiliao
ls /home/
aaa                  atlassian-jira-software-8.1.0-x64.bin  jdk-8u172-linux-x64.tar.gz  mysql57-community-release-el7-10.noarch.rpm  mysql-connector-java-5.1.47.tar.gz  xuxu
atlassian-agent.jar  ceshilearn                             jira                        mysql-connector-java-5.1.47                  oracle
[root@jira ~]# cat /etc/passwd   #新增了两个用户
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
polkitd:x:999:998:User for polkitd:/:/sbin/nologin
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
chrony:x:998:996::/var/lib/chrony:/sbin/nologin
ntp:x:38:38::/etc/ntp:/sbin/nologin
tcpdump:x:72:72::/:/sbin/nologin
nscd:x:28:28:NSCD Daemon:/:/sbin/nologin
jira:x:1000:1000:Atlassian JIRA:/home/jira:/bin/bash
mysql:x:27:27:MySQL Server:/var/lib/mysql:/bin/false
oracle:x:1001:1002::/home/oracle:/bin/bash
tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin
xuxu:x:1002:1003::/home/xuxu:/bin/bash
zhiliao:x:1003:1004::/home/aaa:/bin/bash

5.设置用户密码: passwd

在Linux中,root(也叫超级用户)用户可以使用passwd命令为普通用户设置或修改用户口令,用户也可以直接使用该命令来修改自己的口令,而无需在命令后面使用用户名.

[root@jira ~]# passwd xuxu #修改和创建用户xuxu的密码,不需要提供旧密码,就可以直接修改
Changing password for user xuxu.
New password: 
BAD PASSWORD: The password is shorter than 8 characters  #虽然提示了密码很简单,但是还是可以修改成功的
Retype new password: 
passwd: all authentication tokens updated successfully.

6.删除用户: userdel

命令含义
userdel xuxu(用户名)删除xuxu用户,但不会自动删除用户的主目录
userdel -r aaa(用户名))删除aaa用户并删除用户的主目录
[root@jira aaa]# ls /home  #两个用户目录 xuxu,zhiliao
aaa                  atlassian-jira-software-8.1.0-x64.bin  jdk-8u172-linux-x64.tar.gz  mysql57-community-release-el7-10.noarch.rpm  mysql-connector-java-5.1.47.tar.gz  xuxu
atlassian-agent.jar  ceshilearn                             jira                        mysql-connector-java-5.1.47                  oracle                              zhiliao
[root@jira aaa]# userdel zhiliao  删除用户zhiliao,但是并没有删除/home下的zhiliao目录
[root@jira aaa]# ls /home
aaa                  atlassian-jira-software-8.1.0-x64.bin  jdk-8u172-linux-x64.tar.gz  mysql57-community-release-el7-10.noarch.rpm  mysql-connector-java-5.1.47.tar.gz  xuxu
atlassian-agent.jar  ceshilearn                             jira                        mysql-connector-java-5.1.47                  oracle                              zhiliao
[root@jira aaa]# userdel -r xuxu #加上-r参数后,xuxu用户目录彻底删除
[root@jira aaa]# ls /home/
aaa                  atlassian-jira-software-8.1.0-x64.bin  jdk-8u172-linux-x64.tar.gz  mysql57-community-release-el7-10.noarch.rpm  mysql-connector-java-5.1.47.tar.gz  zhiliao
atlassian-agent.jar  ceshilearn                             jira                        mysql-connector-java-5.1.47                  oracle

7.切换用户: su

可以通过su命令切换用户,su后面可以加“-”。su和su –命令不同之处在于,su -切换到对应的用户时会将当前的工作目录自动转换到切换后的用户主目录:

[root@jira aaa]# pwd  #我在的当前目录
/home/aaa
[root@jira aaa]# su zhiliao2  #切换到zhiliao2用户
[zhiliao2@jira aaa]$ pwd   #还是在/home/aaa目录,目录没变
/home/aaa
[zhiliao2@jira aaa]$ exit
exit
[root@jira aaa]# su - zhiliao2  #加上-直接到了/home/zhiliao主目录
zhiliao2
Last login: Sat Apr 25 11:35:51 CST 2020 on pts/1
[zhiliao2@jira ~]$ pwd
/home/zhiliao

命令含义:su|切换到root用户| |su root|跟su一样也是切换到root用户| |su -|切换到root用户,同时切换目录到/root| |su - root|切换root用户,同时切换到目录到/root| |su 普通用户|切换到普通用户| |su - 普通用户|切换到普通用户,同时切换普通用户所在的目录|

8.查看用户组

[zhiliao2@jira ~]$ cat /etc/group
root:x:0:
bin:x:1:
daemon:x:2:
sys:x:3:
adm:x:4:
tty:x:5:
disk:x:6:
lp:x:7:
mem:x:8:
kmem:x:9:
wheel:x:10:
cdrom:x:11:
mail:x:12:postfix
man:x:15:
dialout:x:18:
floppy:x:19:
games:x:20:
tape:x:33:
video:x:39:
ftp:x:50:
lock:x:54:
audio:x:63:
nobody:x:99:
users:x:100:
utmp:x:22:
utempter:x:35:
input:x:999:
systemd-journal:x:190:
systemd-network:x:192:
dbus:x:81:
polkitd:x:998:
ssh_keys:x:997:
sshd:x:74:
postdrop:x:90:
postfix:x:89:
chrony:x:996:
ntp:x:38:
tcpdump:x:72:
nscd:x:28:
jira:x:1000:
mysql:x:27:
oinstall:x:1001:
dba:x:1002:
tss:x:59:
zhiliao2:x:1005:

9.添加,删除组账号: groupadd,groupdel

[root@jira ~]# groupadd ceshixuxu  #添加组
[root@jira ~]# cat /etc/group
root:x:0:
bin:x:1:
daemon:x:2:
sys:x:3:
adm:x:4:
tty:x:5:
disk:x:6:
lp:x:7:
mem:x:8:
kmem:x:9:
wheel:x:10:
cdrom:x:11:
mail:x:12:postfix
man:x:15:
dialout:x:18:
floppy:x:19:
games:x:20:
tape:x:33:
video:x:39:
ftp:x:50:
lock:x:54:
audio:x:63:
nobody:x:99:
users:x:100:
utmp:x:22:
utempter:x:35:
input:x:999:
systemd-journal:x:190:
systemd-network:x:192:
dbus:x:81:
polkitd:x:998:
ssh_keys:x:997:
sshd:x:74:
postdrop:x:90:
postfix:x:89:
chrony:x:996:
ntp:x:38:
tcpdump:x:72:
nscd:x:28:
jira:x:1000:
mysql:x:27:
oinstall:x:1001:
dba:x:1002:
tss:x:59:
zhiliao2:x:1005:
ceshixuxu:x:1006:
[root@jira ~]# groupdel ceshixuxu   删除组
[root@jira ~]# cat /etc/group
root:x:0:
bin:x:1:
daemon:x:2:
sys:x:3:
adm:x:4:
tty:x:5:
disk:x:6:
lp:x:7:
mem:x:8:
kmem:x:9:
wheel:x:10:
cdrom:x:11:
mail:x:12:postfix
man:x:15:
dialout:x:18:
floppy:x:19:
games:x:20:
tape:x:33:
video:x:39:
ftp:x:50:
lock:x:54:
audio:x:63:
nobody:x:99:
users:x:100:
utmp:x:22:
utempter:x:35:
input:x:999:
systemd-journal:x:190:
systemd-network:x:192:
dbus:x:81:
polkitd:x:998:
ssh_keys:x:997:
sshd:x:74:
postdrop:x:90:
postfix:x:89:
chrony:x:996:
ntp:x:38:
tcpdump:x:72:
nscd:x:28:
jira:x:1000:
mysql:x:27:
oinstall:x:1001:
dba:x:1002:
tss:x:59:
zhiliao2:x:1005:

10.查看用户在哪个组

[root@jira ~]# id zhiliao2 #两个方法groups和id
uid=1004(zhiliao2) gid=1005(zhiliao2) groups=1005(zhiliao2)
[root@jira ~]# groups zhiliao2
zhiliao2 : zhiliao2

11.修改文件权限: chmod

chmod --修改文件权限
两种写法 chmod [-R] ±= rwx- //filename chmod [-R] 755 //filename

参数含义
uuser表示该文件的所有者
ggroup表示该文件的所属组,用户组
oother 表示其他人 就是就是任何人
aall表示三者都给权限

|参数| 含义| |+| 增加权限| |-| 撤销权限| |=| 设定权限|

|参数| 含义| |r|read 表示可读取,对于一个目录,如果没有r权限,那么就意味着不能通过ls查看这个目录的内容。就是不能读取这个文件| |w| write 表示可写入,对于一个目录,如果没有w权限,那么就意味着不能在目录下创建新的文件。如果对文件没有w权限就不能修改文件| |x| excute 表示可执行,对于一个目录,如果没有x权限,那么就意味着不能通过cd进入这个目录。如果是一个脚本就不能运行|

|数字表示| 说明 |

数字表示说明
r读取权限,数字可使用’4’
w写入权限,数字可使用’2’
x执行权限,数字代号为’1’
-不具备任何权限,数字代号为’0‘
[root@jira ~]# touch a.sh
[root@jira ~]# ll
total 0
-rw-r--r-- 1 root root 0 Apr 25 13:43 a
-rw-r--r-- 1 root root 0 Apr 25 13:46 a.sh

[root@jira ~]# chmod u=rwx,g=rx,o=rx a.sh 
[root@jira ~]# ll
total 0
-rw-r--r-- 1 root root 0 Apr 25 13:43 a
-rwxr-xr-x 1 root root 0 Apr 25 13:46 a.sh
[root@jira ~]# touch b.sh
[root@jira ~]# ll
total 0
-rw-r--r-- 1 root root 0 Apr 25 13:43 a
-rwxr-xr-x 1 root root 0 Apr 25 13:46 a.sh
-rw-r--r-- 1 root root 0 Apr 25 13:49 b.sh
[root@jira ~]# chmod 777 b.sh 
[root@jira ~]# ll
total 0
-rw-r--r-- 1 root root 0 Apr 25 13:43 a
-rwxr-xr-x 1 root root 0 Apr 25 13:46 a.sh
-rwxrwxrwx 1 root root 0 Apr 25 13:49 b.sh


[root@jira ~]# touch ccc.sh
[root@jira ~]# ll
total 0
-rw-r--r-- 1 root root 0 Apr 25 13:43 a
-rwxr-xr-x 1 root root 0 Apr 25 13:46 a.sh
-rwxrwxrwx 1 root root 0 Apr 25 13:49 b.sh
-rw-r--r-- 1 root root 0 Apr 25 13:56 ccc.sh
[root@jira ~]# chmod u+x ccc.sh 
[root@jira ~]# chmod u+x,g+wx,o+rwx ccc.sh 
[root@jira ~]# ll
total 0
-rw-r--r-- 1 root root 0 Apr 25 13:43 a
-rwxr-xr-x 1 root root 0 Apr 25 13:46 a.sh
-rwxrwxrwx 1 root root 0 Apr 25 13:49 b.sh
-rwxrwxrwx 1 root root 0 Apr 25 13:56 ccc.sh

说明: chmod u=rwx,g=rx,o=rx filename 就等同于:chmod u=7,g=5,o=5 filename chmod 755 file:

文件所有者: r w x

同组用户: r x

其它用户: r x 如果要递归授权可以加上参数“-R” 如: chmod 777 test/ -R 给test目录下面所有的文件和目录加上777权限

修改文件所有者: chown

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值