免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 6022 | 回复: 4
打印 上一主题 下一主题

sudo 的环境变量保持与重置问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-05-26 14:17 |只看该作者 |倒序浏览
在使用sudo是,我观察到sudo对环境变量的处理的有趣现象,请看描述:

现有如下脚本:
myecho.sh
  1. #!/bin/bash
  2. echo $HOME
复制代码
添加 +x可执行文件属性。
$>chmod +x myecho.sh

然后在有sudo权限的普通用户shell下执行如下命令, 本人在fedora16是用一个隶属与wheel组的账户操作。/etc/sudoers文件除了去掉wheel组的注释外没做其他修改:
$>echo $HOME
输出:/home/somebody

$>sudo echo $HOME
输出:/home/somebody

$>sudo ./myecho.sh
输出:/root

问题:为什么sudo执行相同的指令(myecho.sh脚本只包含一个简单的echo 命令,执行脚本就等于执行一次 echo )却得到不同的结果?

论坛徽章:
13
15-16赛季CBA联赛之同曦
日期:2016-01-28 19:52:032015亚冠之北京国安
日期:2015-10-07 14:28:19NBA常规赛纪念章
日期:2015-05-04 22:32:03处女座
日期:2015-01-15 19:45:44卯兔
日期:2014-10-28 16:17:14白羊座
日期:2014-05-24 15:10:46寅虎
日期:2014-05-10 09:50:35白羊座
日期:2014-03-12 20:52:17午马
日期:2014-03-01 08:37:27射手座
日期:2014-02-19 19:26:54子鼠
日期:2013-11-30 09:03:56狮子座
日期:2013-09-08 08:37:52
2 [报告]
发表于 2012-05-26 14:32 |只看该作者
$>sudo echo $HOME
/home/somebody     # 当前shell环境没有改变, echo读取当前变量

$>sudo ./myecho.sh # 当前shell环境已经变为root 这是 fork-and-exec 在子进程中运行
/root

Fork-exec is a commonly used technique in Unix whereby an executing process spawns a new program.

论坛徽章:
0
3 [报告]
发表于 2012-05-26 17:23 |只看该作者
本帖最后由 millerixlee 于 2012-05-26 17:54 编辑

回 2楼
$> sudo sleep 100
$> ps axuf
会看到sudo指令会产生两次fork,第一次是从bash 本身 fork然后立刻 execve 指令“ sudo sleep 100”得到子进程 sudo sleep 100 称之为child1, 这个子进程的用户是root; 第二次fork是从 新产生的子进程child1再生成一个新的子进程 “sleep 100”,称为child2.
bash  
\
   ---> sudo sleep 100
         \
            ---> sleep 100
所以
sudo echo $HOME
bash  
\
   ---> sudo echo $HOME   ###ps axuf是不会看到 $HOME的, 因为 该环境变量已经被shell展开了。(该注释是觉悟后添加的)
         \
            ---> echo $HOME
与 sudo  ./myecho.sh
bash  
\
   ---> sudo ./myecho.sh
         \
            ---> /bin/sh myecho.sh
可见都是在所谓的 fork -execve 的子进程运行。 何来sudo echo $HOME 的当前shell环境变量不改变?

论坛徽章:
0
4 [报告]
发表于 2012-05-26 17:49 |只看该作者
我觉悟了。
原来bash 在把 $HOME传递给子进程之前会进行变量扩展, 而此时是处于当前的shell环境中, 也就是说环境变量没有改变。
然而, sudo去执行一个脚本时, 脚本是在当前bash的孙子进程中执行的, 孙子进程会被sudo 重置环境变量。 这样当前bash 的环境变量就传递不到 这个孙子进程中了。
另外,顺便提议下,要想sudo 保持 当前bash的环境变量有两种方法(据我所知道的):一个是:sudo -E; 另一个是编辑 /etc/sudoers文件中的 env_keep 参数。
谢谢二楼

论坛徽章:
15
2015年辞旧岁徽章
日期:2015-03-03 16:54:15双鱼座
日期:2015-01-15 17:29:44午马
日期:2015-01-06 17:06:51子鼠
日期:2014-11-24 10:11:13寅虎
日期:2014-08-18 07:10:55酉鸡
日期:2014-04-02 12:24:51双子座
日期:2014-04-02 12:19:44天秤座
日期:2014-03-17 11:43:36亥猪
日期:2014-03-13 08:13:51未羊
日期:2014-03-11 12:42:03白羊座
日期:2013-11-20 10:15:18CU大牛徽章
日期:2013-04-17 11:48:45
5 [报告]
发表于 2012-05-26 20:55 |只看该作者
可以这样想,用sudo后跟执行命令的时候,你是被当作root来执行命令的, 当然用的是root的环境。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP