百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 优雅编程 > 正文

Linux基础命令(十一)——用户和组账号管理

sinye56 2024-11-05 11:45 9 浏览 0 评论

注:文档比较长,前面部分是一些比较概念性的东西,看命令的话可以直接看后面部分。

一、用户账号和组账号概述

与Windows操作系统对比,Linux系统中的用户账号和组账号的作用在本质上是一样的,同样都是基于用户身份来控制对资源的访问,只不过在表现形式及个别细节方面存在些许差异。

1.用户账号:

  • 超级用户:root用户是linux系统中默认的超级用户账号,对本主机拥有至高无上的权限,类似于Windows系统中的Administrator用户。
  • 普通用户:拥有的权限受到一定限制,一般只在用户自己的宿主目录中拥有完整权限
  • 程序用户:在安装Linux系统及部分应用程序时,会添加一些特定的低权限用户账号,这些用户一般不允许登录到系统,而仅用于维持系统或某个程序的正常运行。如,bin、ftp、daemon、mail等。

2.组账号:

  • 基本组(私有组):每个用户账号至少属于一个组,这个组称为该用户的基本组。
  • 附加组(公有组):若该用户还包括在其他的组中,则这些组称为该用户的附加组。

3.UID和GID

  • UID(User IDentity,用户标识号):Linux系统中每一个用户账号都有一个数字形式的身份标记,称为UID。(唯一的)

root用户的UID为固定值0

程序用户账号的UID默认为1~499

普通用户默认为500~60000

  • GID(Group IDentity,组标识号):每一个组账号也有一个数字形式的身份标记,称为GID。(唯一的)

Root组账号的GID为固定值0

程序组账号默认为1~499

普通用户组默认为500~60000

二、用户账号管理

1.用户账号文件

与用户账号相关的配置文件主要有两个,分别是/etc/passwd、/etc/shadow,每一行对应一个用户账号,不同配置项之间用冒号":"分隔。

1) /etc/passwd:保存用户名称、宿主目录、登录shell等基本信息

示例:

查看head、tail命令的相关信息可点击Linux基础命令(五)了解查看。

各个配置字段的含义如下:

注:所有用户都可以访问passwd文件中的内容,但只有root用户才能更改

2) /etc/shadow:保存用户密码、账号有效期等信息

示例:

上图各配置字段(用冒号":"隔开)的含义如下:

第一字段:用户账号名称

第二字段:使用MD5加密的密码子串信息,当为"*"或"!!"时表示此用户不能登录到系统,若该字段内容为空,则该用户无需密码即可登录

第三字段:上次修改密码的时间,表示从1970年01月01日算起到最近一次修改密码时间隔的天数。

第四字段:密码的最短有效天数,默认为0,表示不进行限制

第五字段:密码的最长有效天数,默认为99999,表示不进行限制

第六字段:提前多少天警告用户密码将过期,默认值为7

第七字段:在密码过期之后多少天内禁用此用户

第八字段:账号失效时间,此字段指定了用户作废的天数(从1970年01月01日起计算),默认值为空,表示账号永久可用

第九字段:保留字段,目前没有特殊用途

3) 用户账户的初始配置文件

  • 文件来源:

新建用户帐号时,从 /etc/skel 目录中复制而来,基本上都是隐藏文件。

  • 常用的用户初始配置文件:

~/.bash_profile:用户每次登录时执行

~/.bashrc:每次进入新的Bash环境时执行

~/.bash_logout:用户每次退出登录时执行

2.管理用户账号的命令

1) useradd命令——添加用户账号

命令格式:useradd [选项] 用户名

常用选项:

-u:指定 UID 标记号

-d:指定宿主目录,缺省为 /home/用户名(与-M一起使用时,不生效)

-e:指定帐号失效时间

-g:指定用户的基本组名(或UID号)

-G:指定用户的附加组名(或GID号)

-M:不为用户建立并初始化宿主目录

-s:指定用户的登录Shell

示例:

指定mike的基本组为mike,并加入到ftpuser组;指定主目录为/ftphome/mike;不允许mike通过本地登录服务器

2) passwd命令——为用户账号设置密码

命令格式:passwd [选项] 用户名

常用选项

-d:清空用户的密码,使之无需密码即可登录

-l:锁定用户帐号

-S:查看用户账户的状态(是否被锁定)

-u:解锁用户账户

示例:

3) usermod命令——修改用户账号属性

命令格式:usermod [选项] 用户名

常用选项:

-l:更改用户帐号的登录名称

-L:锁定用户账户

-U:解锁用户账户

-u、-d、-e、-g、-G、-s选项与useradd命令中的含义相同

示例:

4) Userdel命令——删除用户账号

命令格式:userdel [-r] 用户名

添加 -r 选项时,表示连用户的宿主目录一并删除

示例:

