## 6.8 本章習題:
( 要看答案請將鼠標移動到“答:”下面的空白處,按下左鍵圈選空白處即可察看 )
* * *
情境仿真題一:假設系統中有兩個帳號,分別是 alex 與 arod ,這兩個人除了自己群組之外還共同支持一個名為 project 的群組。假設這兩個用戶需要共同擁有 /srv/ahome/ 目錄的開發權,且該目錄不許其他人進入查閱。 請問該目錄的權限設置應為何?請先以傳統權限說明,再以 SGID 的功能解析。
* 目標:了解到為何專案開發時,目錄最好需要設置 SGID 的權限!
* 前提:多個帳號支持同一群組,且共同擁有目錄的使用權!
* 需求:需要使用 root 的身份來進行 chmod, chgrp 等幫用戶設置好他們的開發環境才行! 這也是管理員的重要任務之一!
首先我們得要先制作出這兩個帳號的相關數據,帳號/群組的管理在后續我們會介紹, 您這里先照著下面的指令來制作即可:
```
[root@study ~]# groupadd project <==增加新的群組
[root@study ~]# useradd -G project alex <==創建 alex 帳號,且支持 project
[root@study ~]# useradd -G project arod <==創建 arod 帳號,且支持 project
[root@study ~]# id alex <==查閱 alex 帳號的屬性
uid=1001(alex) gid=1002(alex) groups=1002(alex),1001(project) <==確實有支持!
[root@study ~]# id arod
uid=1002(arod) gid=1003(arod) groups=1003(arod),1001(project) <==確實有支持!
```
然后開始來解決我們所需要的環境吧!
1. 首先創建所需要開發的專案目錄:
```
[root@study ~]# mkdir /srv/ahome
[root@study ~]# ll -d /srv/ahome
drwxr-xr-x. 2 root root 6 Jun 17 00:22 /srv/ahome
```
2. 從上面的輸出結果可發現 alex 與 arod 都不能在該目錄內創建文件,因此需要進行權限與屬性的修改。 由于其他人均不可進入此目錄,因此該目錄的群組應為project,權限應為770才合理。
```
[root@study ~]# chgrp project /srv/ahome
[root@study ~]# chmod 770 /srv/ahome
[root@study ~]# ll -d /srv/ahome
drwxrwx---. 2 root project 6 Jun 17 00:22 /srv/ahome
# 從上面的權限結果來看,由于 alex/arod 均支持 project,因此似乎沒問題了!
```
3. 實際分別以兩個使用者來測試看看,情況會是如何?先用 alex 創建文件,然后用 arod 去處理看看。
```
[root@study ~]# su - alex <==先切換身份成為 alex 來處理
[alex@www ~]$ cd /srv/ahome <==切換到群組的工作目錄去
[alex@www ahome]$ touch abcd <==創建一個空的文件出來!
[alex@www ahome]$ exit <==離開 alex 的身份
[root@study ~]# su - arod
[arod@www ~]$ cd /srv/ahome
[arod@www ahome]$ ll abcd
-rw-rw-r--. 1 alex alex 0 Jun 17 00:23 abcd
# 仔細看一下上面的文件,由于群組是 alex ,arod并不支持!
# 因此對于 abcd 這個文件來說, arod 應該只是其他人,只有 r 的權限而已啊!
[arod@www ahome]$ exit
```
由上面的結果我們可以知道,若單純使用傳統的 rwx 而已,則對剛剛 alex 創建的 abcd 這個文件來說, arod 可以刪除他,但是卻不能編輯他!這不是我們要的樣子啊!趕緊來重新規劃一下。
4. 加入 SGID 的權限在里面,并進行測試看看:
```
[root@study ~]# chmod 2770 /srv/ahome
[root@study ~]# ll -d /srv/ahome
drwxrws---. 2 root project 17 Jun 17 00:23 /srv/ahome
測試:使用 alex 去創建一個文件,并且查閱文件權限看看:
[root@study ~]# su - alex
[alex@www ~]$ cd /srv/ahome
[alex@www ahome]$ touch 1234
[alex@www ahome]$ ll 1234
-rw-rw-r--. 1 alex project 0 Jun 17 00:25 1234
# 沒錯!這才是我們要的樣子!現在 alex, arod 創建的新文件所屬群組都是 project,
# 由于兩人均屬于此群組,加上 umask 都是 002,這樣兩人才可以互相修改對方的文件!
```
所以最終的結果顯示,此目錄的權限最好是“2770”,所屬文件擁有者屬于root即可,至于群組必須要為兩人共同支持的project 這個群組才行!
* * *
簡答題部分:
* 什么是絕對路徑與相對路徑絕對路徑的寫法為由 / 開始寫,至于相對路徑則不由 / 開始寫!此外,相對路徑為相對于目前工作目錄的路徑!
* 如何更改一個目錄的名稱?例如由 /home/test 變為 /home/test2mv /home/test /home/test2
* PATH 這個環境變量的意義?這個是用來指定可執行文件執行的時候,指令搜尋的目錄路徑。
* umask 有什么用處與優點?umask 可以拿掉一些權限,因此,適當的定義 umask 有助于系統的安全, 因為他可以用來創建默認的目錄或文件的權限。
* 當一個使用者的 umask 分別為 033 與 044 他所創建的文件與目錄的權限為何?在 umask 為 033 時,則默認是拿掉 group 與 other 的 w(2)x(1) 權限,因此權限就成為“文件 -rw-r--r-- , 目錄 drwxr--r-- ”而當 umask 044 時,則拿掉 r 的屬性,因此就成為“文件 -rw--w--w-,目錄 drwx-wx-wx”
* 什么是 SUID ?當一個指令具有 SUID 的功能時,則:
* SUID 權限僅對二進制程序(binary program)有效;
* 執行者對于該程序需要具有 x 的可執行權限;
* 本權限僅在執行該程序的過程中有效 (run-time);
* 執行者將具有該程序擁有者 (owner) 的權限。
* 當我要查詢 /usr/bin/passwd 這個文件的一些屬性時(1)傳統權限;(2)文件類型與(3)文件的隱藏屬性,可以使用什么指令來查詢?ls -al
file
lsattr
* 嘗試用 find 找出目前 linux 系統中,所有具有 SUID 的文件有哪些?find / -perm +4000 -print
* 找出 /etc 下面,文件大小介于 50K 到 60K 之間的文件,并且將權限完整的列出 (ls -l):find /etc -size +50k -a -size -60k -exec ls -l {} \;
注意到 -a ,那個 -a 是 and 的意思,為符合兩者才算成功
* 找出 /etc 下面,文件大小大于 50K 且文件所屬人不是 root 的文件名,且將權限完整的列出 (ls -l);find /etc -size +50k -a ! -user root -exec ls -ld {} \;
find /etc -size +50k -a ! -user root -type f -exec ls -l {} \;
上面兩式均可!注意到 ! ,那個 ! 代表的是反向選擇,亦即“不是后面的項目”之意!
* 找出 /etc 下面,容量大于 1500K 以及容量等于 0 的文件:find /etc -size +1500k -o -size 0
相對于 -a ,那個 -o 就是或 (or) 的意思啰!
- 鳥哥的Linux私房菜:基礎學習篇 第四版
- 目錄及概述
- 第零章、計算機概論
- 0.1 電腦:輔助人腦的好工具
- 0.2 個人電腦架構與相關設備元件
- 0.3 數據表示方式
- 0.4 軟件程序運行
- 0.5 重點回顧
- 0.6 本章習題
- 0.7 參考資料與延伸閱讀
- 第一章、Linux是什么與如何學習
- 1.1 Linux是什么
- 1.2 Torvalds的Linux發展
- 1.3 Linux當前應用的角色
- 1.4 Linux 該如何學習
- 1.5 重點回顧
- 1.6 本章習題
- 1.7 參考資料與延伸閱讀
- 第二章、主機規劃與磁盤分區
- 2.1 Linux與硬件的搭配
- 2.2 磁盤分區
- 2.3 安裝Linux前的規劃
- 2.4 重點回顧
- 2.5 本章習題
- 2.6 參考資料與延伸閱讀
- 第三章、安裝 CentOS7.x
- 3.1 本練習機的規劃--尤其是分區參數
- 3.2 開始安裝CentOS 7
- 3.3 多重開機安裝流程與管理(Option)
- 3.4 重點回顧
- 3.5 本章習題
- 3.6 參考資料與延伸閱讀
- 第四章、首次登陸與線上求助
- 4.1 首次登陸系統
- 4.2 文字模式下指令的下達
- 4.3 Linux系統的線上求助man page與info page
- 4.4 超簡單文書編輯器: nano
- 4.5 正確的關機方法
- 4.6 重點回顧
- 4.7 本章習題
- 4.8 參考資料與延伸閱讀
- 第五章、Linux 的文件權限與目錄配置
- 5.1 使用者與群組
- 5.2 Linux 文件權限概念
- 5.3 Linux目錄配置
- 5.4 重點回顧
- 5.5 本章練習
- 5.6 參考資料與延伸閱讀
- 第六章、Linux 文件與目錄管理
- 6.1 目錄與路徑
- 6.2 文件與目錄管理
- 6.3 文件內容查閱
- 6.4 文件與目錄的默認權限與隱藏權限
- 6.5 指令與文件的搜尋
- 6.6 極重要的復習!權限與指令間的關系
- 6.7 重點回顧
- 6.8 本章習題:
- 6.9 參考資料與延伸閱讀
- 第七章、Linux 磁盤與文件系統管理
- 7.1 認識 Linux 文件系統
- 7.2 文件系統的簡單操作
- 7.3 磁盤的分區、格式化、檢驗與掛載
- 7.4 設置開機掛載
- 7.5 內存交換空間(swap)之創建
- 7.6 文件系統的特殊觀察與操作
- 7.7 重點回顧
- 7.8 本章習題 - 第一題一定要做
- 7.9 參考資料與延伸閱讀
- 第八章、文件與文件系統的壓縮,打包與備份
- 8.1 壓縮文件的用途與技術
- 8.2 Linux 系統常見的壓縮指令
- 8.3 打包指令: tar
- 8.4 XFS 文件系統的備份與還原
- 8.5 光盤寫入工具
- 8.6 其他常見的壓縮與備份工具
- 8.7 重點回顧
- 8.8 本章習題
- 8.9 參考資料與延伸閱讀
- 第九章、vim 程序編輯器
- 9.1 vi 與 vim
- 9.2 vi 的使用
- 9.3 vim 的額外功能
- 9.4 其他 vim 使用注意事項
- 9.5 重點回顧
- 9.6 本章練習
- 9.7 參考資料與延伸閱讀
- 第十章、認識與學習BASH
- 10.1 認識 BASH 這個 Shell
- 10.2 Shell 的變量功能
- 10.3 命令別名與歷史命令
- 10.4 Bash Shell 的操作環境:
- 10.5 數據流重導向
- 10.6 管線命令 (pipe)
- 10.7 重點回顧
- 10.8 本章習題
- 10.9 參考資料與延伸閱讀
- 第十一章、正則表達式與文件格式化處理
- 11.1 開始之前:什么是正則表達式
- 11.2 基礎正則表達式
- 11.3 延伸正則表達式
- 11.4 文件的格式化與相關處理
- 11.5 重點回顧
- 11.6 本章習題
- 11.7 參考資料與延伸閱讀
- 第十二章、學習 Shell Scripts
- 12.1 什么是 Shell scripts
- 12.2 簡單的 shell script 練習
- 12.3 善用判斷式
- 12.4 條件判斷式
- 12.5 循環 (loop)
- 12.6 shell script 的追蹤與 debug
- 12.7 重點回顧
- 12.8 本章習題
- 第十三章、Linux 帳號管理與 ACL 權限設置
- 13.1 Linux 的帳號與群組
- 13.2 帳號管理
- 13.3 主機的細部權限規劃:ACL 的使用
- 13.4 使用者身份切換
- 13.5 使用者的特殊 shell 與 PAM 模塊
- 13.6 Linux 主機上的使用者訊息傳遞
- 13.7 CentOS 7 環境下大量創建帳號的方法
- 13.8 重點回顧
- 13.9 本章習題
- 13.10 參考資料與延伸閱讀
- 第十四章、磁盤配額(Quota)與進階文件系統管理
- 14.1 磁盤配額 (Quota) 的應用與實作
- 14.2 軟件磁盤陣列 (Software RAID)
- 14.3 邏輯卷軸管理員 (Logical Volume Manager)
- 14.4 重點回顧
- 14.5 本章習題
- 14.6 參考資料與延伸閱讀
- 第十五章、例行性工作調度(crontab)
- 15.1 什么是例行性工作調度
- 15.2 僅執行一次的工作調度
- 15.3 循環執行的例行性工作調度
- 15.4 可喚醒停機期間的工作任務
- 15.5 重點回顧
- 15.6 本章習題
- 第十六章、程序管理與 SELinux 初探
- 16.1 什么是程序 (process)
- 16.2 工作管理 (job control)
- 16.3 程序管理
- 16.4 特殊文件與程序
- 16.5 SELinux 初探
- 16.6 重點回顧
- 16.7 本章習題
- 16.8 參考資料與延伸閱讀
- 第十七章、認識系統服務 (daemons)
- 17.1 什么是 daemon 與服務 (service)
- 17.2 通過 systemctl 管理服務
- 17.3 systemctl 針對 service 類型的配置文件
- 17.4 systemctl 針對 timer 的配置文件
- 17.5 CentOS 7.x 默認啟動的服務簡易說明
- 17.6 重點回顧
- 17.7 本章習題
- 17.8 參考資料與延伸閱讀
- 第十八章、認識與分析登錄文件
- 18.1 什么是登錄文件
- 18.2 rsyslog.service :記錄登錄文件的服務
- 18.3 登錄文件的輪替(logrotate)
- 18.4 systemd-journald.service 簡介
- 18.5 分析登錄文件
- 18.6 重點回顧
- 18.7 本章習題
- 18.8 參考資料與延伸閱讀
- 第十九章、開機流程、模塊管理與 Loader
- 19.1 Linux 的開機流程分析
- 19.2 核心與核心模塊
- 19.3 Boot Loader: Grub2
- 19.4 開機過程的問題解決
- 19.5 重點回顧
- 19.6 本章習題
- 19.7 參考資料與延伸閱讀
- 第二十章、基礎系統設置與備份策略
- 20.1 系統基本設置
- 20.2 服務器硬件數據的收集
- 20.3 備份要點
- 20.4 備份的種類、頻率與工具的選擇
- 20.5 鳥哥的備份策略
- 20.6 災難復原的考慮
- 20.7 重點回顧
- 20.8 本章習題
- 20.9 參考資料與延伸閱讀
- 第二十一章、軟件安裝:源代碼與 Tarball
- 20.1 開放源碼的軟件安裝與升級簡介
- 21.2 使用傳統程序語言進行編譯的簡單范例
- 21.3 用 make 進行宏編譯
- 21.4 Tarball 的管理與建議
- 21.5 函數庫管理
- 21.6 檢驗軟件正確性
- 21.7 重點回顧
- 21.8 本章習題
- 21.9 參考資料與延伸閱讀
- 第二十二章、軟件安裝 RPM, SRPM 與 YUM
- 22.1 軟件管理員簡介
- 22.2 RPM 軟件管理程序: rpm
- 22.3 YUM 線上升級機制
- 22.4 SRPM 的使用 : rpmbuild (Optional)
- 22.5 重點回顧
- 22.6 本章習題
- 22.7 參考資料與延伸閱讀
- 第二十三章、X Window 設置介紹
- 23.1 什么是 X Window System
- 23.2 X Server 配置文件解析與設置
- 23.3 顯卡驅動程序安裝范例
- 23.4 重點回顧
- 23.5 本章習題
- 23.6 參考資料與延伸閱讀
- 第二十四章、Linux 核心編譯與管理
- 24.1 編譯前的任務:認識核心與取得核心源代碼
- 24.2 核心編譯的前處理與核心功能選擇
- 24.3 核心的編譯與安裝
- 24.4 額外(單一)核心模塊編譯
- 24.5 以最新核心版本編譯 CentOS 7.x 的核心
- 24.6 重點回顧
- 24.7 本章習題
- 24.8 參考資料與延伸閱讀