zoukankan      html  css  js  c++  java
  • Linux之用户组、文件权限详解

    用户和用户组

    文件所有者(u)

    一般为文件的创建者,谁创建了该文件,就天然的成为该文件的所有者

    用ls ‐ahl命令可以看到文件的所有者

    也可以使用chown 用户名 文件名来修改文件的所有者

    用户组(g)

    当某个用户创建了一个文件后,这个文件的所在组就是该用户所在的组

    用ls ‐ahl命令可以看到文件的所有组

    也可以使用chgrp 组名 文件名来修改文件所在的组

    其他人(o)

    除开文件的所有者和所在组的用户外,系统的其它用户都是文件的其他人

    文件权限

    ls -l中显示的内容如下:

    -rwxrw-r‐-1 root root 1213 Feb 2 09:39 abc

    - 10个字符确定不同用户能对文件干什么

    - 第一个字符代表文件(-)、目录(d),链接(l),设备文件里面可供存储的接口设备(b),设备文件里面串行端口设备(c),套接字(s),管道(p)

    - 其余字符每3个一组(rwx),读(r)、写(w)、执行(x)

    - 第一组rwx:文件所有者的权限是读、写和执行

    - 第二组rw-:与文件所有者同一组的用户的权限是读、写但不能执行

    - 第三组r--:不与文件所有者同组的其他用户的权限是读不能写和执行

    也可用数字表示为:r=4,w=2,x=1  因此rwx=4+2+1=7

    - 1 表示有多少文件名链接到此节点(i-node)

    - 第一个root 表示此文件(或目录)的“所有者账号”

    - 第二个root表示此文件所属用户组

    - 1213 表示文件大小(字节)

    - Feb 2 09:39 表示最后修改日期

    - abc 表示文件名

    文件特殊权限和隐藏权限

    Linux之文件(目录)默认权限、特殊权限与隐藏权限

    Linux用户身份与用户组记录的文件

    在我们的Linux系统当中,默认的情况下所有的系统上的账号与一般身份用户,还有那个root的相关信息,都是记录在/etc/passwd这个文件内。个人的密码则是记录在/etc/shadow文件下。此外,Linux所有的组名都记录在/etc/group内。

    root:x:0:0:root:/root:/bin/bash
    daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin
    bin:x:2:2:bin:/bin:/usr/sbin/nologin
    sys:x:3:3:sys:/dev:/usr/sbin/nologin
    sync:x:4:65534:sync:/bin:/bin/sync
    games:x:5:60:games:/usr/games:/usr/sbin/nologin
    man:x:6:12:man:/var/cache/man:/usr/sbin/nologin
    lp:x:7:7:lp:/var/spool/lpd:/usr/sbin/nologin
    mail:x:8:8:mail:/var/mail:/usr/sbin/nologin
    news:x:9:9:news:/var/spool/news:/usr/sbin/nologin
    uucp:x:10:10:uucp:/var/spool/uucp:/usr/sbin/nologin
    proxy:x:13:13:proxy:/bin:/usr/sbin/nologin
    www-data:x:33:33:www-data:/var/www:/usr/sbin/nologin
    backup:x:34:34:backup:/var/backups:/usr/sbin/nologin
    list:x:38:38:Mailing List Manager:/var/list:/usr/sbin/nologin
    irc:x:39:39:ircd:/var/run/ircd:/usr/sbin/nologin
    gnats:x:41:41:Gnats Bug-Reporting System (admin):/var/lib/gnats:/usr/sbin/nologin
    nobody:x:65534:65534:nobody:/nonexistent:/usr/sbin/nologin
    systemd-timesync:x:100:102:systemd Time Synchronization,,,:/run/systemd:/bin/false
    systemd-network:x:101:103:systemd Network Management,,,:/run/systemd/netif:/bin/false
    systemd-resolve:x:102:104:systemd Resolver,,,:/run/systemd/resolve:/bin/false
    systemd-bus-proxy:x:103:105:systemd Bus Proxy,,,:/run/systemd:/bin/false
    syslog:x:104:108::/home/syslog:/bin/false
    _apt:x:105:65534::/nonexistent:/bin/false
    messagebus:x:106:110::/var/run/dbus:/bin/false
    uuidd:x:107:111::/run/uuidd:/bin/false
    lightdm:x:108:114:Light Display Manager:/var/lib/lightdm:/bin/false
    whoopsie:x:109:116::/nonexistent:/bin/false
    avahi-autoipd:x:110:119:Avahi autoip daemon,,,:/var/lib/avahi-autoipd:/bin/false
    avahi:x:111:120:Avahi mDNS daemon,,,:/var/run/avahi-daemon:/bin/false
    dnsmasq:x:112:65534:dnsmasq,,,:/var/lib/misc:/bin/false
    colord:x:113:123:colord colour management daemon,,,:/var/lib/colord:/bin/false
    speech-dispatcher:x:114:29:Speech Dispatcher,,,:/var/run/speech-dispatcher:/bin/false
    hplip:x:115:7:HPLIP system user,,,:/var/run/hplip:/bin/false
    kernoops:x:116:65534:Kernel Oops Tracking Daemon,,,:/:/bin/false
    pulse:x:117:124:PulseAudio daemon,,,:/var/run/pulse:/bin/false
    rtkit:x:118:126:RealtimeKit,,,:/proc:/bin/false
    saned:x:119:127::/var/lib/saned:/bin/false
    usbmux:x:120:46:usbmux daemon,,,:/var/lib/usbmux:/bin/false
    hwli:x:1000:1000:hwli,,,:/home/hwli:/bin/bash
    sshd:x:121:65534::/var/run/sshd:/usr/sbin/nologin
    

    以上是cat /etc/passwd的结果,文件的每一行代表着一个用户,每一行由冒号“:”分割成7个字段,其结构如下:

    用户名:密码:UID:GID:用户全名:home目录:shell

    UID:

    • UID 0 root用户
    • UID 1~999 是占坑用户,即一写无法登录的用户(以前是系统是1~499,最近刚改)
    • UID 1000 以上是正常的可登录用户

    GID:前面说了一个用户可以属于多个用户组,但这里只有一个,表示的是专职用户组,即一个用户只有一个专职用户组,其属于其他用户组的关联关系存储在/etc/group 文件中。

    root:$6$Clyx30gD$C0MVxM4rzCsf10RfDy6ETLFXzVRoC/6clwLnqL3LltB.MneyyZbpz0kex4fpGW.gaKgI7VKEAPxORbcu5amjR0:17470:0:99999:7:::
    daemon:*:17001:0:99999:7:::
    bin:*:17001:0:99999:7:::
    sys:*:17001:0:99999:7:::
    sync:*:17001:0:99999:7:::
    games:*:17001:0:99999:7:::
    man:*:17001:0:99999:7:::
    lp:*:17001:0:99999:7:::
    mail:*:17001:0:99999:7:::
    news:*:17001:0:99999:7:::
    uucp:*:17001:0:99999:7:::
    proxy:*:17001:0:99999:7:::
    www-data:*:17001:0:99999:7:::
    backup:*:17001:0:99999:7:::
    list:*:17001:0:99999:7:::
    irc:*:17001:0:99999:7:::
    gnats:*:17001:0:99999:7:::
    nobody:*:17001:0:99999:7:::
    systemd-timesync:*:17001:0:99999:7:::
    systemd-network:*:17001:0:99999:7:::
    systemd-resolve:*:17001:0:99999:7:::
    systemd-bus-proxy:*:17001:0:99999:7:::
    syslog:*:17001:0:99999:7:::
    _apt:*:17001:0:99999:7:::
    messagebus:*:17001:0:99999:7:::
    uuidd:*:17001:0:99999:7:::
    lightdm:*:17001:0:99999:7:::
    whoopsie:*:17001:0:99999:7:::
    avahi-autoipd:*:17001:0:99999:7:::
    avahi:*:17001:0:99999:7:::
    dnsmasq:*:17001:0:99999:7:::
    colord:*:17001:0:99999:7:::
    speech-dispatcher:!:17001:0:99999:7:::
    hplip:*:17001:0:99999:7:::
    kernoops:*:17001:0:99999:7:::
    pulse:*:17001:0:99999:7:::
    rtkit:*:17001:0:99999:7:::
    saned:*:17001:0:99999:7:::
    usbmux:*:17001:0:99999:7:::
    hwli:$6$nG6K1ezO$2Dhl8G6N9WXxCnIsj90PskC2VPs.8OszplUoTdZUhUF2A6v/oOQTDmXi4.qNqNm2tCpkuJG5UAwsusDjmuaBF1:17469:0:99999:7:::
    sshd:*:17470:0:99999:7:::
    

    以上是cat /etc/shadow的结果,其结构如下:

    登录名:加密过的密码(*代表此用户不能用来登录):密码最近更改日期(linux时间戳):最少密码天数(0代表随时可更改):最多密码天数:过期前几天提醒用户:密码不可用期限:账户过期日期:保留位
    root:x:0:
    daemon:x:1:
    bin:x:2:
    sys:x:3:
    adm:x:4:syslog,hwli
    tty:x:5:
    disk:x:6:
    lp:x:7:
    mail:x:8:
    news:x:9:
    uucp:x:10:
    man:x:12:
    proxy:x:13:
    kmem:x:15:
    dialout:x:20:
    fax:x:21:
    voice:x:22:
    cdrom:x:24:hwli
    floppy:x:25:
    tape:x:26:
    sudo:x:27:hwli
    audio:x:29:pulse
    dip:x:30:hwli
    www-data:x:33:
    backup:x:34:
    operator:x:37:
    list:x:38:
    irc:x:39:
    src:x:40:
    gnats:x:41:
    shadow:x:42:
    utmp:x:43:
    video:x:44:
    sasl:x:45:
    plugdev:x:46:hwli
    staff:x:50:
    games:x:60:
    users:x:100:
    nogroup:x:65534:
    systemd-journal:x:101:
    systemd-timesync:x:102:
    systemd-network:x:103:
    systemd-resolve:x:104:
    systemd-bus-proxy:x:105:
    input:x:106:
    crontab:x:107:
    syslog:x:108:
    netdev:x:109:
    messagebus:x:110:
    uuidd:x:111:
    ssl-cert:x:112:
    lpadmin:x:113:hwli
    lightdm:x:114:
    nopasswdlogin:x:115:
    whoopsie:x:116:
    mlocate:x:117:
    ssh:x:118:
    avahi-autoipd:x:119:
    avahi:x:120:
    bluetooth:x:121:
    scanner:x:122:saned
    colord:x:123:
    pulse:x:124:
    pulse-access:x:125:
    rtkit:x:126:
    saned:x:127:
    hwli:x:1000:
    sambashare:x:128:hwli
    skysolid:x:1001:

    以上是cat /etc/group的结果,其结构如下:

    组名:用户组密码:GID:用户组内的用户名

    参考资料:

      https://www.cnblogs.com/duhuo/p/5892513.html

  • 相关阅读:
    virtualbox mout 错误解决
    Python pip 学习
    tzset()与localtime()
    TSE部署实践
    变量和关系符和JAVA基本类型笔记与常考面试题
    实例:判断客户是否中奖与纸牌互换,计算银行本息
    实例:五位数各位数之和与员工实领工资
    关于变量,JAVA基本数据类型,运算符类型,如何从控制台接收输入的数据
    Java的程序执行过程与编译原理
    CMD控制器常用命令
  • 原文地址:https://www.cnblogs.com/hwli/p/9609345.html
Copyright © 2011-2022 走看看