AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 406434
Accepted
Nir Friedman
Nir Friedman
Asked: 2017-11-23 16:22:26 +0800 CST2017-11-23 16:22:26 +0800 CST 2017-11-23 16:22:26 +0800 CST

以其他用户身份运行单个命令;sudo 的限制

  • 772

我正在一台没有 root 权限的机器上工作,但有一个允许的sudo命令列表。这些命令之一是/bin/su - foouser. 所以我可以输入sudo su - foouser,然后我得到一个交互式 shell 作为 foouser。然后我可以运行一些东西作为foouser.

问题是这foouser是一个共享的用户/外壳,用于产生某些重要的生产过程。我无法轻松自定义它或按照我想要的方式设置它。而且我不应该一直在其中工作,这会分割我的终端,以及我以自己身份登录的终端和我所在的终端之间的命令历史记录foouser。

我真正想做的是有一种方法来运行单个命令foouser,让它阻塞,像通常的命令一样将stdout和stderr打印到我的shell,然后返回我仍然以我自己的身份登录(并且不是foouser)。例如,这可以封装在一个脚本中,以便as_foo bar运行命令baras foouser,打印 stdout 和 stderr,返回返回码bar,然后将我放回我的 shell。

我可以要求系统管理员更改权限。例如,他们可以添加bar到 sudo 列表中,然后我可以使用(我认为)su -c以我描述的方式运行 bar。但是,如果第二天我想跑步bar2,我必须再次与他们交谈。

有没有办法摆脱这种困境?这似乎很愚蠢,因为我显然可以成为foouser并运行任意数量的命令,所以我可以看到在安全性方面没有区别。只是找不到任何明显方便的方法来实现这一点。

sudo su
  • 2 2 个回答
  • 1501 Views

2 个回答

  • Voted
  1. Best Answer
    telcoM
    2017-11-23T23:19:35+08:002017-11-23T23:19:35+08:00

    sudo su - foouser <command>要求您至少具有有限的 root 访问权限才能su - foouser <command>以 root 身份运行。

    sudo -u foouser <command>可以一步完成你想要的。但它要求系统管理员以这种方式授予您sudo对foouser帐户的访问权限:

    ignacio ALL=(foouser) ALL
    

    而不是这种方式:

    ignacio ALL=(root) su - foouser
    

    以这种方式配置sudo将允许您定义例如您设想的别名:

    as_foo='sudo -u foouser'
    

    通过避免使用su -,您可以继续使用自己的自定义设置:sudo以这种方式使用只会更改用户身份,但会保持其先前的值,从您的主目录而不是'sHOME读取任何 shell 启动脚本和其他自定义设置。foouser

    (当然,其他用户也必须能够读取这些脚本,并且您可能运行的任何共享脚本最好foouser明确引用 的主目录,/home/foouser而不仅仅是$HOME.)

    但是,有一些sudo设置可能会阻止该解决方案工作:如果always_set_home在 sudoers 文件中设置了 sudo 选项,或者如果env_reset在未添加HOME到env_keep列表的情况下设置了选项,HOME则无论如何都会重置。在这种情况下,请尝试将-E选项添加到sudo命令以明确请求保留您的环境。

    并且当您真的想运行foouser与登录时完全一样的环境设置时foouser(即等效于sudo su - foouser),添加-i选项以专门请求该选项。100 %sudo -i -u foouser准确替换.sudo su - foouser

    如果您发现某些系统具有如此古老的版本而sudo没有该-i选项,请改用该-H选项和 sudo:它不是完美的替代品,但可能就足够了。这样一个旧版本sudo很可能也有一些对安全敏感的已知错误,所以无论如何更新它都是值得的。

    您可以使用sudo -l自己来查看您的 sudo 访问权限是如何定义的,以及哪些 sudo 选项(也称为默认条目)对您有效。

    • 1
  2. Ignacio Vazquez-Abrams
    2017-11-23T16:34:54+08:002017-11-23T16:34:54+08:00

    将附加参数传递给su.

    sudo su - foouser sh -c 'echo $USER'
    
    • -1

相关问题

  • 允许用户以 root 身份运行命令

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    JSON数组使用jq来bash变量

    • 4 个回答
  • Marko Smith

    日期可以为 GMT 时区格式化当前时间吗?[复制]

    • 2 个回答
  • Marko Smith

    bash + 通过 bash 脚本从文件中读取变量和值

    • 4 个回答
  • Marko Smith

    如何复制目录并在同一命令中重命名它?

    • 4 个回答
  • Marko Smith

    ssh 连接。X11 连接因身份验证错误而被拒绝

    • 3 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Marko Smith

    systemctl 命令在 RHEL 6 中不起作用

    • 3 个回答
  • Marko Smith

    rsync 端口 22 和 873 使用

    • 2 个回答
  • Marko Smith

    以 100% 的利用率捕捉 /dev/loop -- 没有可用空间

    • 1 个回答
  • Marko Smith

    jq 打印子对象中所有的键和值

    • 2 个回答
  • Martin Hope
    EHerman JSON数组使用jq来bash变量 2017-12-31 14:50:58 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Drux 日期可以为 GMT 时区格式化当前时间吗?[复制] 2017-12-26 11:35:07 +0800 CST
  • Martin Hope
    AllisonC 如何复制目录并在同一命令中重命名它? 2017-12-22 05:28:06 +0800 CST
  • Martin Hope
    Steve “root”用户的文件权限如何工作? 2017-12-22 02:46:01 +0800 CST
  • Martin Hope
    Bagas Sanjaya 为什么 Linux 使用 LF 作为换行符? 2017-12-20 05:48:21 +0800 CST
  • Martin Hope
    Cbhihe 将默认编辑器更改为 vim for _ sudo systemctl edit [unit-file] _ 2017-12-03 10:11:38 +0800 CST
  • Martin Hope
    showkey 如何下载软件包而不是使用 apt-get 命令安装它? 2017-12-03 02:15:02 +0800 CST
  • Martin Hope
    youxiao 为什么目录 /home、/usr、/var 等都具有相同的 inode 编号 (2)? 2017-12-02 05:33:41 +0800 CST
  • Martin Hope
    user223600 gpg —list-keys 命令在将私钥导入全新安装后输出 uid [未知] 2017-11-26 18:26:02 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve