【转】sudo命令情景分析
文章转自:http://www.cnblogs.com/hazir/p/sudo_command.html
Linux 下使用 sudo
命令,可以让普通用户也能执行一些或者全部的 root 命令。本文就对我们常用到 sudo 操作情景进行简单分析,通过一些例子来了解 sudo 命令相关的技巧。
情景一:用户无权限执行 root 命令
普通用户登录 shell 之后,如果自身没有权限访问某个文件或执行某个命令时,若该用户获得root授权,那么就可以在需要执行的命令之前加上 sudo,临时切换到root用户的权限,完成相关的操作。在sudo于1980年前后被写出之前,一般用户管理系统的方式是利用su切换为超级用户。但是使用su的缺点之一在于必须要先告知超级用户的密码,而sudo使一般用户不需要知道超级用户的密码即可获得权限。
那么哪些用户可以临时获得 root 权限呢?这就需要在 /etc/sudoers 文件中进行配置:
授权给单个用户:
- # User privilege specification
- guohl ALL=(ALL) ALL
上面这个例子中:
- guohl:允许使用 sudo 的用户名
- ALL:允许从任何终端(任何机器)使用 sudo
- (ALL):允许以任何用户执行 sudo 命令
- ALL:允许 sudo 权限执行任何命令
如果我们想让用户 test 只能在本主机(主机名为guohl-pc)以 root 账户执行/bin/chown、/bin/chmod 两条命令,那么就应该这样配置:
- # User privilege specification
- test guohl-pc=(root) /bin/chown,/bin/chmod
如果test 登录之后运行 sudo 命令,不满足上面三个条件命令均失败。
授权给用户组:
- # Allow members of group sudo to execute any command
- # (Note that later entries override this, so you might need to move it further down)
- %sudo ALL=(ALL) ALL
和授权给单个用户类似,只不过将用户名在这里换成%组名
,所有在该组中的用户都按照此规则进行授权。对于该例,所有在 sudo 组内的用户都有在任何终端(第一个ALL)、以任何用户(第二个ALL)、执行任何命令(第三个ALL)的权限,查看 /etc/group 文件可以知道哪些用户属于 sudo 组。
举例:
如果当前帐号在 /etc/sudoers 文件中被授予 sudo 的权限,那么你就可以将任何 root 命令作为 sudo 命令的参数,使用 root 权限来执行该命令。举例来说,挂载一个文件系统只能由 root 来执行,但是一个普通用户也可以使用 sudo 来挂载:
- $sudo mount /dev/sda7 /mnt
- [sudo] password for guohailin:
首次使用会要求你输入当前用户的密码,系统确实输入正确即以 root 权限来执行 mount 命令,接下来一段时间(默认为5分钟)再次使用 sudo 命令就不需要输密码了。
情景二:vim 编辑后发现忘记使用 sudo
我们经常会遇到这样的一个囧境:使用 vim 对某个文件进行编辑,编辑完之后,按 ESC
之后回到普通模式,再按 :wq
准备保存退出时,发现没有权限对该文件进行修改,我们在使用 vim 命令时忘记在前面加 sudo 了。我就经常出现这种问题,之前的做法是只能不保存强退,再加上 sudo 重新编辑。
但是今后我们再也不需要用这么愚蠢的做法了,我们可以在 vim 的普通模式下,按 :w !sudo tee %
,这样就可以 root 权限来保存文件了,你也无需因为自己一时忘记加个 sudo 而沮丧懊恼了!
情景三:执行 root 命令忘记加 sudo
我们还会遇到这样稍微好一点的情形:输入一个长长的命令,按 Enter
之后出现无权限操作,因为我们忘记加 sudo 了。大多人的做法是按 ↑
回到上一条命令,在该命令之前加上 sudo,再执行该命令。
以后,我们无需这样了,只要输入 sudo !!
即可,这里的 !! 代表上一条命令。如:
- $ head -n /etc/sudoers
- head: cannot open `/etc/sudoers' for reading: Permission denied
- $ sudo !!
- sudo head -n /etc/sudoers
- # /etc/sudoers
- #
- # This file MUST be edited with the 'visudo' command as root.
- #
- 情景四:shell 内置命令如何使用 sudo
shell 是一个交互式的应用程序,在执行外部命令时通过 fork 来创建一个子进程,再通过 exec 来加载外部命令的程序来执行,但是如果一个命令是 shell 内置命令,那么只能直接由 shell 来运行。sudo 的意思是,以别的用户(如root)的权限来 fork 一个进程,加载程序并运行,因此 sudo 后面不能跟 shell 的内置命令,如:
- $ sudo cd /sys/kernel/debugfs
- sudo: cd: command not found
在这种情况,我们又没有 root 账户的密码,我们怎样执行该命令呢?有种办法就是使用 sudo 获得root shell 的权限,然后在root shell 中执行该命令。进入root shell 很简单,输入sudo bash
确认本用户的密码即可,此时你会发现命令提示符显示当前是 root。一旦获得root shell,你可以执行任何命令而不需要在每条命令前输入sudo了。
另外,常用的shell 内置命令在这里 有简单介绍,我们可以使用 type 命令来查看命令的类型,如:
- $ type ls
- ls is /bin/ls
- $ type umask
- umask is a shell builtin
情景五:sudo 操作记录日志
作为一个 Linux 系统的管理员,不仅可以让指定的用户或用户组作为root用户或其它用户来运行某些命令,还能将指定的用户所输入的命令和参数作详细的记录。而sudo的日志功能就可以用户跟踪用户输入的命令,这不仅能增进系统的安全性,还能用来进行故障检修。但是要记录sudo的日志还要一些简单的配置:
创建sudo日志文件
我们将sudo日志文件放置在/var/log/sudo.log
文件中:- $ sudo touch /var/log/sudo.log
修改
/etc/rsyslog.conf
配置文件
我使用系统为Ubuntu13.04 为改名字,但有些系统名为/etc/syslog.conf
,注意不同发行版之间的差别,在该文件加入下面一行:- local2.debug /var/log/sudo.log #空白不能用空格,必须用tab
- 修改
/etc/sudoers
配置文件
注意网上很多关于sudo日志文件配置都缺少这一步!在该文件中加入下面一行:- Defaults logfile=/var/log/sudo.log
- 重启 syslog 服务:
- $ sudo service rsyslog restart
查看 sudo 日志记录:
经过上面的配置,sudo 的所有成功和不成功的sudo
命令都记录到文件/var/log/sudo.log 中,例如我运行几条sudo 命令之后,查看该文件的记录如下:- $ cat sudo.log
- Sep :: : guohailin : TTY=pts/ ; PWD=/var/log ; USER=root ;
- COMMAND=/bin/cat /etc/sudoers
- Sep :: : guohailin : TTY=pts/ ; PWD=/var/log ; USER=root ;
- COMMAND=/usr/sbin/service rsyslog restart
- Sep :: : guohailin : TTY=pts/ ; PWD=/var/log ; USER=root ;
- COMMAND=/bin/ls
- Sep :: : guohailin : TTY=pts/ ; PWD=/var/log ; USER=root ;
- COMMAND=/bin/ls /root/
- $ cat sudo.log
参考资料:
【转】sudo命令情景分析的更多相关文章
- sudo 命令情景分析
Linux 下使用 sudo 命令,可以让普通用户也能执行一些或者全部的 root 命令.本文就对我们常用到 sudo 操作情景进行简单分析,通过一些例子来了解 sudo 命令相关的技巧. 情景一:用 ...
- sodu 命令场景分析
摘自:http://www.cnblogs.com/hazir/p/sudo_command.html sudo 命令情景分析 Linux 下使用 sudo 命令,可以让普通用户也能执行一些或者全 ...
- Linux内核源代码情景分析系列
http://blog.sina.com.cn/s/blog_6b94d5680101vfqv.html Linux内核源代码情景分析---第五章 文件系统 5.1 概述 构成一个操作系统最重要的就 ...
- 《Android系统源代码情景分析》连载回忆录:灵感之源
上个月,在花了一年半时间之后,写了55篇文章,分析完成了Chromium在Android上的实现,以及Android基于Chromium实现的WebView.学到了很多东西,不过也挺累的,平均不到两个 ...
- Android系统--输入系统(十四)Dispatcher线程情景分析_dispatch前处理
Android系统--输入系统(十四)Dispatcher线程情景分析_dispatch前处理 1. 回顾 我们知道Android输入系统是Reader线程通过驱动程序得到上报的输入事件,还要经过处理 ...
- Android : 跟我学Binder --- (4) 驱动情景分析
目录: Android : 跟我学Binder --- (1) 什么是Binder IPC?为何要使用Binder机制? Android : 跟我学Binder --- (2) AIDL分析及手动实现 ...
- UBuntu sudo 命令 :xxx is not in the sudoers file. This incident will be reported.
[1]分析问题 提示内容翻译成中文即:用户XXX(一般是新添加的用户名称)没有权限使用sudo. 解决方法修改新用户的权限,具体操作即修改一下/etc/sudoers文件. [2]切换至root用户模 ...
- 10.7 android输入系统_Dispatcher线程情景分析_Reader线程传递事件和dispatch前处理
android输入系统C++最上层文件是com_android_serve_input_InputManagerService.cpp global key:按下按键,启动某个APP可以自己指定,修改 ...
- 转 Linux sudo命令
脚本中使用$HOME变量 问题描述:某些同事原来写的脚本中包含如下内容. BIN_DIR=${HOME}/tools TAIR_BIN_DIR=${HOME}/tair_binTAIR_SRC_DIR ...
随机推荐
- JS Math对象中一些小技巧
JS中快速获取数组中最大/最小值 var a=[1,2,3,5]; alert(Math.max.apply(Math, a));//最大值 alert(Math.min.apply(Math, a) ...
- hpp头文件与h头文件的区别
hpp,其实质就是将.cpp的实现代码混入.h头文件当中,定义与实现都包含在同一文件,则该类的调用者只需要include该hpp文件即可,无需再将cpp加入到project中进行编译.而实现代码将直接 ...
- HBase体系结构
HBase的服务器体系结构遵从简单的主从服务器架构,它由HRegion服务器(HRegion Service)群和HBase Master服务器(HBase Master Server)构成.Hbas ...
- [CF #290-C] Fox And Names (拓扑排序)
题目链接:http://codeforces.com/contest/510/problem/C 题目大意:构造一个字母表,使得按照你的字母表能够满足输入的是按照字典序排下来. 递归建图:竖着切下来, ...
- IMX6下移植WKxxx驱动
wkXXX.c #include<linux/init.h> #include <linux/module.h> #include <linux/kernel.h> ...
- php数组转换成json格式。
{ "touser":"OPENID", "template_id":"ngqIpbwh8bUfcSsECmogfXcV14J0t ...
- Flask——route
Flask——route 关于路由flask中有三种方法(例子)处理: flask.Flask.route 装饰器(关于装饰器可以参考该文),这时最常见的使用方法,在装饰器的参数中加入想要的路由即可, ...
- VBS在指定范围内生成不重复的随机数
Dim Z()ReDim Z(15)For i=0 To UBound(Z) Z(i)=GetRndNum(i-1,UBound(Z)) WScript.Echo Z(i)Next Fun ...
- tomcat的乱码问题
String filename=request.getParameter("filename"); filename=new String(filename.getBytes(&q ...
- vagrant系列教程(四):vagrant搭建redis与redis的监控程序redis-stat(转)
上一篇php7环境的搭建 真是火爆,仅仅两天时间,就破了我之前swagger系列的一片文章,看来,大家对搭建环境真是情有独钟. 为了访问量,我今天再来一篇Redis的搭建.当然不能仅仅是redis的搭 ...