linux中用户、组的管理(密码管理、权限管理及其修改用户、组)
2013-03-03 20:34
531 查看
process(进程) 1 计算资源 权限 用户(获取资源或服务的凭证或标识) 用户,容器,关联权限:用户组(标识符),方便地指派权限 2 用户、组、权限 安全上下文(secure context): 权限:r,w,x 文件: r:可读,可以使用类似 cat等命令查看文件内容; w:可写,可以编辑或删除此文件; x:可执行,eXacutable,可以命令提示符下当作命令提交给内核运行; 3 目录 r:可以对此目录执行ls以列出内部的所有文件; w:可以在此目录创建文件; x:可以使用cd切换进此目录,也可使用ls -l查看内部文件的详细信息; rwx: r--:只读 r-x:读和执行 ---:无权限 0 000 ---:无权限 1 001 --x:执行 2 010 -w-:写 3 011 -wx:写和执行 4 100 r--:只读 5 101 r-x:读和执行 6 110 rw-:读写 7 111 rwx:读写执行 eg:755:rwxr-xr-x rw-r-----:640 660:rw-rw---- rwxrwr-x:775 用户:UID,/etc/passwd 组 :GID,/etc/group 影子口令:etc/shadow 组:/etc/gshadow 4 用户类别 管理员:0 普通用户:1-65535 系统用户:1-499 一般用户:500-60000 用户组类别: 管理员组: 普通组:(包括系统组和一般组) 用户组类别: 私有组:创建用户时,如果没有为其指定所属的组,系统会自动为其创建一个与用户名同名的组 基本组:用户的默认组 附件组,额外组:默认组以外的其它组 5 解析:名称解析 /etc/passwd account:登录名 password:密码 UID:用户组ID GID:基本组ID comment:注释 HOME DIR:家目录 SHELL:用户的默认shell /etc/shadow account:登录名 encrypted password:加密的密钥 6 加密方法 对称加密:加密和解密使用同一个密钥 公钥加密:每个密码都成对儿出现,一个为私钥(secret key),一个为公钥(publickey),公钥加密做密钥交换 单项加密,散列加密:提取数据特征码,常用于数据完整性校验,单项加密不可逆 1.雪崩效应(初始条件的微小改变将会引起结果的巨大改变) 2.定长输出 MD5:Message Digest9(信息摘要),128位定长输出 SHA1:Secure Hash Algorithm(安全的哈希算法),160位定长输出 eg:which useradd ls -l useradd 查看当前用户下useradd命令 ls -l $(which useradd) ls -l ’which useradd‘ /etc/passwd: 用户名:密码:GUI:GID 注释: 家目录:默认SHELL /etc/group: 组名:密码:GID:以此组为其附加组的用户列表 /etc/shadow: 用户名:密码:最近一次修改密码的时间:最短使用期限:最长使用期限:警告时间:非活动时间:过期时间 7 useradd [options] USERNAME -u UID:指定选项(普通用户ID>=500) -g GID(基本组) -G GID,...(附加组或额外组,组必须事先存在,组可以有多个,彼此间用“,”隔开) -c "COMMENT":指定用户注释信息 eg:useradd -c "Tom" -d /home/blear user4 -d /path/to/somedirectory:指定家目录 -r 添加系统用户 -s SHELL:指定SHELL路径 eg:useradd -s /sbin/nologin user5 su user5 cat /etc/shells (利用echo $shell可以查看自己的shell是什么) /etc/shells :指定了当前系统可用的安全的shell -M :不为用户创建家目录 就算/etc/login.defs下设定家目录也不创建 -m :强制为用户创建家目录 -k :把skel这个目录的所有文件在创建用户的家目录以后把这个目录下的所有文件复制到用户的家目录下去 skel是人的骨架,框架 (里面是一些bash的配置文件) -m -k :两者通常同时使用 eg:ls -a /etc/shel -r:添加为系统用户 8 userdel(删除用户) userdel [option] USERNAME -r :删除用户的同时也删除用户的家目录 id : 查看用户的账号属性信息 -u :只查看UID -g :只查看GID -G :查看当前用户所有组 -n :显示用户名 -u -n: 同时用可显示用户的名字,而不是只显示用户的id号 eg:id -u -n user1 -g -n: 同时用可显示组的名字 eg:id -g -n user1 -G -n: 同时用可显示所有组的组名 eg:id -G -n user1 -Gn :同时用可显示每一个组的组名 eg:id -Gn finger:查看(检索)用户账号信息 finger USERNAME 9 修改用户账号属性 usermod -u UID :改用户的信息 eg:user -u 2002 -g GID :改基本组 -a -G GID :改用户的附加组信息,为用户在原有组的基础上额外附加组,不使用-a选项,会覆盖此前的附加组 -c :指定注释信息 -d -m:既指定新的家目录,又移动此前的文件移至新的家目录当中去 -s :改用户的shell -l :改用户的登录名 -L :锁定用户账号 -U :解锁账号 -e : 指定用户的过期时间 -f : 指定非活动时间(即密码过期了) chsh(change shell的简写): 修改用户的默认shell chfn(change finger):修改用户的注释信息 10 密码管理 普通用户只能用passwd修改自己的密码 passwd [USERNAME] 管理员用于修改其他用户的密码 --stdin :标准输入 passwd --stdin :从标准输入读取密码,标准输入在键盘 eg:echo “redhat”| passwd --stdin user3 -l :锁定用户账号 -u :解锁 -d :删除用户密码 -w :警告时间 pwck:检查用户账号的完整性 组管理: 创建组:groupaddwhich useradd groupadd -g:指定GID -r: 添加为系统组 eg:# groupadd -r nginx # tail -1 /etc/group groupmod -g GID -n GRPNAME groupdel(删除组) gpasswd:为组设定密码 newgrp GRPNAME <--> exit change -d:最近一次的修改时间 -E:过期时间 -I:非活动时间 -m:最短使用期限 -M:最长使用期限 -W:警告时间 groupadd USERNAME 用户管理: useradd,userdel,usermod,passwd,chsh,chfn,finger,id,change 组管理: groupadd,groupdel,groupmod,gpasswd 11 权限管理:(r,w,x) 三类用户: u:属主 g: 属组 o: 其它用户 chown:改变文件属主(只有管理员可以使用此命令) # chown USERNAME file,... -R:修改目录及其内部文件的属主 --reference=/path/to/somefile file,... chown USERNAME:GRPNAME file (可改属组也可改属主) chown :GRPNAME file (属主不动只改组) # chgrp GRPNAME file,... -R --reference=/path/to/somefile file,... chmod:修改文件的权限 修改三类用户的权限: chmod MODE file,... -R :递归修改 --reference=/path/to/somefile file,... 修改某类用户或某些类用户权限: u,g,o,a chmod 用户类别=MODE file,... 修改某类的用户某位或某些位权限: u,g,o,a chmod 用户类别+|-MODE file,... su - openstack bc 是计算器 openssl passwd 生成密码 eg: openssl passwd -1(数字1)-salt '12345678' umask:用户创建文件用的遮罩码/掩码 # umask 文件默认不能具有执行权限,如果算得的结果中有执行权限,则将其权限加1; umask:023 文件:666-023=643 目录:777-023=754 站在用户登录的的角度来说,SHELL的类型: 登录式shell: 正常通常某终端登录 su - USERNAME su -1 USERNAME 非登录式shell: su USERNAME 图形终端下打开命令窗口 自动执行的shell脚本 bash的配置文件: 全局配置 /etc/profile,/etc/profile.d/*.sh,/etc/bashrc 个人配置 ~/.bash_profile,~/.bashrc profile类的文件: 设定环境变量 运行命令或脚本 bashrc类的文件: 设定本地变量 定义命令别名 登录式shell如何读取配置文件? /etc/profile --> /etc/profile.d/*.sh --> ~/.bash_profile --> ~/.bashrc --> /etc/bashrc 非登录式shell如何读取配置文件? ~/.bashrc --> /etc/bashrc --> /etc/profile.d/*.sh
相关文章推荐
- linux中用户、组的管理(密码管理、权限管理及其修改用户、组)
- linux中用户、组的管理(密码管理、权限管理及其修改用户、组)(转)
- linux的用户管理,sudo的介绍和开机修改root密码
- Linux命令:MySQL系列之十--MySQL用户和权限管理,mysql管理员密码重置
- [添加用户]解决useradd 用户后没有添加用户Home目录的情况,Linux改变文件或目录的访问权限命令,linux修改用户密码,usermod的ysuum安装包。飞
- linux练习:用户、组管理及权限管理--新建用户,复制修改权限
- Mysql-linux下密码修改,忘记密码修改,超级管理用户修改
- Linux系统中管理用户账户和组账户及其权限设置
- Linux查看用户及其权限管理
- Linux用户及其权限管理命令
- Linux学习日记 —— 7.3.2 用户和用户组管理-用户组管理命令-修改用户密码passwd
- linux用户管理(创建修改删除用户、用户组,修改密码,)
- (转)Linux查看用户及其权限管理
- Linux用户和组及其权限管理
- Linux中的用户和组及其权限管理
- 四.用户管理页面(显示所有的用户信息,同时为用户的添加,编辑,修改密码,删除,修改权限等功能提供相应的链接) UserMange.aspx
- [添加用户]解决useradd 用户后没有添加用户Home目录的情况,Linux改变文件或目录的访问权限命令,linux修改用户密码
- Linux添加用户,修改密码,修改用户权限
- linux用户管理(2)----修改用户模式(usermod,sudo权限等)
- linux用户管理(2)----修改用户模式(usermod,sudo权限等)