shell运行环境之sudo的环境

 |   

shell运行环境之环境配置文件讲解了 Shell 里面四个配置文件的作用域以及 Shell 的四种常用模式。在此基础上,我们进一步探究一下在用户切换过程中,运行环境的变化。在 Ubuntu 里,我们通常使用 sudo 来提权,使用 su 来切换用户,而这两种操作都会对终端运行环境产生影响。搞明白运行环境的变化,你将明白如何在终端中使用代理。

简介

我们经常在终端中使用 sudo 来提权–以普通用户的身份去行使管理员的权限(前提是该用户在 /etc/sudoers 中被授权),这样减少了 root 用户的登录次数和管理时间,也提高了系统的安全性。不过有时我们也会直接用 su 切换到管理员进行一系列操作。susudo 虽然功能不一样,但是它们的目的大部分情况是为了获取 root 权限。

  • su 命令
    su 命令是 switch user 的简写,是用来切换用户的。当不加任何参数时,它将切换到 root 用户。它需要你想切换到的用户的密码,在输入密码后,你将切换到那个用户的运行环境。
  • sudo命令
    该命令是 superuser do 的简写,能够以 root 的权限去执行命令,但是它需要的是当前用户的密码,而不是像 su 需要的是想要切换到的用户的密码。这样需要执行一些需要root权限的命令时就不需要频繁输入 root 用户的密码,当然前提是当前用户的信息是存档在特殊的文件(/etc/sudoers)中。默认情况下,系统将记住当前用户的密码一段时间,以方便用户不用经常输入密码。

运行环境的变化

  • sudo
    根据 man 的说明,sudoers 提供了两种方法来限制 sudo 从用户环境中继承的变量。默认是 env_reset 变量是 enabled,此时将会执行一个新的,最小的环境 /etc/environment。另一种是设置 env_reset 变量是 disabled,此时 env_check 和 env_delete 充当白列表的作用,因此不建议第二种情况。
  • sudo su
    bash 将以一个交互非登录模式运行,所以只有两个 bashrc 文件(/etc/bash.bashrc 和 ~/.bashrc)将被执行。所以当用户切换成 root 后,我们还在当前的工作的目录,而非 /root 目录。
  • sudo su -
    bash 将以登录模式运行的,此时 /etc/profile 和 ~/.profile 将会被执行,隐形的 /etc/bash.bashrc 和 ~/.bashrc 也将会被执行。此时,我们的当前目录是 /root。
  • sudo -i
    -i 是 –login 的简写,所以接近 sudo su - 的情况
  • sudo /bin/bash
    bash 将以非登录模式运行,上面四个文件将不会被执行。

试验

问题

今天在公司准备使用命令行 sudo /opt/logstash/bin/plugin install logstash-output-webhdfs 给 logstash 安装logstash-output-webhdfs 插件,以实现将 logstash 收集的日志信息存储到 Hadoop 文件系统这一目的。但是却一直提示如下错误:

Unable to download data from https://rubygems.org/ - 连接被对端重置 (https://rubygems.global.ssl.fastly.net/latest_specs.4.8.gz)
ERROR: Installation aborted, verification failed for logstash-output-webhdfs

这里公司上网环境是使用了代理。本人在 ~/.bashrc 中添加了 export http_proxy=xxxexport https_proxy=xxx 设置。接下来按照网上的解决方法作了如下尝试,均已失败告终。

  1. 用 Google 搜索错误提示 Unable to download data from https://rubygems.org
  2. 手动安装插件logstash-output-webhdfs

解决方案

  1. 设置sudo的运行环境 使用 sudo visudo 对 /etc/sudoers 文件进行如下修改:

    1Defaults env_keep = "http_proxy https_proxy"
    2Defaults env_reset
    

    通过保留当前用户的 http_proxy 和 https_proxy 变量,使得 sudo 情况下也能使用代理。具体参考 这里

  2. 进入 root 用户,并设定 http_proxy 和 https_proxy 代理。

参考文献

  1. 如何更换rubygem镜像的源
  2. 如何手动安装logstash插件logstash-output-elasticsearch-shield
  3. 维基百科sudo
  4. su和sudo对运行环境的影响
  5. sudo使用代理
  6. sudo环境设置
技术茶话会
< 前一篇 后一篇 >