sudo
终端中的sudo命令 |
|
| 開發者 | Todd C. Miller |
|---|---|
| 穩定版本 | 1.8.6p8/ 2013年4月11日 |
| 預覽版本 | 1.8.7rc2/ 2013年5月4日 |
| 作業系統 | Unix-like |
| 類型 | 權限授權 |
| 許可協議 | ISC-style[1] |
| 網站 | www.sudo.ws |
Sudo(substitute user [或 superuser] do),是一種程式,用於類Unix作業系統如BSD,Mac OS X,以及GNU/Linux以允許使用者透過安全的方式使用特殊的權限執行程式(通常為系統的超級使用者)。
目录 |
原理 [编辑]
在sudo於1980年前後被寫出之前[2],一般使用者管理系統的方式是利用su切換為超級使用者。但是使用su的缺點之一在於必須要先告知超級使用者的密碼。
sudo使一般使用者不需要知道超級使用者的密碼即可獲得權限。首先超級使用者將普通用户的名字、可以执行的特定命令、按照哪种用户或用户组的身份执行等信息,登記在特殊的檔案中(通常是/etc/sudoers),即完成對該使用者的授權(此時該使用者稱為「sudoer」)[3];在一般使用者需要取得特殊權限時,其可在命令前加上「sudo」,此時sudo將會詢問該使用者自己的密碼(以確認終端機前的是該使用者本人),回答後系統即會將該命令的进程以超級使用者的權限執行。之後的一段時間內(預設為5分鐘[4],可在/etc/sudoers自訂),使用sudo不需要再次輸入密碼。
由於不需要超級使用者的密碼,部分Unix系統甚至利用sudo使一般使用者取代超級使用者作為管理帳號,例如Ubuntu、Mac OS X等。
语法 [编辑]
sudo [-bhHpV][-s ][-u <用户>][指令]
或
sudo [-klv]
参数 [编辑]
-b 在后台执行指令。
-h 显示帮助。
-H 将HOME环境变量设为新身份的HOME环境变量。
-k 结束密码的有效期限,也就是下次再执行sudo时便需要输入密码。
-l 列出目前用户可执行与无法执行的指令。
-p 改变询问密码的提示符号。
-s 执行指定的shell。
-u <用户> 以指定的用户作为新的身份。若不加上此参数,则预设以root作为新的身份。
-v 延长密码有效期限5分钟。
-V 显示版本信息。
-S 从标准输入流替代终端来获取密码
參考資訊 [编辑]
- ^ Sudo License
- ^ Miller, Todd C. A Brief History of Sudo. [2008-06-20].
- ^ 在Ubuntu系统中,管理员通过执行
visudo来编辑/etc/sudoers,给普通用户授予某些sudo的权力 - ^ 依各發行版可能有所異同,例如Ubuntu下預設為15分鐘。
外部連結 [编辑]
- 官方网站
- How to audit and log user and root shells with sudo via sudosh
- sudo tools
- a logging root shell
- sudo(8) man page from OpenBSD
- sudo(8) man page from linuxmanpages.com
- sudo explained in webcomic form by en:xkcd
|
|||||||||||||||||||||||||||||