Linux用户权限管理

安全上下文 (secure context):

用户:#UID /etc/passwd
组:#GID   /etc/group
影子口令:
用户:#/etc/shadow
组:  #/etc/gshadow

用户类别:

管理员:#0
普通用户:#1-65535
系统用户:#1-499(不允许登录)
一般用户:#500-60000

用户组类别:

私有组:#创建用户时,如果没有为其指定所属的组,系统会自动为其创建一个与用户名同名的组
基本组:#用户的默认组
附加组:#额外组:默认组意外的其他组 /etc/passwd
account:#登录名
password:#密码
UID:
GID:#基本组ID
comment:#注释
HOME DIR:#家目录
SHELL:#用户默认shell
/etc/shadow
account:#登录名
encrypted password:#加密的密码

用户管理:

useradd,userdel,usermod,passwd,chsh,chfn,finger,id,chage
useradd [options] USERNAME 

-u:#UID
-g:#GID(基本组)
-G:#GID(附加组,可添加多个使用,号隔开)
-c:#"COMMENT" 指定注释信息
-d:#/path/to/directory
-M:#不为用户创建家目录
-r: #添加系统用户
-s:#shell路径(echo $SHELL:查看当前shell)指定shell路径(/etc/shells:指定了当前系统可以的安全shell)

userdel
userdel [options] USERNAME 
-r:#同时删除用户的家目录

usermod:修改用户账户属性
usermod [options] USERNAME
-u:#UID
-g:#GID
-a -G:#GID不使用-a会覆盖此前的附加组,使用-a -g为用户原有基础上追加附加组)
-c:#指定注册信息
-m -d:#既指定新的家目录,又移动此前的文件
-s:#修改用户的shell
-l:#修改用户登录名称
-L:#锁定帐号
-U:#解锁帐号
chsh:#修改用户的默认shell    #chsh USERNAME
chfn:#修改用户注释信息       #chfn USERNAME
finger:#查看用户帐号信息
finger USERNAME

密码管理:

passwd [USERNAME]  --stdin
echo "passwd" | passwd --stdin USERNAME
-l:#锁定
-u:#解锁
-d:#删除用户密码
openssl passwd -1 -salt '123456789'    生成8位加密密码(单项加密)
pwck:检查用户帐号完整性

组密码管理:


groupadd,grouopdel,groupmod gpasswd
group [options] USERNAME 

groupadd:#创建组
-g:#GID
-r:#添加系统组

groupmod:#修改组信息
-g:#修改GID
-n:#修改组名

groupdel:#删除组
gpasswd:#为组设定密码
newgrp GRPNAME <--> exit:短暂为用户添加为基本组
chage [options] user
-d:#最近一次的修改时间
-E:#过期时间
-I:#非活动时间
-m:#最短使用期限
-M:#最长使用期限
-w:#警告时间

权限管理:

文件权限:r,w,x
r:#可读,可以使用类似cat等命令查看文件内容
w:#可写,可以编辑或删除此文件
x:#可执行,可以命令提示符下当作命令提交给内核运行


目录权限:
r:#可以对此目录执行ls以列出内部的所有文件
w:#可以在此目录创建文件
x:#可以使用cd切换进此目录,也可以使用ls -l查看内部文件的详细信息
0 000 ---:#无权限
1 001 --x:#执行
2 010 -w-:#写
3 011 -wx:#写和执行
4 100 r--:#读
5 101 r-x:#读和执行
6 110 rw-:#读写
7 111 rwx:#读写执行


管理命令详解:
chown,chgrp,chmod,umask
chown:#修改属主(只有管理员可以使用此命令)
chown USERNAME  file
-R:#修改目录及其内部文件的属主
--reference=/path/smile file:#参考某个文件,设定跟参考文件属主一样
chown USERNAME:GRPNAME file #同时改变文件属主属组
chown USERNAME.GRPNAME file
chown :GRPNAME  file #单独改变属组
chown USERNAME: #file单独改变属主

chgrp:#修改属组(只有管理员可以使用此命令)
chown USERNAMEfile
-R:#修改目录及其内部文件的属组
--reference=/path/smile file:#参考某个文件,设定跟参考文件属组一样

chmod:#修改文件的权限
-R:#修改目录及其内部文件的属组
修改三类用户的权限:
修改某类用户或某些类用户权限:
修改某类用户的某位或某些位权限:

umask:#反向掩码
666-umask:#创建文件权限
777-umask:#创建目录权限
文件默认不能具有执行权限,如果算得的结果中有执行权限,则将其权限加1;

站在用户登录的角度来说,SHELL的类型:

登录式shell:
正常通过某终端登录:
su - USERNAME
su - l USERNAME


非登录式shell:
su USERNAME
图形终端下打开命令窗口
自动执行的shell脚本


登录式shell如何读取配置文件?
# /etc/profile --> /etc/profile.d/*sh --> ~/.bash_profile --> ~/.bashrc --> /etc/bashrc

非登录式shell如何读取配置文件?
# ~/.bashrc --> /etc/bashrc --> .etc.profile.d/*.sh


bash的配置文件:(一般作用范围越小越优先)
全局配置(对所有用户都生效)
#/etc/profile, /etc/profile.d/*.sh, /etc/bashrc


个人配置:(只针对当前用户本身)
# ~/.bashrc_profile, ~/.bashrc


profile类的文件:
#设定环境变量
#运行命令或脚本


bashrc类的文件:
#设定本地变量
#定义命令别名

你可能感兴趣的:(linux,用户权限)