首页 游戏 软件 资讯 排行榜 专题
首页
系统平台
Linux怎么限制普通用户权限 Linux下Restricted Shell详解

Linux怎么限制普通用户权限 Linux下Restricted Shell详解

热心网友
81
转载
2026-04-30

Linux怎么限制普通用户权限 Linux下Restricted Shell详解

Linux怎么限制普通用户权限 Linux下Restricted Shell详解

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

rbash 启动后为什么 cd 报错?

很多朋友第一次接触受限Shell(Restricted Shell)时,都会遇到一个直观的困惑:为什么一执行cd命令就报错?提示往往是bash: cd: restricted

这其实不是目录权限的问题,而是Shell自身在“使绊子”。当rbash启动后,它会直接拦截cd这个内置命令的调用路径。换句话说,无论你想切换到上级目录(cd ..)还是绝对路径(cd /tmp),都会被一概拒绝。这是一种由内而外的限制机制。

那么,这个限制是怎么触发的呢?关键在启动方式。无论是通过bash -r参数启动,还是直接调用名为rbash的软链接(比如/bin/rbash),效果都一样。Shell会检查$0(当前程序名)的basename,如果名字是“rbash”,就自动进入受限模式。这也意味着,如果你自己创建一个叫mybash的软链接,它是不会触发限制的。

  • 如何验证? 运行shopt restricted_shell,如果看到输出restricted_shell on,就说明受限模式已经生效。
  • 一个常见的误解是以为登录后可以用set -r手动开启限制。实际上,这个模式只能在Shell初始化时启用,运行时设置是无效的。
  • 虽然cd被禁了,但像pwdls这样的命令依然可用。不过,前提是这些命令必须位于$PATH环境变量所包含的路径中,并且调用时不能包含斜杠(/)。

用户能运行哪些命令由什么决定?

受限Shell下,用户能执行什么命令,并不是靠某个神秘的白名单配置文件来决定的。真正的规则,藏在$PATH和命令的调用方式里。

核心限制就一条:禁止执行任何包含斜杠(/)的路径。这意味着,像/bin/ls./my_script.sh或者~/bin/command这样的调用方式会全部失败。系统只允许你使用不带斜杠的命令名,例如直接输入ls。当然,这个ls命令本身必须能在$PATH所定义的搜索路径里找到对应的可执行文件。

基于这个机制,常见的部署策略是为受限用户创建一个专属的、高度可控的命令目录。比如,在用户家目录下建立一个.bin文件夹(/home/user/.bin),里面只放置允许执行的命令的软链接。然后,将用户的$PATH环境变量修改为只包含这个目录。

export PATH="/home/user/.bin"

这个方案听起来简单,但有几个细节必须卡死:

  • 软链接必须由root创建:例如,sudo ln -s /bin/ls /home/user/.bin/ls。不能让用户有自己添加链接的权限。
  • 配置文件权限必须收紧:用户用于初始化环境的文件(如.profile.bash_profile)必须由root掌控所有权和权限:chown root:root .profile && chmod 755 .profile。否则,用户一旦能修改这些文件,就能随意篡改PATH,限制形同虚设。
  • 注意.bashrc的读取规则:默认情况下,rbash不会自动读取~/.bashrc文件。除非你在.profile里显式地使用source命令去加载它,否则里面的设置不会生效。

为什么用户还能逃出 rbash?常见绕过点在哪?

必须清醒地认识到,rbash并非一个滴水不漏的沙箱,它只是一层轻量级的限制外壳。只要用户能够执行某个程序,而这个程序又恰好提供了调用外部Shell或执行系统命令的功能,就很可能成为逃逸的突破口。

最经典的“后门”就是那些支持交互式命令的工具,比如vimlessmanftp甚至gdb。它们通常内置了一个!命令,用于执行系统命令。例如,如果用户被允许运行vim,那么他只需要在vim中输入:!sh:!/bin/bash,瞬间就能获得一个不受限制的完整Shell。

