目录
一、Linux 的安全性
Linux 安全系统的核心是用户账户。
用户权限是通过创建用户时分配的用户 ID( user ID, UID)来跟踪的。 UID 是个数值,每个用户都有一个唯一的 UID。
用户在登录系统时是使用登录名( login name)来代替 UID 登录的。
下面介绍 Linux 系统使用哪些 特定文件和工具 来跟踪及管理系统的用户账户。
1.1
/etc/passwd
文件
Linux 系统使用一个专门的文件
/etc/passwd
来匹配登录名与对应的 UID 值,下面是我的Ubuntu系统的
/etc/passwd
做了部分删减的文件示例,
$ cat /etc/passwd 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 sshd:x:116:65534::/var/run/sshd:/usr/sbin/nologin statd:x:117:65534::/var/lib/nfs:/bin/false wkd:x:1000:1000:,,,:/home/wkd:/bin/bash aaa:x:1001:1001::/var/www/html/aaa: tftp:x:118:125:tftp daemon,,,:/var/lib/tftpboot:/bin/false $
/etc/passwd 文件各个字段的含义如下:
- 登录用户名
- 用户密码
- 用户账户的 UID(数字形式)
- 用户账户的组 ID(数字形式)
- 用户账户的文本描述(称为备注字段)
- 用户$HOME 目录的位置
- 用户的默认 shell
文件解析:
- root 用户账户是 Linux 系统的管理员,为其固定分配的UID 是 0;
- Linux 系统会为各种各样的功能创建 系统用户,是系统中运行的各种服务进程访问资源使用的特殊账户。例如,上面的daemon用户、bin用户。
- Linux 会为系统账户预留了UID,Ubuntu系统预留了1000个ID,所以创建普通用户时使用的UID会从1000。例如,上面的wkd用户。
- /etc/passwd 文件中的密码字段都被设置为 x,并不是说所有的用户账户都使用相同的密码。而是因为绝大多数 Linux 系统将用户密码保存在单独的文件(称为 shadow 文件,位于/etc/shadow)中。只有特定的程序(比如登录程序)才能访问该文件。
- /etc/passwd 是一个标准的文本文件,可直接使用文本编辑器修改内容,但不建议修改,如果/etc/passwd 文件受损,系统无法读取文件内容,则会导致用户(即便是 root 用户)无法正常登录
1.2
/etc/shadow
文件
/etc/shadow
文件对 Linux系统密码管理提供了更多的控制。只有 root 用户才能访问
/etc/shadow
文件,这使其与
/etc/passwd
相比要安全许多。
下面是wkd用户在 ``/etc/shadow` 文件的记录:wkd:$1$jNrWJ3eQ$4ONPjdkvFngn5j7R09g90/:17704:0:99999:7:::
/etc/shadow
文件中的每条记录共包含 9 个字段。
- 登录名,对应于/etc/passwd 文件中的登录名。
- 加密后的密码。
- 自上次修改密码后已经过去的天数(从 1970 年 1 月 1 日开始计算)。
- 多少天后才能更改密码。
- 多少天后必须更改密码。
- 密码过期前提前多少天提醒用户更改密码。
- 密码过期后多少天禁用用户账户。
- 用户账户被禁用的日期(以从 1970 年 1 月 1 日到当时的天数表示)。
- 预留给以后使用的字段
有了 shadow 密码系统, Linux 系统就可以更好地控制用户密码了,比如控制用户多久更改一次密码,以及如果密码未更新的话,什么时候禁用该账户。
1.3 添加新用户 —— useradd
useradd
命令可以一次性轻松创建新用户账户并设置用户的$HOME 目录结构。
-D 选项,查看useradd 命令所使用的默认值:wkd@ubuntu:~$ useradd -D GROUP=100 HOME=/home INACTIVE=-1 EXPIRE= SHELL=/bin/sh SKEL=/etc/skel CREATE_MAIL_SPOOL=no wkd@ubuntu:~$
上面默认值解析:
- 新用户会被添加到 GID 为 100 的公共组。
- 新用户的主目录会位于
/home/登录名
。- 新用户账户密码在过期后不会被禁用。
- 新用户账户不设置过期日期。
- 新用户账户将
/bin/sh
作为默认 shell。- 系统会将/etc/skel 目录的内容复制到用户的$HOME 目录。
- 系统不会为该用户账户在 mail 目录下创建一个用于接收邮件的文件。
在Ubuntu下,/etc/skel/ 目录下有下面文件,创建新用户时会被复制到新用户的主目录。
wkd@ubuntu:~$ ls /etc/skel/ -la total 40 drwxr-xr-x 2 root root 4096 Jun 1418:50 . drwxr-xr-x 133 root root 12288 Jun 15 02:59 .. -rw-r--r-- 1 root root 220 Apr 92014 .bash_logout -rw-r--r-- 1 root root 3637 Apr 92014 .bashrc -rw-r--r-- 1 root root 8980 Oct 42013 examples.desktop -rw-r--r-- 1 root root 675 Jun 1418:50 .profile wkd@ubuntu:~$
useradd 命令行选项:
选 项描 述-c comment给新用户添加备注-d home_dir为主目录指定一个名字(如果不想用登录名作为主目录名的话)-e expire_date用 YYYY-MM-DD 格式指定账户过期日期-f inactive_days指定账户密码过期多少天后禁用该账户; 0 表示密码一过期就立即禁用, -1 表示不使用这个功能-g initial_group指定用户登录组的 GID 或组名-G group …指定除登录组之外用户所属的一个或多个附加组-k必须和-m 一起使用,将/etc/skel 目录的内容复制到用户的$HOME 目录-m创建用户的$HOME 目录-M不创建用户的$HOME 目录,即便默认设置里要求创建-n创建一个与用户登录名同名的新组-r创建系统账户-p passwd为用户账户指定默认密码-s shell指定默认的登录 shell-u uid为账户指定一个唯一的 UID
useradd 修改系统默认新用户设置值
选 项描 述-b default_home修改用户$HOME 目录默认创建的位置-e expiration_date修改新账户的默认过期日期-f inactive修改从密码过期到账户被禁用的默认天数-g group修改默认的组名称或 GID-s shell修改默认的登录 shell
例如:useradd -D -s /bin/tsch
1.4 删除用户 —— userdel
在默认情况下, userdel 命令只删除 /etc/passwd 和 /etc/shadow 文件中的用户信息,属于该账户的文件会被保留。
加入-r
选项,则 userdel 会删除用户的 $HOME 目录以及邮件目录。
1.5 修改用户 —— usermod、passwd、chpasswd
usermod
修改用户账户字段,还可以指定主要组( primary group)以及辅助组( secondary group)的所属关系。
提供了修改 /etc/passwd 文件中大部分字段的相关选项,只需指定相应的选项即可。
- -c用于修改备注字段,
- -e 用于修改过期日期,
- -g 用于修改默认的登录组
- -l:修改用户账户的登录名
- -L:锁定账户,禁止用户登录。
- -p:修改账户密码。
- -U:解除锁定,恢复用户登录。
-L 选项尤为实用。该选项可以锁定账户,使用户无法登录,无须删除账户和用户数据。要恢复账户,只需使用-U 选项即可。
passwd
命令可以方便地修改用户密码:
passwd 用户名
;
-e
选项可以强制用户下次登录时修改密码;
chpasswd
命令能从标准输入自动读取一系列以冒号分隔的登录名和密码对偶;
chsh
命令可以快速修改默认的用户登录 shell。使用时必须用 shell 的 全路径名 作为参数:
chsh -s /bin/csh test
chage
命令可用于帮助管理用户账户的有效期:
选 项描 述-d设置自上次修改密码后的天数-E设置密码过期日期-I设置密码过期多少天后锁定账户-m设置更改密码的最小间隔天数-M设置密码的最大有效天数-W设置密码过期前多久开始出现提醒信息
二、使用 Linux 组
为了解决共享资源的一组用户的安全性问题,Linux 系统采用了另一个安全概念——组。
组权限允许多个用户对系统对象(比如文件、目录或设备等)共享一组权限。
每个组都有唯一的 GID,和 UID 类似,该值在系统中是唯一的。除了 GID,每个组还有一个唯一的组名。
这节将介绍 Linux 系统中用于创建和管理组的 组工具。
2.1
/etc/group
文件
/etc/group
文件包含系统中每个组的信息,下面是
/etc/group
的内容,有删减。
wkd@ubuntu:~$ cat /etc/group root:x:0: daemon:x:1: bin:x:2: sys:x:3: adm:x:4:syslog,lu tty:x:5: disk:x:6: lp:x:7: mail:x:8: users:x:100: nogroup:x:65534: sambashare:x:124:lu wkd:x:1000: aaa:x:1001: tftp:x:125: wkd@ubuntu:~$
/etc/group 文件有 4 个字段。
- 组名
- 组密码
- GID
- 属于该组的用户列表
组密码允许非组内成员使用密码临时性地成为该组成员。
2.2 创建新组 —— groupadd
groupadd
命令可用于创建新组:
groupadd 组名
groupadd shared
在创建新组时,默认不为其分配任何用户,groupadd 命令没有提供向组中添加用户的选项,但可以用 usermod 命令来解决,下面语句将用户rich添加到shared组:
usermod-G shared rich
2.3 修改组 —— groupmod
groupmod 命令可以修改已有组的 GID(使用-g 选项)或组名(使用-n 选项):
groupmod -n sharing shared
语句将 shared 组改名为 sharing。
三、理解文件权限
四、更改安全设置
五、共享文件
如果文章有帮助的话,点赞👍、收藏⭐,支持一波,谢谢 😁😁😁
版权归原作者 wkd_007 所有, 如有侵权,请联系我们删除。