Linux 用戶和許可權

来源:https://www.cnblogs.com/woodware/archive/2020/05/15/12893664.html
-Advertisement-
Play Games

用戶和組的相關概念 賬號:是一種用來記錄單個用戶或是多個用戶的數據。在Linux 上的賬號可以分成兩類: 用戶賬號 用來儲存單一用戶的數據,你可以使用一個用戶賬號,來儲存某一個用戶的數據。 群組賬號 用來儲存多個用戶的信息,每一個群組賬號可以用來記錄一組用戶的數據。 依照賬號的位置 本機賬號: 儲存 ...


  • 用戶和組的相關概念

    賬號:是一種用來記錄單個用戶或是多個用戶的數據。在Linux 上的賬號可以分成兩類

         用戶賬號  用來儲存單一用戶的數據,你可以使用一個用戶賬號,來儲存某一個用戶的數據。

         群組賬號  用來儲存多個用戶的信息,每一個群組賬號可以用來記錄一組用戶的數據。

    依照賬號的位置

    本機賬號: 儲存於本機硬碟中的賬號數據,我們稱為本機賬號。本機賬號使用範圍局限在賬號建立的 Linux 系統上,如果超出範圍時,本機賬號將無法使用。比如你在自己電腦上登錄用的賬號和密碼,正常是無法在其它的電腦上使用的。

    本機賬號的優點是簡單易用,你無須作額外的設置,就可以直接建立本機賬號;但缺點則是無法具備延展性(Scalability)。比如你在一個擁有很多主機的環境中,想擁有一個在每台主機都可以登錄的賬號時,你就需要在所有的主機上都建立相關的用戶

    網域賬號: 你也可以把大量的電腦組織成為一個網域,然後在網域中的某一臺 Linux 上建立賬號數據,並且通過某些通信協議,將賬號數據分享出來。當其他電腦需要取得賬號數據時,再通過網路調用這些分享的賬號即可。這種賬號我們稱為網域賬號 (Domain Account)。

    網域賬號的優點在於具備延展性。在大規模的環境中,使用網域賬號往往能節省管理賬號的時間;但網域賬號也有缺點,其最大的缺點就是要配置網域賬號前,你必須先建立“域”的環境才行。

    依照賬號的功能

          用戶賬號部分:包含了超級用戶、普通用戶;而普通用戶中還可細分為系統用戶、真實用戶兩種。

          群組賬號部分:包含了超級用戶群組、系統群組以及用戶自定義組三大類。

  • 用戶賬號管理

    •  本機的用戶賬號數據儲存於/etc/passwd文件中。與其他的配置文件一樣,passwd 也是一個文本文件,因此,你可以直接使用文字處理程式,例如 cat 或 less 瀏覽其中的內容。
      root:x:0:0:root:/root:/bin/bash
      bin:x:1:1:bin:/bin:/sbin/nologin
      daemon:x:2:2:daemon:/sbin:/sbin/nologin
       /etc/passwd 許可權必須是0644,每一行代表一個用戶的賬號數據,每一行又使用冒號(:)分隔為幾個部分
       USERNAME:PASSWORD:UID:GID:COMMENT:HOMEDIR:SHELL
       USERNAME: 用戶識別名稱,也是登錄的名稱
       PASSWORD: 密碼位,用於存儲用戶的密碼,為了安全起見,密碼放在另一個文件中,這裡統一用x
       UID: 用戶識別號,0表示為管理員,非0為普通用戶
       GID: 組識別號,用來識別用戶組的身份,同樣0為管理員組,非0為系統群組或者自定義組
       COMMENT: 描述信息
       HOMEDIR: 家目錄位置
       SHELL: shell類型
      這個文件我們就介紹完了,現在我們來看下用戶管理的相關命令

    • useradd
      -u UID                          用來指定賬號的 UID,如果省略這個參數,useradd會自動以最後一個可用的 UID 作為新賬號的 UID。 如果你指定的 UID 已經使用過,useradd 將會顯示錯誤信息,此時你可以配合 -o 參數,告訴 useradd 允許重覆的 UID。
      -g GROUP                        定義用戶的主要群組。使用 -g 參數前,GROUP 必須已經存在。
      -d HOME                          指定用戶的主目錄。預設的主目錄是建立在 /home/ 目錄下,而且目錄名稱與用戶名稱相同。
      -s SHELL                         指定用戶登錄執行的程式。
      -c COMMENT                  指定用戶的批註說明。如果批註文字包含空白,請記得使用雙引號 (") 包起來。
      -r                                     這個參數用來指出建立一個系統用戶的賬號。
      這些參數大多數可以同時使用,可以根據自己的需求指定,如:
      useradd -u 1500 -g hello -d /home/hello -s /bin/bash -c "this is a test user" hello
    • usermod 是用來修改用戶相關信息的,和useradd使用的參數很多是相同的,用法也是一樣的,除此之外usermod命令還有一些額外的參數
      -l NEWNAME                           修改賬號的用戶名稱,NEWNAME 即是新的賬號名稱。
      -L                                            鎖定賬號,一經鎖定的賬號將無法用來登錄系統。
      -U                                            解除鎖定。
      userdel                                    刪除用戶,有一個常用參數-r,含義是刪除用戶的相關數據,包括家目錄,郵箱。

      id
      [root@manage01 ~]# id hello
      uid=1000(hello) gid=1000(hello) 組=1000(hello)
      [root@manage01 ~]# id -u hello
      1000

      whoami
      [root@manage01 ~]# whoami
      root
  • 組賬號管理

    本機的群組賬號數據被儲存在 /etc/group 文件中,許可權也必須為0644,與 /etc/passwd 一樣,這也是一個文本文件。 
    root:x:0:
    bin:x:1:
    daemon:x:2:

    這與/etc/passwd文件的格式類似

    GROUPNAME:PASSWORD:GID:MEMBERS 

    GROUPNAME: 組名

    PASSWORD: 組密碼,這裡也和passwd文件一樣是個x

    GID: 群組識別號

    MEMBERS: 組成員

    groupadd 建立組
    -g GID            指定群組賬號的標識符
    -r                         指定添加的群組成為系統群組
    -f                         強制執行。 在一般的情況下,groupadd 不允許建立一個與使用過的 GID 相同的群組賬號,而使用這個參數時,groupadd 將會建立相同 GID 的 群組賬號。

    groupmod 修改群組信息
    -g GID                  修改群組賬號的標識符。GID 就是新的標識符。
    -n NEWNAME       用來修改群組的名稱。NEWNAME 就是新的組名。

    groupdel 刪除群組賬號

  • 密碼管理

    passwd 修改用戶密碼
    -d             刪除用戶密碼,亦即把文件中的密碼欄位清空。
    -l              這個參數用來鎖定賬號,賬號一經鎖定,用戶再怎樣輸入密碼,都會被判斷為錯誤。這個參數只能由 root 使用,普通用戶無法用來鎖定自己的賬號。

    gpasswd 修改組密碼
    -r             用來刪除群組的密碼。
    -R            鎖定 GROUP 的群組密碼。

    群組管理員
    群組管理員可以
    指派群組管理員,如果有多個管理員用“,”分隔,如果想刪除群組管理員,保持位置為空
    gpasswd -A USER    GROUP
    gpasswd -A hello    test#將test組的管理員設置為hello
    gpasswd -A '' test    #刪除test組的管理員
    加入與刪除群組成員
    gpasswd -a USER GROUP
    gpasswd -d USER GROUP

 

 

           管理密碼的有效期限

              [root@manage01 ~]# chage -l hello
    最近一次密碼修改時間 :從不
    密碼過期時間 :從不
    密碼失效時間 :從不
    帳戶過期時間 :從不
    兩次改變密碼之間相距的最小天數 :0
    兩次改變密碼之間相距的最大天數 :99999
    在密碼過期之前警告的天數 :7

     chage
      -m 設置密碼修改的最小天數
      -M 設置密碼修改的最大天數
      -d 設置密碼最後修改日期
      -I 設置密碼過期後,鎖定賬號的天數
      -E 設置賬號過期日期,0=立即過期,-1=永不過期
      -W 設置密碼過期前的警告天數
     -l 查看指定用戶的相關信息
    -h 幫助    

 

 


  •  

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在 Linux 命令行下進行文本關鍵字的搜索,大家肯定第一時間會想到 命令。grep 命令確實十分強大,但如果需要用到它更加靈活的功能時,可能命令就會顯得十分複雜。 於是,為了簡化 grep 的語句並達到同等效果,很多業內高手開發出了很多同樣強大的工具,在某些程度上甚至可以替代 grep 。 下麵我 ...
  • 目錄結構及相關命令筆試題集合 一、複習題 1.伺服器的結構類型有哪些?簡單說明 2.在32位操作系統最大可以使用__32_G記憶體. 3.系統交換分區時作為系統___虛擬存儲__的一塊區域. 4./etc文件系統的標準應用是用於(D) ​ A.安裝附加的應用程式 ​ B.存放可執行程式、系統管理工具 ...
  • 1、查看firewall服務狀態 systemctl status firewalld 2、查看firewall的狀態 firewall-cmd --state 3、開啟、重啟、關閉、firewalld.service服務 # 開啟 service firewalld start # 重啟 serv ...
  • 一、伺服器硬體與基礎命令 1· 在32位操作系統最大可以使用_4 _G記憶體 2. 多核CPU和單核CPU的優點和缺點,是否所有程式在多核CPU上運行速度都快?為什麼? 3. 伺服器的主要組成部分有哪些 4. 在以前的工作中主要接觸哪些伺服器品牌和型號 5. 設超級用戶root當前所在目錄為:/usr ...
  • 你知道Unix、Linux、GNU、GNU/Linux 之間的關係嗎? ...
  • ThinkPad-BIOS 如有問題請指出 ~謝謝 ...
  • 當前標識 (IIS APPPOOL\.NET v4.5) 沒有對”C:\Windows\Microsoft.NET\Framework\v4.0.30319\Temporary ASP.NET Files” 的寫訪問許可權。 ...
  • 如何在Vmware中創建Linux虛擬機並設置Vmware和虛擬機網路 創建Linux虛擬機 創建虛擬機 配置類型選擇自定義 虛擬機硬體相容性,選擇當前Vmware版本即可 選擇要使用的Linux ISO鏡像文件,鏡像從“阿裡雲鏡像站”下載。 虛擬機命名與虛擬機存放位置 虛擬機CPU核數配置 虛擬機 ...
一周排行
    -Advertisement-
    Play Games
  • GoF之工廠模式 @目錄GoF之工廠模式每博一文案1. 簡單說明“23種設計模式”1.2 介紹工廠模式的三種形態1.3 簡單工廠模式(靜態工廠模式)1.3.1 簡單工廠模式的優缺點:1.4 工廠方法模式1.4.1 工廠方法模式的優缺點:1.5 抽象工廠模式1.6 抽象工廠模式的優缺點:2. 總結:3 ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 本章將和大家分享ES的數據同步方案和ES集群相關知識。廢話不多說,下麵我們直接進入主題。 一、ES數據同步 1、數據同步問題 Elasticsearch中的酒店數據來自於mysql資料庫,因此mysql數據發生改變時,Elasticsearch也必須跟著改變,這個就是Elasticsearch與my ...
  • 引言 在我們之前的文章中介紹過使用Bogus生成模擬測試數據,今天來講解一下功能更加強大自動生成測試數據的工具的庫"AutoFixture"。 什麼是AutoFixture? AutoFixture 是一個針對 .NET 的開源庫,旨在最大程度地減少單元測試中的“安排(Arrange)”階段,以提高 ...
  • 經過前面幾個部分學習,相信學過的同學已經能夠掌握 .NET Emit 這種中間語言,並能使得它來編寫一些應用,以提高程式的性能。隨著 IL 指令篇的結束,本系列也已經接近尾聲,在這接近結束的最後,會提供幾個可供直接使用的示例,以供大伙分析或使用在項目中。 ...
  • 當從不同來源導入Excel數據時,可能存在重覆的記錄。為了確保數據的準確性,通常需要刪除這些重覆的行。手動查找並刪除可能會非常耗費時間,而通過編程腳本則可以實現在短時間內處理大量數據。本文將提供一個使用C# 快速查找並刪除Excel重覆項的免費解決方案。 以下是實現步驟: 1. 首先安裝免費.NET ...
  • C++ 異常處理 C++ 異常處理機制允許程式在運行時處理錯誤或意外情況。它提供了捕獲和處理錯誤的一種結構化方式,使程式更加健壯和可靠。 異常處理的基本概念: 異常: 程式在運行時發生的錯誤或意外情況。 拋出異常: 使用 throw 關鍵字將異常傳遞給調用堆棧。 捕獲異常: 使用 try-catch ...
  • 優秀且經驗豐富的Java開發人員的特征之一是對API的廣泛瞭解,包括JDK和第三方庫。 我花了很多時間來學習API,尤其是在閱讀了Effective Java 3rd Edition之後 ,Joshua Bloch建議在Java 3rd Edition中使用現有的API進行開發,而不是為常見的東西編 ...
  • 框架 · 使用laravel框架,原因:tp的框架路由和orm沒有laravel好用 · 使用強制路由,方便介面多時,分多版本,分文件夾等操作 介面 · 介面開發註意欄位類型,欄位是int,查詢成功失敗都要返回int(對接java等強類型語言方便) · 查詢介面用GET、其他用POST 代碼 · 所 ...
  • 正文 下午找企業的人去鎮上做貸後。 車上聽同事跟那個司機對罵,火星子都快出來了。司機跟那同事更熟一些,連我在內一共就三個人,同事那一手指桑罵槐給我都聽愣了。司機也是老社會人了,馬上聽出來了,為那個無辜的企業經辦人辯護,實際上是為自己辯護。 “這個事情你不能怪企業。”“但他們總不能讓銀行的人全權負責, ...