因此,在配置完成后,进行一次彻底的安全检查至关重要:

  • 盘点可用命令:先echo $PATH查看路径,然后逐一检查这些路径下有哪些二进制文件(ls -l)。
  • 测试重定向限制:执行echo test > file,看看是否能成功创建文件。如果成功,说明输出重定向的限制可能未生效或被绕过了。
  • 警惕脚本解释器:检查用户是否能访问pythonperlawk等。一行像python -c “import os; os.system(‘/bin/sh’)”的代码就是极高风险的信号。
  • 审查sudo权限:运行sudo -l查看用户是否有免密码执行某些命令的权限。如果输出显示用户可以无密码运行sudo /bin/bash,那所有的Shell限制都将在一瞬间被绕过。

rbash 适合什么场景?不适合什么?

那么,rbash到底该用在什么地方?它的定位其实很明确。

它适合那些短期、低信任度的访问场景。比如,给外包人员一个临时账号,只允许其查看特定的日志文件;为教学实验室的学生提供一个受控的实验环境;或者给持续集成(CI)系统使用的构建账号。在这些情况下,rbash的优势在于成本极低、无需部署额外服务、基本上开箱即用。

但它绝对不适合作为生产环境核心权限隔离的解决方案。它的限制机制相对表层,很容易被系统中已有的各种工具链(如上述的编辑器、解释器)绕过。更重要的是,它无法防范进程间通信、内存读取、ptrace调试注入等更深层次的系统行为。

当真正需要强隔离时,目光应该转向更专业的方案,例如systemd --scopecgroups v2firejail,或者直接使用容器技术。可以说,rbash更像是一个“礼貌性的围栏”,用于标识边界和阻止无心之失,但它绝不是一道坚固的“防火墙”。

最后,还有一个极其关键却常被忽略的点:rbash用户的家目录($HOME)本身必须设置严格的权限。如果用户能够写入/home/user/.bash_profile,他就可以覆盖PATH或注入任意启动命令;如果用户能够修改/home/user/.ssh/authorized_keys文件,他甚至可能通过配置特定的SSH密钥,在登录时直接绕过受限Shell。这些文件系统的权限,是与Shell限制相辅相成的最后一道防线。

来源:https://www.php.cn/faq/2393908.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

Xrender支持哪些图形格式
编程语言
Xrender支持哪些图形格式

