day21--操作系统用户管理

  1. 课程介绍部分

    1. 用户相关文件
    2. 用户相关目录
    3. 用户提权方法 4种方法
    4. 用户相关命令 chmod chown
  2. 课程知识回顾(提问环节)

    1. 系统常见面试题
      a 掌握系统启动流程
      b 如何编写服务启动脚本
    2. 用户管理概念知识
      a 用户分类知识 3类
      b 用户权限说明
      r : 文件/目录
      w : 文件/目录
      x : 文件/目录
      文件数据读写原理: inode/block
    3. 数据默认权限
      umask
      权限运算公式:
      文件: 666 - umask(奇数/偶数)
      目录: 777 - umask
  3. 系统用户重要文件: 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列: 用户密码信息
    生成密码密文信息

    利用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.com

    python -c "from passlib.hash import sha512_crypt; import getpass; print(sha512_crypt.using(rounds=5000).hash(getpass.getpass()))"

    /etc/group : 系统用户组记录文件
    /etc/gshadow : 系统用户组密码记录文件

  4. 系统用户重要目录:
    /etc/skel --- 样板房
    useradd oldboy

    1. 将用户信息填充到用户文件中
    2. 在/home目录创建家目录 mkdir /home/oldboy(权限700)
    3. 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/

  5. 如何进行用户提权操作:
    如何让普通用户获得更多权限

    1. 切换用户为root
      su - / su - root

    2. 修改文件或目录权限
      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/

    3. 利用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文件合法性

    4. 系统特殊权限位 12位权限
      setuid (4-s): 可以让普通用户获得一个命令文件属主能力 (root)
      修改命令权限:
      chmod u+s /usr/bin/cat
      chmod 4755 /usr/bin/cat
      补充: s权限位会覆盖执行权限位:
      执行权限位有x setuid符号为小写
      [root@oldboyedu ~]# ll which cat
      -rwxr-xr-x. 1 root root 54160 Oct 31 2018 /usr/bin/cat
      [root@oldboyedu ~]# chmod 4755 /usr/bin/cat
      [root@oldboyedu ~]# ll which cat
      -rwsr-xr-x. 1 root root 54160 Oct 31 2018 /usr/bin/cat
      执行权限位无x setuid符号为大写
      [root@oldboyedu ~]# ll which cat
      -rw-r-xr-x. 1 root root 54160 Oct 31 2018 /usr/bin/cat
      [root@oldboyedu ~]# chmod 4655 /usr/bin/cat
      [root@oldboyedu ~]# ll which 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/cat

    sticky 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/

  6. 用户管理相关命令:
    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: 显示系统所有用户登录信息

  7. 课程知识总结:

    1. 掌握文件数据权限概念 rwx
    2. 掌握文件数据读写原理 inode/block
    3. 掌握默认权限设置方法 umask
    4. 掌握普通用户提权方法 sudo 4种方法
      特殊权限位
    5. 掌握用户相关命令
      useradd userdel chmod chown id w
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,088评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,715评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,361评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,099评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 60,987评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,063评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,486评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,175评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,440评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,518评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,305评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,190评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,550评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,880评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,152评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,451评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,637评论 2 335

推荐阅读更多精彩内容