這篇文章主要講解了“l(fā)inux下chgrp和newgrp命令簡介”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“l(fā)inux下chgrp和newgrp命令簡介”吧!
創(chuàng)新互聯(lián)是一家專業(yè)提供豐南企業(yè)網(wǎng)站建設,專注與成都做網(wǎng)站、網(wǎng)站建設、H5高端網(wǎng)站建設、小程序制作等業(yè)務。10年已為豐南眾多企業(yè)、政府機構等服務。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站制作公司優(yōu)惠進行中。
chgrp
只是更改文件的組所有權。這與 chown :
命令相同。你可以使用:
$chown :alan mynotes
或者:
$chgrp alan mynotes
chgrp
和它的一些參數(shù)可以用在命令行和腳本中。就像許多其他 Linux 命令一樣,chgrp
有一個遞歸參數(shù) -R
。如下所示,你需要它來對文件夾及其內容進行遞歸操作。我加了 -v
(詳細)參數(shù),因此 chgrp
會告訴我它在做什么:
$ ls -l . conf.:drwxrwxr-x 2 alan alan 4096 Aug 5 15:33 conf conf:-rw-rw-r-- 1 alan alan 0 Aug 5 15:33 conf.xml# chgrp -vR delta confchanged group of 'conf/conf.xml' from alan to deltachanged group of 'conf' from alan to delta
當你要更改文件的組以匹配特定的配置,或者當你不知道具體的組時(比如你運行一個腳本時),可使用參考文件 (--reference=RFILE
)。你可以復制另外一個作為參考的文件(RFILE)的組。比如,為了撤銷上面的更改 (請注意,點 .
代表當前工作目錄):
$ chgrp -vR --reference=. conf
大多數(shù)命令都有用于控制其輸出的參數(shù)。最常見的是 -v
來啟用詳細信息,而且 chgrp
命令也擁有詳細模式。它還具有 -c
(--changes
)參數(shù),指示 chgrp
僅在進行了更改時報告。chgrp
還會報告其他內容,例如是操作不被允許時。
參數(shù) -f
(--silent
、--quiet
)用于禁止顯示大部分錯誤消息。我將在下一節(jié)中使用此參數(shù)和 -c
來顯示實際更改。
Linux 文件系統(tǒng)的根目錄(/
)應該受到高度重視。如果命令在此層級犯了一個錯誤,那么后果可能是可怕的,并會讓系統(tǒng)無法使用。尤其是在運行一個會遞歸修改甚至刪除的命令時。chgrp
命令有一個可用于保護和保持根目錄的參數(shù)。它是 --preserve-root
。如果在根目錄中將此參數(shù)和遞歸一起使用,那么什么也不會發(fā)生,而是會出現(xiàn)一條消息:
[root@localhost /]# chgrp -cfR --preserve-root a+w /chgrp: it is dangerous to operate recursively on '/'chgrp: use --no-preserve-root to override this failsafe
不與遞歸(-R)結合使用時,該選項無效。但是,如果該命令由 root
用戶運行,那么 /
的權限將會更改,但其下的其他文件或目錄的權限則不會被更改:
[alan@localhost /]$ chgrp -c --preserve-root alan /chgrp: changing group of '/': Operation not permitted[root@localhost /]# chgrp -c --preserve-root alan /changed group of '/' from root to alan
令人驚訝的是,它似乎不是默認參數(shù)。而選項 --no-preserve-root
是默認的。如果你在不帶“保持”選項的情況下運行上述命令,那么它將默認為“無保持”模式,并可能會更改不應更改的文件的權限:
[alan@localhost /]$ chgrp -cfR alan /changed group of '/dev/pts/0' from tty to alanchanged group of '/dev/tty2' from tty to alanchanged group of '/var/spool/mail/alan' from mail to alan
newgrp
命令允許用戶覆蓋當前的主要組。當你在所有文件必須有相同的組所有權的目錄中操作時,newgrp
會很方便。假設你的內網(wǎng)服務器上有一個名為 share
的目錄,不同的團隊在其中存儲市場活動照片。組名為 share
。當不同的用戶將文件放入目錄時,文件的主要組可能會變得混亂。每當添加新文件時,你都可以運行 chgrp
將錯亂的組糾正為 share
:
$ cd sharels -l-rw-r--r--. 1 alan share 0 Aug 7 15:35 pic13-rw-r--r--. 1 alan alan 0 Aug 7 15:35 pic1-rw-r--r--. 1 susan delta 0 Aug 7 15:35 pic2-rw-r--r--. 1 james gamma 0 Aug 7 15:35 pic3-rw-rw-r--. 1 bill contract 0 Aug 7 15:36 pic4
我在 chmod 命令的文章中介紹了 setgid
模式。它是解決此問題的一種方法。但是,假設由于某種原因未設置 setgid
位。newgrp
命令在此時很有用。在任何用戶將文件放入 share
目錄之前,他們可以運行命令 newgrp share
。這會將其主要組切換為 share
,因此他們放入目錄中的所有文件都將有 share
組,而不是用戶自己的主要組。完成后,用戶可以使用以下命令切換回常規(guī)主要組(舉例):
newgrp alan
感謝各位的閱讀,以上就是“l(fā)inux下chgrp和newgrp命令簡介”的內容了,經(jīng)過本文的學習后,相信大家對linux下chgrp和newgrp命令簡介這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關知識點的文章,歡迎關注!