信息安全实战案例:Linux系统用户权限管理
ahcoder 2025-06-18 10:29 1 浏览
在 Linux 系统管理中,用户权限分配与安全控制是信息安全的核心环节。直接使用 root 账户进行日常操作存在极高风险,一旦密码泄露或误操作,可能导致系统失控、数据泄露或恶意攻击。此外,普通用户权限过度开放或受限不足,也会引发权限滥用或业务受阻。本案例针对企业或服务器环境中常见的多用户协作场景,通过精细化用户权限管理,平衡安全性与操作便利性,防止未授权访问和权限滥用,确保系统稳定运行。
本案例基于 Linux 系统(如 CentOS),演示如何通过用户创建、权限分配及登录安全设置构建多层次权限管理体系。核心步骤包括:
- 用户创建与基础配置:使用useradd创建普通用户user1,通过passwd设置强密码,并验证账户登录功能,避免直接使用 root 账户。
- sudo 权限精细化管理:编辑/etc/sudoers文件,允许user1执行特定管理命令(如创建用户useradd、修改普通用户密码passwd),但禁止修改 root 密码(通过!/usr/bin/passwd root规则),实现 “最小权限原则”。测试显示,user1可成功创建user2并设置密码,但尝试修改 root 密码时被拒绝。
- 登录安全强化:禁止 root 远程登录(修改sshd_config中PermitRootLogin no),设置用户会话超时时间(TMOUT=180秒无操作自动注销),并通过附加组(如 wheel 组)灵活扩展用户权限。
案例实现了普通用户与管理员账户的权限隔离,降低了 root 账户暴露风险,同时确保普通用户在授权范围内高效操作,为企业级 Linux 系统权限管理提供了可复用的安全模板。
3.1.1 创建用户并测试登录
(1)创建新用户:执行useradd user1创建一个普通用户,为后续权限分配做准备,避免直接使用高权限的root用户进行日常操作,降低安全风险。
(2)设置用户密码:执行passwd user1设置登录密码,强密码能有效防止暴力破解,提升账户安全性。
(3)确认账户可正常登录:使用新创建的user1账户尝试登录系统。
3.1.2 修改用户权限
(1)为新用户添加 sudo 权限:编辑/etc/sudoers文件,添加nuser1 ALL=(ALL) ALL。允许user1在无需密码的情况下执行sudo命令,方便进行管理操作,同时保持了一定的权限控制。
(2)在 /etc/sudoers 文件中授予普通用户执行所有命令的权限后,该用户并不能直接使用 su - 或 su - root 命令切换到 root 用户,而必须要使用 sudo su - 或 sudo su - root 命令。
(3)授予普通用户创建用户,并修改用户密码的权限,但是禁止该用户修改 root 用户密码,在 /etc/sudoers 文件中将nuser1 ALL=(ALL) ALL修改为user1 ALL=(ALL) /usr/sbin/useradd, /usr/bin/passwd, !/usr/bin/passwd "", !/usr/bin/passwd root。
命令选项与参数说明:
/usr/bin/useradd:允许 user1 用户执行 useradd USER 命令创建普通用户。
/usr/bin/passwd:允许 user1 用户执行 passwd USER 命令修改用户密码。
!/usr/bin/passwd root:禁止 user1 用户执行 passwd root 命令修改 root 用户密码。
!/usr/bin/passwd "":禁止 user1 用户执行 passwd 命令修改 root 用户密码,因为 passwd 命令后边为空则默认为 root 用户。
(4)测试创建普通用户和设置用户密码效果
(5)测试修改root用户密码和修改当前用户密码效果
3.1.3 用户登录安全设置
(1)禁止 root 远程登录:打开/etc/ssh/sshd_config文件,找到PermitRootLogin项,将其值设置为no,完成后重启ssh服务生效配置,减少因root账户被入侵导致系统完全失控的风险。
在宿主机上打开命令提示符窗口,使用root用户远程链接测试是否能登录。
(2)设置用户登录超时时间:编辑/etc/profile文件,添加TMOUT=180,表示用户在 3 分钟(180 秒)无操作后自动注销登录。这可避免因用户离开但会话仍保持活跃而带来的安全隐患。
(3)为用户添加附加组:运行usermod -a -G wheel newuser,将newuser添加到wheel组,wheel组通常具有较高权限,添加到该组可根据需要赋予用户更多管理权限,与在/etc/sudoers文件,添加nuser1 ALL=(ALL) ALL配置类似,可选择使用其中一种方法即可。
相关推荐
- Java程序员必备的Linux命令速查表
-
Java程序员必备的Linux命令速查表在Java开发的世界里,Linux就像一位默默支持的幕后英雄。作为一名Java开发者,掌握一些基本的Linux命令,不仅能提高工作效率,还能让你在团队中显得格外...
- Linux 命令速查手册:这 30 个高频指令,拯救 90% 的运维小白!
-
在Linux系统的世界里,命令行是强大的武器。对于运维小白而言,掌握一些高频使用的Linux命令,能极大提升工作效率,轻松应对各种系统管理任务。今天,就为大家奉上精心整理的30个Linu...
- linux磁盘管理相关命令(linux磁盘管理常用命令)
-
磁盘的使用情况会直接影响系统的性能,因此我们经常会用到以下命令,主要围绕:fdisk:磁盘分区df:文件系统的磁盘空间占用情况du:文件目录的磁盘空间占用情况查看磁盘关系lsblk查看磁盘分区情况fd...
- 第四章 Linux常用shell命令-4.5.磁盘管理
-
主要介绍一下跟磁盘管理相关命令,有比较多的内容摘抄自网络,如有侵权,请及时联系我删除:显示目前在Linux系统上的文件系统磁盘使用情况统计:df创建和维护分区表的程序:fdisk将磁盘分区或镜像挂...
- Linux新手必备:20个高效命令轻松掌握!
-
Linux基本命令使用指南在现代计算机操作系统中,Linux因其开放性、灵活性和强大的功能,广泛应用于服务器和开发环境中。作为技术人员,掌握Linux的基本命令是非常重要的。在本文中,我们将重点介绍2...
- 每日必学Linux命令:ls命令(linux命令详解之ls命令)
-
ls命令是linux下最常用的命令。ls命令就是list的缩写缺省下ls用来打印出当前目录的清单如果ls指定其他目录那么就会显示指定目录里的文件及文件夹清单。通过ls命令不仅可以查看linux文件...
- Linux系统dev和proc目录详解(linux dev/sr0)
-
简介:Linux系统里的/dev和/proc目录那可是相当重要的系统文件。在Linux系统中,/dev目录专门用来存放设备文件。不光有设备文件,系统里还有好多特殊功能也是通过设备的形式...
- Linux切换目录之cd命令(linux切换指定目录)
-
1.基本概念1.1命令作用当我们在Linux系统上工作时,做得相当多的一项任务就是在不同的目录之间进行切换,这时就需要用到cd命令了。cd是"changedirectory"的首...
- Linux切换目录(cd命令)(linux如何切换到目录)
-
cd命令,是ChangeDirectory的缩写,用来切换工作目录。Linux命令按照来源方式,可分为两种,分别是Shell内置命令和外部命令。所谓Shell内置命令,就是Shel...
- MongoDB数据库的快速部署和启动(mongodb的使用教程)
-
一、Mongodb介绍常见数据库介绍关系数据库RDBMS设计表结构,通过SQL语句进行操作。连表关系常见的关系型数据库:mysqloracle(商业)DB2(IBM)sqlserver(微软...
- 5分钟学会网络服务搭建,飞凌i.MX9352 + Linux 6.1实战示例
-
在“万物互联”的技术浪潮下,网络服务已成为连接物理世界与数字世界的核心纽带,它不仅赋予了终端设备“开口说话”的能力,更构建了智能设备的开发范式。本文就将以飞凌嵌入式OK-MX9352-C开发板(搭载了...
- centos安装geoserver并配置开机启动
-
前提条件:服务器已经安装了java环境一、下载下载地址:http://geoserver.org/release/maintain/下载后文件名为:geoserver-2.19.3-bin.zip二、...
- 开机启动流程(开机流程图)
-
grubandbootCentos5,6的开机启动流程grubCentos7的开机启动流程Centos5,6的开机启动流程initrd/initramfs一般存储在/boot目录下,以.img...
- Linux cron服务概述(crontab服务)
-
cron是Linux/Unix系统中一个非常重要的后台服务(守护进程),用于在预定的时间间隔自动执行命令或脚本。它使得自动化重复性任务成为可能,例如日志清理、数据备份、系统维护等。1.cron...
- CentOS 8利用rc.local进行开机自启动的配置
-
CentOS8利用rc.local进行开机自启动的配置CentOS8linux系统是不建议使用rc.local进行开机自启动的,建议创建systemdservice。我们为了方便以后多一个配置...
- 一周热门
- 最近发表
- 标签列表
-
- linux 远程 (37)
- u盘 linux (32)
- linux 登录 (34)
- linux 路径 (33)
- linux 文件命令 (35)
- linux 是什么 (35)
- linux 界面 (34)
- 查看文件 linux (35)
- linux 语言 (33)
- linux代码 (32)
- linux 查看命令 (33)
- 关闭linux (34)
- root linux (33)
- 删除文件 linux (35)
- linux 主机 (34)
- linux与 (33)
- linux 函数 (35)
- linux .ssh (35)
- cpu linux (35)
- 查看linux 系统 (32)
- linux 防火墙 (33)
- linux 手机 (32)
- linux 镜像 (34)
- linux ip地址 (34)
- linux 用户查看 (33)