三、组账号管理

1.组账号文件

与用户帐号文件相类似

/etc/group:保存组帐号基本信息

/etc/gshadow:保存组帐号的密码信息

2.管理组账号的命令

1) groupadd命令——添加组账号

命令格式:groupadd [-g GID] 组账号名

示例:

2) gpasswd命令——添加、设置、删除组成员

命令格式:gpasswd [选项] 组帐号名

常用选项:

-a:添加用户到组

-d:删除组内的某用户

-M:定义组成员列表,以逗号分隔

示例:

四、查询账号信息

1.id命令——查询用户身份标识

格式:id [用户名]

2.groups命令——查询用户所属的组

格式:groups [用户名]

3.finger命令——查询用户帐号的详细信息

格式:finger [用户名]

4.users、w 、who命令——查询已登录到主机的用户信息

注意命令格式中的空格,显示的比较不明显。期待你的关注。

相关推荐

Linux两种光驱自动挂载的方法

环境:CentOS6.4西昆云服务器方式一修改fstab文件/etc/fstab是系统保存文件系统信息?静态文件,每一行描述一个文件系统;系统每次启动会读取此文件信息以确定需要挂载哪些文件系统。参...

linux系统运维,挂载和分区概念太难?在虚机下操作一次全掌握

虚拟机的好处就是可以模拟和学习生产环境的一切操作,假如我们还不熟悉磁盘操作,那先在虚机环境下多操作几次。这次来练习下硬盘扩容操作。虚拟机环境:centos8vm11linux设备命名规则在linux中...

Linux 挂载 NFS 外部存储 (mount 和 /etc/fstab)

mount:手工挂载,下次重启需再重新挂载,操作命令:mount-tnfs-ooptionsserver:/remote/export/local/directory上面命令中,本地目录...

在Linux中如何设置自动挂载特定文件系统(示例)

Linux...

Linux环境中的绑定挂载(bind mount)

简介:Linux中的mount命令是一个特殊的指令,主要用于挂载文件目录。而绑定挂载(bindmount)命令更为特别。mount的bind选项将第一个目录克隆到第二个。一个目录中的改变将会在...

Linux挂载CIFS共享 临时挂载 1. 首先

如何解决服务器存储空间不足的问题?大家好,欢迎回来。在上一期视频中,我为大家介绍了如何利用Linux挂载来扩容服务器存储空间。这一期视频,我将以Linux为例,教大家如何进行扩容。群辉使用的是Linu...

Linux 硬盘挂载(服务器重启自动挂载)

1、先查看目前机器上有几块硬盘,及已挂载磁盘:fdisk-l能够查看到当前主机上已连接上的磁盘,以及已经分割的磁盘分区。(下面以/dev/vdb磁盘进行分区、挂载为例,挂载点设置为/data)df...

linux 挂载磁盘

在Linux中挂载硬盘的步骤如下:...

笨小猪教您Linux磁盘挂载

本教程针对Linux系统比较熟悉或者想学习Linux基础的用户朋友,本教程操作起来比较傻瓜式,跟着步骤就会操作,本文使用的工具是XShell同时多多注意空格(文中会有提示)。【问答】什么是磁盘挂载?答...

Linux 磁盘挂载和docker安装命令

本篇给大家介绍Linux磁盘挂载和docker安装的相关内容,Linux服务器的操作是一个手熟的过程,一些不常用的命令隔断时间就忘记了,熟话说好记性不如烂笔头,还需在平时的工作中多练习记录。...

Linux设置开机自动挂载分区

有时候,我们在安装完Linux系统之后,可能在使用过程中添加硬盘或者分区进行使用,这时候就需要手动把磁盘分区挂载到某个路径,但是开机之后就会消失,需要重新挂载,非常麻烦,那么我们应该如何设置开机自动挂...

在linux挂载一个新硬盘的完整步骤

以下是在Linux中挂载新原始磁盘的完整步骤,包括分区、创建文件系统以及使用UUID在/etc/fstab中启动时挂载磁盘:将新的原始磁盘连接到Linux系统并打开电源。运行以下命令,...

Linux系统如何挂载exFAT分区

简介:Linux系统中不能像Windows系统那样自动识别加载新设备,需要手动识别,手动加载。Linux中一切皆文件。文件通过一个很大的文件树来组织,文件树的根目录是:/,从根目开始录逐级展开。这些文...

Linux系统挂载硬盘

fdisk-l查看可挂载的磁盘都有哪些df-h查看已经挂载的磁盘...

WSL2发布,如何在Win10中挂载Linux文件系统

WSL2是最新版本的架构,它为Windows子系统提供支持,使其能够在Windows上运行ELF64Linux二进制文件。通过最近的更新,它允许使用Linux文件系统访问存储在硬盘中的文件。如果你...

取消回复欢迎 发表评论: