首页 > 系统相关 >6-Linux操作系统 用户与用户组

6-Linux操作系统 用户与用户组

时间:2023-09-28 09:03:30浏览次数:38  
标签:选项 用户名 操作系统 删除 用户组 用户 密码 Linux

一、介绍说明

  Linux系统是一个多用户多任务的操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统。

  用户的账号一方面可以帮助系统管理员对使用系统的用户进行跟踪,并控制他们对系统资源的访问;另一方面也可以帮助用户组织文件,并为用户提供安全性保护。

  每个用户账号都拥有一个唯一的用户名和各自的密码。

  用户在登录时键入正确的用户名和密码后,就能够进入系统和自己的主目录。

  要想实现用户账号的管理,要完成的工作主要有如下几个方面:

  用户账号的添加、删除、修改以及用户密码的管理。

  用户组的管理(添加、删除、修改)。

注意三个文件:

  /etc/passwd 存储用户的关键信息

  /etc/group 存储用户组的关键信息

  /etc/shadow 存储用户的密码信息

说明:

  在Linux系统中,用户和用户组是极其重要的概念。每次登录系统都必须以一个用户的身份登录,并且登录后的权限也会根据用户身份来确定。每个用户在都有一个初始用

户组,表现为/etc/passwd的第4栏的GID。

  用户组是具有相似属性的用户的集合,可以是一组用户,也可以是一个用户。在Linux系统中,每个用户都属于一个用户组,这个用户组就称为初始用户组。此外,Linux系

统中还存在一种虚拟用户,也称为“伪”用户,这类系统用户不能登录系统。

  总的来说,Linux系统中的每一个目录、文件,都会有其属于的用户和用户组,我们称其为属主和属组。Linux系统就是通过UID和GID来对用户和组进行管理的。

     

二、用户管理

①添加用户

语法:#useradd 选项 用户名

常用选项:

-g:表示指定用户的用户主(主要)组,选项的值可以是用户组的id,也可以是组名

Useradd -g zhang -G -c 这是一个普通用户 临时创建的

-G:表示指定用户的用户附加(额外)组,选项的值可以是用户组的id,也可以是组名

-u:uid,用户的id(用户的标识符),系统默认会从之后按顺序分配uid,如果不想使用系统分配的,可以通过该选项自定义【类似于腾讯QQ的自选靓号情况】

-c:comment,添加注释(选择是否添加)

-s:指定用户登入后所使用的shell 解释器 【专门的接待员】

-d:指定用户登入时的启始目录(家目录位置)

-n:取消建立以用户名称为名的群组(了解)

案例:创建用户yunhe ,并验证a./etc/passwd b. ls /home c.id yunhe

认识passwd文件(拓展)

用户名:密码:用户ID:用户组ID:注释:家目录:解释器shell

用户名:创建新用户名称,后期登录的时候需要输入;

密码:此密码位置一般情况都是“x”,表示密码的占位;

用户ID:用户的识别符;【-u】

用户组ID:该用户所属的主组ID;【-g】

注释:解释该用户是做什么用的;【-c】

家目录:用户登录进入系统之后默认的位置;【-d】

解释器shell:等待用户进入系统之后,用户输入指令之后,该解释器会收集用户输入的指令,传递给内核处理;【如果解释器是/bin/bash表示用户可以登录到统,/sbin/nologin表示该用户不能登录到系统】【-s】

注意:在不添加选项的时候,执行useradd之后会执行一系列的操作

a. 创建同名的家目录;

b. 创建同名的用户组;

案例:添加选项,创建用户guo,让guo属于1000主组,自选靓号1066,并且要求不能登录到系统,

验证是否创建成功:

注意:查看用户的主组可以查看passwd文件,查看附加组可以查看group文件。

guozhengyuan行的含义:在guozhengyuan的组里(组id是)有一个组内用户guo(guo的附加组就是,附加组的名字是guo)。

如果需要为一个用户指定多个附加组,只需要将多个附件组的id通过英文逗号“,”分割即可。

【主组只能有1个(类似于亲生父母只有一对),附加组可以多个,也可以没有附加组(类似于认干爹干妈,可以有也可以没有,也可以有多个)】

