Shell运行环境之sudo的环境
nanshan 2024-11-24 19:39 15 浏览 0 评论
Shell运行环境之环境配置文件[1] 讲解了 Shell 里面四个配置文件的作用域以及 Shell 的四种常用模式。在此基础上,我们进一步探究一下在用户切换过程中,运行环境的变化。在 Ubuntu 里,我们通常使用 sudo 来提权,使用 su 来切换用户,而这两种操作都会对终端运行环境产生影响。搞明白运行环境的变化,你将明白如何在终端中使用代理。
简介
我们经常在终端中使用 sudo 来提权--以普通用户的身份去行使管理员的权限(前提是该用户在 /etc/sudoers 中被授权),这样减少了 root 用户的登录次数和管理时间,也提高了系统的安全性。不过有时我们也会直接用 su 切换到管理员进行一系列操作。su 和 sudo 虽然功能不一样,但是它们的目的大部分情况是为了获取 root 权限。
? su 命令
su 命令是 switch user 的简写,是用来切换用户的。当不加任何参数时,它将切换到 root 用户。它需要你想切换到的用户的密码,在输入密码后,你将切换到那个用户的运行环境。
? sudo[2]命令
该命令是 superuser do 的简写,能够以 root 的权限去执行命令,但是它需要的是当前用户的密码,而不是像 su 需要的是想要切换到的用户的密码。这样需要执行一些需要root权限的命令时就不需要频繁输入 root 用户的密码,当然前提是当前用户的信息是存档在特殊的文件(/etc/sudoers)中。默认情况下,系统将记住当前用户的密码一段时间,以方便用户不用经常输入密码。
运行环境的变化[3]
? 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=xxx 和 export https_proxy=xxx 设置。接下来按照网上的解决方法作了如下尝试,均已失败告终。
- 用 Google 搜索错误提示Unable to download data from https://rubygems.org[4]
- 手动安装插件logstash-output-webhdfs[5]
解决方案
- 设置sudo的运行环境[6] 使用 sudo visudo 对 /etc/sudoers 文件进行如下修改:
Defaults env_keep = "http_proxy https_proxy"
Defaults env_reset
通过保留当前用户的 http_proxy 和 https_proxy 变量,使得 sudo 情况下也能使用代理。具体参考这里[7]。
- 进入 root 用户,并设定 http_proxy 和 https_proxy 代理。
参考文献
1.如何更换rubygem镜像的源[8]
2.如何手动安装logstash插件logstash-output-elasticsearch-shield[9]
3.维基百科sudo[10]
4.su和sudo对运行环境的影响[11]
5.sudo使用代理[12]
6.sudo环境设置[13]
References
[1] Shell运行环境之环境配置文件: https://blog.haojunyu.com/post/shell_sudo/
[2] sudo: https://zh.wikipedia.org/zh/Sudo
[3] 运行环境的变化: http://askubuntu.com/questions/376199/sudo-su-vs-sudo-i-vs-sudo-bin-bash-when-does-it-matter-which-is-used
[4] Unable to download data from https://rubygems.org: https://help.rubygems.org/discussions/problems/31565-unable-to-download-data-from-httpsrubygemsorg-timed-out
[5] 手动安装插件logstash-output-webhdfs: https://discuss.elastic.co/t/shield-w-logstash-offline-install/25072
[6] 设置sudo的运行环境: https://getpocket.com/a/read/149876899
[7] 这里: http://my.oschina.net/alphajay/blog/28811
[8] 如何更换rubygem镜像的源: https://help.rubygems.org/discussions/problems/31565-unable-to-download-data-from-httpsrubygemsorg-timed-out
[9] 如何手动安装logstash插件logstash-output-elasticsearch-shield: https://discuss.elastic.co/t/shield-w-logstash-offline-install/25072
[10] 维基百科sudo: https://zh.wikipedia.org/zh/Sudo
[11] su和sudo对运行环境的影响: http://askubuntu.com/questions/376199/sudo-su-vs-sudo-i-vs-sudo-bin-bash-when-does-it-matter-which-is-used
[12] sudo使用代理: https://getpocket.com/a/read/149876899
[13] sudo环境设置: http://my.oschina.net/alphajay/blog/28811
如果该文章对您产生了帮助,或者您对技术文章感兴趣,可以关注微信公众号: 技术茶话会, 能够第一时间收到相关的技术文章,谢谢!
相关推荐
- 雷军1994年写的老代码曝光,被称像诗一样优雅
-
大数据文摘授权转载自程序员的那些事雷军的代码像诗一样优雅↓↓↓有些网友在评论中质疑,说雷军代码不会是“屎”一样优雅吧。说这话的网友,也许是开玩笑的,也许是真没看过雷军写过的代码。在2011年的时候,我...
- 原创经验分享:低级bug耗费12小时Fix
-
调试某程序非常简单的程序,简单到认为不可能存在缺陷,但该BUG处理时间超过12小时:程序属于后台进程,监控系统每隔15秒检查外设IO状态,IO异常后发出报警或复位外设,外设都在linux下有/sys/...
- SpringBoot实现的简单停车位管理系统附带导入和演示教程视频
-
这一次为大家带来的是简单的停车位管理系统,基于SpringBoot+Thymeleaf+Mybatis框架,这个系统相对来说比较简单,很容易学习并快速上手,因为逻辑很清晰,没有太复杂的代码逻辑,所以学...
- 一个开箱即用的代码生成器(代码自动生成工具开源)
-
今天给大家推荐一个好用的代码生成器,名为renren-generator,该项目附带前端页面,可以很方便的选择我们所需要生成代码的表。首先我们通过git工具克隆下来代码(地址见文末),导入idea。...
- 【免费开源】JeecgBoot单点登录源码全部开源了
-
JeecgBoot单点登录源码全部开源了,有需要的朋友可以来薅羊毛了。一、JeecgBoot介绍JeecgBoot是一款企业级的低代码平台!前后端分离架构SpringBoot2.x,SpringCl...
- SpringBoot+JWT+Shiro+Mybatis实现Restful快速开发后端脚手架
-
作者:lywJee来源:cnblogs.com/lywJ/p/11252064.html一、背景前后端分离已经成为互联网项目开发标准,它会为以后的大型分布式架构打下基础。SpringBoot使编码配置...
- 为什么越来越多的人选择使用idea软件
-
IDEA软件是什么?IDEA软件是干什么的?为什么越来越多的人选择使用IDEA软件?IDEA软件,全称IntelliJIDEA,它是由JetBrains公司开发开发的一款功能强大的集成开发环境(ID...
- 开题报告大学生互助系统(附源码)java毕设
-
本系统(程序+源码)带文档lw万字以上文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容选题背景随着互联网技术的飞速发展,大学生群体对信息共享与互助的需求日益增长。关于大...
- SpringBoot项目快速开发框架JeecgBoot——项目简介及系统架构!
-
项目简介及系统架构JeecgBoot是一款基于SpringBoot的开发平台,它采用前后端分离架构,集成的框架有SpringBoot2.x、SpringCloud、AntDesignof...
- 新手配电脑13代CPU怎么选择(新手配电脑13代cpu怎么选择好)
-
Intel第13代酷睿i3、i5、i7、i9系列处理器的核心参数、性能差异及适用群体的详细说明(以桌面端为例):一、13代酷睿全系参数对比(桌面端主流型号)参数i3-13100i5-13600Ki7-...
- 加速 SpringBoot 应用开发,官方热部署神器真带劲
-
平时使用SpringBoot开发应用时,修改代码后需要重新启动才能生效。如果你的应用足够大的话,启动可能需要好几分钟。有没有什么办法可以加速启动过程,让我们开发应用代码更高效呢?今天给大家推荐一款Sp...
- 基于微信小程序的移动端物流系统-计算机毕业设计源码+LW文档
-
摘要随着Internet的发展,人们的日常生活已经离不开网络。未来人们的生活与工作将变得越来越数字化,网络化和电子化。网上管理,它将是直接管理移动端物流系统app的最新形式。本论文是以构建移动端物流系...
- springboot教务管理系统+微信小程序云开发附带源码
-
今天给大家分享的程序是基于springboot的管理,前端是小程序,系统非常的nice,不管是学习还是毕设都非常的靠谱。本系统主要分为pc端后台管理和微信小程序端,pc端有三个角色:管理员、学生、教师...
- SpringBoot全家桶:23篇博客加23个可运行项目让你对它了如指掌
-
SpringBoot现在已经成为Java开发领域的一颗璀璨明珠,它本身是包容万象的,可以跟各种技术集成。本项目对目前Web开发中常用的各个技术,通过和SpringBoot的集成,并且对各种技术通...
- Maven+JSP+Servlet+C3P0+Mysql实现的音乐库管理系统
-
本系统基于Maven+JSP+Servlet+C3P0+Mysql实现的音乐库管理系统。简单实现了充值、购买歌曲、poi数据导入导出、歌曲上传下载、歌曲播放、用户注册登录注销等功能。难度等级:简单技术...
你 发表评论:
欢迎- 一周热门
-
-
UOS服务器操作系统防火墙设置(uos20关闭防火墙)
-
极空间如何无损移机,新Z4 Pro又有哪些升级?极空间Z4 Pro深度体验
-
如何修复用户配置文件服务在 WINDOWS 上登录失败的问题
-
手机如何设置与显示准确时间的详细指南
-
如何在安装前及安装后修改黑群晖的Mac地址和Sn系列号
-
日本海上自卫队的军衔制度(日本海上自卫队的军衔制度是什么)
-
NAS:DS video/DS file/DS photo等群晖移动端APP远程访问的教程
-
爱折腾的特斯拉车主必看!手把手教你TESLAMATE的备份和恢复
-
10个免费文件中转服务站,分享文件简单方便,你知道几个?
-
FANUC 0i-TF数据备份方法(fanuc系统备份教程)
-
- 最近发表
- 标签列表
-
- linux 查询端口号 (58)
- docker映射容器目录到宿主机 (66)
- 杀端口 (60)
- yum更换阿里源 (62)
- internet explorer 增强的安全配置已启用 (65)
- linux自动挂载 (56)
- 禁用selinux (55)
- sysv-rc-conf (69)
- ubuntu防火墙状态查看 (64)
- windows server 2022激活密钥 (56)
- 无法与服务器建立安全连接是什么意思 (74)
- 443/80端口被占用怎么解决 (56)
- ping无法访问目标主机怎么解决 (58)
- fdatasync (59)
- 405 not allowed (56)
- 免备案虚拟主机zxhost (55)
- linux根据pid查看进程 (60)
- dhcp工具 (62)
- mysql 1045 (57)
- 宝塔远程工具 (56)
- ssh服务器拒绝了密码 请再试一次 (56)
- ubuntu卸载docker (56)
- linux查看nginx状态 (63)
- tomcat 乱码 (76)
- 2008r2激活序列号 (65)