-
系统用户重要文件: 4个
/etc/passwd : 系统用户记录文件 ******
root :x:0 :0 :root :/root :/bin/bash
nobody :x:99 :99 :Nobody:/ :/sbin/nologin
oldbaby:x:1013:1013: :/home/oldbaby:/bin/bash
01列: 用户名称信息
02列: 用户密码信息
03列: 用户uid数值信息
04列: 用户gid数值信息
05列: 用户注释信息
06列: 指定用户家目录
07列: 用户登录系统方式 bash == shell nologin
# cat /etc/shells
/bin/sh
/bin/bash
/usr/bin/sh
/usr/bin/bash
/etc/shadow : 系统用户密码(密文)记录文件 ******
alex :!!:18103:0:99999:7:::
oldbaby :!!:18106:0:99999:7:::
old01 :!!:18106:0:99999:7:::
01列: 用户名称信息
02列: 用户密码信息
生成密码密文信息5利用python模块功能
yum install python-pip
pip install passlib
优化pip源
~/.pip/pip.conf
中添加或修改:
[global]
index-url = https://mirrors.aliyun.com/pypi/simple/[install]
trusted-host=mirrors.aliyun.compython -c "from passlib.hash import sha512_crypt; import getpass; print(sha512_crypt.using(rounds=5000).hash(getpass.getpass()))"
/etc/group : 系统用户组记录文件
/etc/gshadow : 系统用户组密码记录文件 -
系统用户重要目录:
/etc/skel --- 样板房
useradd oldboy- 将用户信息填充到用户文件中
- 在/home目录创建家目录 mkdir /home/oldboy(权限700)
- cp -r /etc/skel/.bas* /home/oldboy
/etc/skel/* /home/oldboy
企业面试题: 恢复命令提示:
方式一: 修改PS环境变量
vim /etc/profile
export PS1='[\e[32;1m][\u@\h \W]$ [\e[0m]'
方式二: 复制/etc/skel目录中的隐藏文件
cp /etc/skel/.bash* /home/oldboy/ -
如何进行用户提权操作:
如何让普通用户获得更多权限切换用户为root
su - / su - root-
修改文件或目录权限
chmod:
单独修改权限信息:
· 单独修改属主权限 chmod u+r/w/x chmod u-r/w/x chmod u=r/w/x u--user
· 单独修改属组权限 chmod g+r/w/x chmod g-r/w/x chmod g=r/w/x g--group
· 单独修改其他用户权限 chmod o+r/w/x chmod o-r/w/x chmod o=r/w/x o--other创建 oldboy01.txt oldboy02.txt oldboy03.txt
oldboy01.txt 属主权限为只读
oldboy02.txt 属组权限为读写执行
oldboy03.txt 其他用户权限为只能执行批量修改权限信息:
· 利用数值进行修改 744
chmod 744 01.txt
· 利用符号修改权限 +rwx -rwx =rwx
chmod a+x 01.txt
创建 oldboy01.txt
oldboy01.txt 属主权限为只读 4
属组权限为读写执行 7
其他用户权限为只能执行 1
chmod 471 oldboy01.txt
创建 oldboy/ oldboy01..03
修改目录权限为666, 保证目录下面数据权限也为666
chmod -R 777 /oldboy/ --- 利用-R参数实现递归修改目录以及目录下面所有数据权限chown
属主信息 chown oldboy 目录/文件
数组信息 chown .oldboy 目录/文件
全部信息 chown oldboy.oldboy 目录/文件
chown nobody. oldboy02.txt
创建 oldboy/ oldboy01..03
修改目录权限属主为oldboy 属组为oldgirl 并且所有目录下面数据权限和目录一致
chown -R oldboy.oldgirl /oldboy --- 利用-R参数实现递归修改目录以及目录下面所有数据权限[oldboy@oldboyedu ~]$ cat /etc/shadow
cat: /etc/shadow: Permission denied
chmod o+r /etc/shadow[oldboy@oldboyedu ~]$ touch /etc/oldboy
touch: cannot touch ‘/etc/oldboy’: Permission denied
chmod o+w /etc/ -
利用sudo方式对指定用户提权 皇帝root -大宝剑- 大臣 -大宝剑- 其他人
第一个里程: 皇帝下派指定权力
visudo
oldboy ALL=(ALL) /sbin/, /bin/, vi
oldboy ALL=(ALL) /bin/, !/bin/vim, !/usr/sbin/visudo --- 对有些危险命令进行取反配置
oldboy ALL=(ALL) NOPASSWD: /bin/, !/bin/vim, !/usr/sbin/visudo --- 忽略sudo密码信息01: 将root权力赋予哪个用户
02: ??? 权限集中管理服务器 --- 跳板机
03: 赋予什么特殊权力echo 123456|passwd --stdin oldboy
第二个里程: 测试赋予权力
普通用户测试执行
sudo -l --- 查看特殊权限
/bin/cat /etc/shadow, /bin/touch /etc/*
sudo cat /etc/shadow --- 操作命令sudo -l --- 查看sudo权力
sudo -k --- 清除sudo密码缓存
visudo(语法检查功能) == vim /etc/sudoers
visudo -c --- 检查/etc/sudoers文件合法性 系统特殊权限位 12位权限
setuid (4-s): 可以让普通用户获得一个命令文件属主能力 (root)
修改命令权限:
chmod u+s /usr/bin/cat
chmod 4755 /usr/bin/cat
补充: s权限位会覆盖执行权限位:
执行权限位有x setuid符号为小写
[root@oldboyedu ~]# llwhich cat
-rwxr-xr-x. 1 root root 54160 Oct 31 2018 /usr/bin/cat
[root@oldboyedu ~]# chmod 4755 /usr/bin/cat
[root@oldboyedu ~]# llwhich cat
-rwsr-xr-x. 1 root root 54160 Oct 31 2018 /usr/bin/cat
执行权限位无x setuid符号为大写
[root@oldboyedu ~]# llwhich cat
-rw-r-xr-x. 1 root root 54160 Oct 31 2018 /usr/bin/cat
[root@oldboyedu ~]# chmod 4655 /usr/bin/cat
[root@oldboyedu ~]# llwhich cat
-rwSr-xr-x. 1 root root 54160 Oct 31 2018 /usr/bin/cat
setgid (2-s): 可以让普通用户获得一个命令文件属组能力 (root)
修改命令权限:
chmod g+s /usr/bin/cat
chmod 2755 /usr/bin/catsticky bit: t=1 对目录设置
创建一个共享目录, 目录中文件数据只能属主用户操作
其他用户只能看不能改, 也不能删除
[root@oldboyedu ~]# chmod o+t /share/
[root@oldboyedu ~]# chmod 1777 /share/
[root@oldboyedu ~]# ll /share/ -d
drwxrwxrwt 2 root root 43 Jul 29 19:45 /share/ -
用户管理相关命令:
useradd: 创建用户
-u : 指定uid信息
-g : 指定用户所属主要组
-G : 指定用户所属附属组
-M : 不创建用户家目录
-s : 指定用户shell登录方式 /sbin/nologin
useradd rsync -M -s /sbin/nologin --- 创建虚拟用户
-c : 给用户添加注释信息userdel: 删除用户
userdel -r 彻底删除用户,以及家目录usermod:
-u : 指定uid信息
-g : 指定用户所属主要组
-G : 指定用户所属附属组
-s : 指定用户shell登录方式 /sbin/nologin
useradd rsync -M -s /sbin/nologin --- 创建虚拟用户
-c : 给用户添加注释信息groupadd: -g
groupdel:
groupmod: -g
chmod:
chown:
passwd: --stdin
id: uid gid 用户组成员信息
w:
USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT
root tty1 15:22 4:48m 0.18s 0.18s -bash
root pts/1 10.0.0.1 18:21 4.00s 0.54s 0.00s w
01: 登录系统用户信息
02: 登录方式 tty本地登录 pts/1远程登录
echo "请其他用户最近2天不要修改/home/oldboy/oldboy.txt" >/dev/pts/0
03: 显示登录的源IP地址
04: 登录时间
05: 登录之后空闲时间
06-07: 执行命令耗费CPU时长
08: 执行了什么操作last: 显示用户曾经登录历史记录
lastlog: 显示系统所有用户登录信息 -
课程知识总结:
- 掌握文件数据权限概念 rwx
- 掌握文件数据读写原理 inode/block
- 掌握默认权限设置方法 umask
- 掌握普通用户提权方法 sudo 4种方法
特殊权限位 - 掌握用户相关命令
useradd userdel chmod chown id w
第二十一节课操作系统用户管理
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 1.用户及用户组配置文件介绍: 用户相关文件:1. /etc/passwd 用户所在文件 /etc/passwd文...