xrender支持的图形格式 核心说明 首先得澄清一个常见的误解:xrender本身并不是一个图像解码库。它实际上是X Window System的一个渲染扩展,主要负责提供抗锯齿、路径绘制、渐变、合成这些高级的2D渲染能力。那么,图片是怎么显示出来的呢?通常,应用程序会先用其他专门的库(比如处理P

热心网友
04.29
怎样用nginx日志解决跨域问题
编程语言
怎样用nginx日志解决跨域问题

如何通过Nginx配置解决跨域问题:从原理到实战 开门见山地说,试图直接利用Nginx日志来解决跨域问题,这个思路本身存在误区。Nginx日志的核心作用是什么?它本质上是一个“记录系统”,负责详尽记录每一次访问详情与错误信息,但其本身并不具备主动配置或修复跨域问题的能力。跨域问题的根源在于浏览器的同

热心网友
04.29
Linux Node.js日志如何压缩
编程语言
Linux Node.js日志如何压缩

Linux Node js日志如何压缩 在Linux服务器上运行Node js应用时,日志文件体积快速增长是运维人员经常面临的挑战。有效管理和压缩日志不仅能节省宝贵的磁盘空间,还能提升日志归档与分析的效率。本文将详细介绍两种主流方法:使用Linux系统自带的gzip命令进行手动压缩,以及配置pm2进

热心网友
04.29
怎样分析JS日志中的用户行为
编程语言
怎样分析JS日志中的用户行为

分析Ja vaScript日志中的用户行为:从数据噪音到业务洞察 面对海量的Ja vaScript日志,你是否感觉像在翻阅一本没有目录的天书?用户点击了哪里,为什么中途离开,哪些流程让他们感到困惑——这些问题的答案,都隐藏在那些看似枯燥的日志行里。将杂乱的日志数据转化为清晰的用户行为洞察,并非难事,

热心网友
04.29
Linux系统中JS日志如何查看
编程语言
Linux系统中JS日志如何查看

在Linux系统中查看Ja vaScript日志的几种实用方法 在Linux环境下排查Ja vaScript应用的问题,日志是关键线索。但具体怎么查看,其实取决于你的应用究竟跑在哪种环境里。下面这几种常见场景和方法,基本能覆盖大多数需求。 1 Node js 环境下的日志查看 如果你的应用是跑在N

热心网友
04.29

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

勇者斗恶龙7重制版包袱皮披风获取方法
游戏攻略
勇者斗恶龙7重制版包袱皮披风获取方法

勇者斗恶龙7重制版包袱皮披风速刷指南:获取方法与效果详解 在经典RPG《勇者斗恶龙7:伊甸的战士们》重制版中,“包袱皮披风”是提升刷宝效率的关键装备。这件披风的唯一效果是显著增加战斗后怪物掉落道具的几率,对于收集稀有锻造材料、完整装备图鉴或推进主线卡关的玩家而言,是不可多得的效率神器。那么,这件高性

热心网友
04.30
勇者斗恶龙7重制版盗贼的钥匙怎么获得
游戏攻略
勇者斗恶龙7重制版盗贼的钥匙怎么获得

勇者斗恶龙7重制版盗贼钥匙获取攻略:开启早期宝箱的关键道具 在《勇者斗恶龙7》重制版的游戏初期,你是否常为那些上锁的宝箱感到困扰?这些无法开启的容器里往往藏着宝贵资源。本篇将详解如何取得第一把永久钥匙——盗贼的钥匙,它是解锁前期各类普通宝箱的唯一途径,能让你的冒险旅程更加顺利。 勇者斗恶龙7重制版盗

热心网友
04.30
USD.AI为何成AI金融基础设施的新焦点?
web3.0
USD.AI为何成AI金融基础设施的新焦点?

USD AI:当合成美元遇上AI算力融资,一个新叙事正在成型 加密世界从不缺少新故事,但能让市场侧目的,往往是那些能将多个热门赛道巧妙缝合的创新。最近,一个名为USD AI的项目正引发广泛讨论。它并非又一个简单的DeFi收益农场,而是精准地站在了合成美元、真实收益与AI基础设施融资这三个领域的交汇点

热心网友
04.30
仁王3东国无双BOSS无伤思路攻略
游戏攻略
仁王3东国无双BOSS无伤思路攻略

仁王3东国无双BOSS无伤打法全攻略:击败本多忠胜技巧详解 一、核心无伤思路与原则 想要在《仁王3》中无伤击败“东国无双”本多忠胜,首要任务是调整战斗思维——核心理念是“生存优先,输出在后”。这位战国第一猛将攻击力极高、范围极大,但几乎所有招式都有明显的起手动作。任何贪刀或判断失误都可能被秒杀。因此

热心网友
04.30
勇者斗恶龙7重制版竞技场席德怎么打
游戏攻略
勇者斗恶龙7重制版竞技场席德怎么打

勇者斗恶龙7重制版竞技场席德怎么打?最详细攻略与打法技巧解析 在《勇者斗恶龙7》重制版的隐藏竞技场中,破坏邪神席德是一个机制独特、难度极高的守关Boss。许多玩家初次挑战时反复受挫,其难点并非简单的数值压制,而在于一套配合严密、环环相扣的致命技能组合。未能理解其行动模式,极易导致全员覆没。不过无需焦

热心网友
04.30