【主组必须有】

【文档的属组指的是主组】

②修改用户

语法:#usermod 选项 用户名

Usermod:user modify,用户修改

常用选项:

-g:表示指定用户的用户主组,选项的值可以是用户组的id,也可以是组名、

-G:表示指定用户的用户附加组,选项的值可以是用户组的id,也可以是组名

-u:uid,用户的id(用户的标识符),系统默认会从之后按顺序分配uid,如果不想使用系统分配的,可以通过该选项自定义【类似于腾讯QQ的自选靓号情况】

-l:修改用户名

-c<备注>:修改用户帐号的备注文字

-d<登入目录>:修改用户登入时的目录

-s<shell>:修改用户登入后所使用的shell

案例:修改guo用户主组为1000,附加组改为1001

#usermod -g 1000 -G 1001 guo

案例:修改guo用户用户名,改为yuan

usermod -l yuan guo

③设置密码

Linux不允许没有密码的用户登录到系统,因此前面创建的用户目前都处于锁定状态,需要设置密码之后才能登录计算机。

语法:#passwd [用户名] 【如果不指定用户名则修改自己的密码】

案例:设置zhangsan用户的密码

#passwd zhangsan

在设置密码的时候也是没有任何输入提示的,放心输入,确保两次输入的密码一致,按下回车即可。

也可以使用弱密码,但是不建议,否则会看到以下的提示:

设置密码之后shadow文件中的体现:能够看出lisi用户没有密码的。

在设置用户密码之后可以登录帐号,例如此处需要登录wangerma

切换用户命令:#su [用户名] (switch user)

如果用户名不指定则表示切换到root用户。

切换用户需要注意的事项:

a. 从root往普通用户切换不需要密码,但是反之则需要root密码;

b. 切换用户之后前后的工作路径是不变的;

c. 普通用户没有办法访问root用户家目录,但是反之则可以;

④删除用户

语法:#userdel 选项 用户名

Userdel:user delete(用户删除)

常用选项:

-r:表示删除用户的同时,删除其家目录;

案例:删除guo用户

#userdel -r guo

注意:已经登录的wangerma用户删除的时候提示删除失败,但是没有登录的lisi用户可以正常删除。

解决办法:简单粗暴,kill对应用户的全部进程

提示:所有跟用户操作的命令(除passwd外,只能修改自己的密码,即不指定用户名)只有root超级管理员有权限执行。

备注:也可以在登录需要删除的用户之后,按下快捷键“ctrl+d”进行对当前用户的注销,随后退回到上一个用户(root)此时就可以对需要删除的用户进行删除操作。

三、用户组的管理

  每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同Linux 系统对用户组的规定有所不同,如Linux下的用户属于与它同名的用户组,这个

用户组在创建用户时同时创建。

  用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就是对/etc/group文件的更新。

文件结构:

  用户组名:密码:用户组ID:组内用户名[看附加组的]

密码:X表示占位符,虽然用户组可以设置密码,但是绝大部分的情况下不设置密码;

组内用户名:表示附加组是该组的用户名称;

①用户组添加

语法:#groupadd 选项 用户组名

常用选项:

-g:类似用户添加里的“-u”,-g表示选择自己设置一个自定义的用户组ID数字,如果自己不指定,则默认从1000之后递增;

案例:使用groupadd指令创建一个新的用户组,命名为admins

#groupadd admins

②用户组编辑

语法:#groupmod 选项 用户组名

常用选项:

-g:类似用户修改里的“-u”,-g表示选择自己设置一个自定义的用户组ID数字

-n:类似于用户修改“-l”,表示设置新的用户组的名称

案例:修改admins用户组,将组ID改成1212,将名称改为admin123

③用户组删除

语法:#groupdel 用户组名

案例:删除admin组

#groupdel admin

注意:当如果需要删除一个组,但是这个组是某个用户的主组时,则不允许删除(附加组是可以的);如果确实需要删除,则先从组内移出所有用户。

提示

针对用户和用户组的管理指令,除了passwd指令之外,其他指令一般情况下只有root用户可以执行。

     
     

 

标签:选项,用户名,操作系统,删除,用户组,用户,密码,Linux
From: https://www.cnblogs.com/ljygzyblog/p/Linux_6.html

相关文章

  • Linux中C程序的编译与运行
    C程序编译的完整过程如下图所示1、编译C文件,生成可执行文件gccmine.c-omine2、运行程序./mine3、编译并运行gccmine.c-omine&&./mine4、编译C程序,生成目标文件gcc-cmine.c-omine.o5、链接目标文件,生成可执行文件,同编译C文件一样。gccmine.o-omine......
  • linux 中批量输出指定目录的磁盘占用和文件数目
     001、磁盘占用(base)[root@pc1test1]#lstest1test2test3(base)[root@pc1test1]#find$PWD-typed##查出所有目录/home/test1/home/test1/test1/home/test1/test1/test/home/test1/test2/home/test1/test3(base)[root@pc1test1]#find$PWD......
  • linux-Shell将命令行终端输出结果写入保存到文件中
    (一)将输出与错误写到同一个文件(1)方法1#!bin/bashjava-jarhbase-example.jar2>&1|teehbase_log.txt说明:0,1,2:在linux分别表示标准输入、标准输出和标准错误信息输出。tee默认为写入覆盖,-a参数表示追加内容。#!bin/bashjava-jarhbase-example.jar2>&1|tee-ahbase_......
  • linux中查询端口占用情况
    1、lsof-i:端口号用于查看某一端口的占用情况,比如查看8000端口使用情况,lsof-i:8000可以看到8000端口已经被轻量级文件系统转发服务lwfs占用2、netstat-tunlp|grep端口号,用于查看指定的端口号的进程情况,如查看8000端口的情况,netstat-tunlp|grep8000说明一下几个参数的含义:......
  • 配java环境在linux上,cuda9.2 old version
    主要参考:https://blog.csdn.net/m0_62946761/article/details/127138742先打个标记#CUDA10.2pipinstalltorch==1.6.0torchvision==0.7.0#CUDA10.1pipinstalltorch==1.6.0+cu101torchvision==0.7.0+cu101-fhttps://download.pytorch.org/whl/torch_stable.html#C......
  • Linux系统下创建LV(逻辑卷)并挂载
    1、查看磁盘情况[root@ecs-34a8-0913916~]#fdisk-lDisk/dev/vda:107.4GB,107374182400bytes,209715200sectorsUnits=sectorsof1*512=512bytesSectorsize(logical/physical):512bytes/512bytesI/Osize(minimum/optimal):512bytes/512bytes......
  • Linux vi替换字符串
     1.基本的替换 :s/vivian/sky/替换当前行第一个vivian为sky :s/vivian/sky/g替换当前行所有vivian为sky :n,$s/vivian/sky/替换第n行开始到最后一行中每一行的第一个vivian为sky :n,$s/vivian/sky/g替换第n行开始到最后一行中每一行所有vivian为sky......
  • [转载] linux下 GCC编译链接静态库&动态库
    转载自:https://www.cnblogs.com/thechosenone95/p/10605172.html#_label0静态库有时候需要把一组代码编译成一个库,这个库在很多项目中都要用到,例如libc就是这样一个库,我们在不同的程序中都会用到libc中的库函数(例如printf),也会用到libc中的变量(例如以后要讲到的environ变量)。......
  • linux上如何使用docker部署前后端分离项目(含部署多个前端页面的方法)
    (目录)前言使用前一段时间写的前后端分离开发的简单小项目,确保本地可以启动部署所需镜像汇总mysql镜像2.后端工程自定义镜像3.nginx镜像<fontcolor=red>下面介绍部署过程</font>一、mysql镜像(1)拉取mysql镜像选择使用的mysql版本,我用的是8.0.33dockerpullmysql......
  • 10 分钟学会Linux常用 bash命令
    目录1.基本操作1.1.文件操作1.2.文本操作1.3.目录操作1.4.SSH,系统信息&网络操作2.基本Shell编程2.1.变量2.2.字符串替换2.3.函数2.4.条件2.5.循环3.技巧4.调试1.BasicOperationsa.export显示所有的环境变量,如果你想获取某个变量的详细信息,使用echo......