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

「Linux」 CentOS7用户和用户组管理-企业级必备

sinye56 2024-11-05 11:46 10 浏览 0 评论

1-6-RHEL7用户管理

本节所讲内容:

  • 用户和组的相关配置文件
  • 管理用户和组
  • RHEL7破解root密码


用户一般来说是指使用计算机的人,计算机对针使用其的每一个人给了一个特定的名称,用户就可以使用这些名称来登录使用计算机,除了人之外,一些系统服务也需要含有部分特权的用户账户运行;因此出于安全考虑,用户管理应运而生,它加以明确限制各个用户账户的权限,root在计算机中用拥有至高特权,所以一般只作管理用,非特权用户可以通过SU或SUDO程序来临时获得特权

GNU/Linux 通过用户和用户组实现访问控制----包括对文件访问、设备使用的控制。

Linux 默认的访问控制机制相对简单直接,它还有更加高级的机制,包括 ACL和 集中式身份管理系统

个人可以拥有很多账户,只不是彼此名称不同,比如root名称已经占用就不能再用了,此外,任意用户可能从属某个用户组,此用户可以加入某些已经存在的组来获得该组的特权

GNU/Linux 系统中的每一个文件都从属一个用户(属主)和一个用户组(属组)。另外,还有三种类型的访问权限:读(read)、写(write)、运行(execute)。我们可以针对文件的属主、属组、而设置相应的访问权限。再次,我们可以通过 ls | stat命令查询文件属主、属组和权限

使用stat命令也可以查看文件所有权和权限:

属主:

[root@panda ~]# stat -c %U /boot/initrd-plymouth.img

root

属组:

[root@panda ~]# stat -c %G /boot/initrd-plymouth.img

root


第1章 用户账号:

1.1 用户的分类

Linux用户三种角色

  • 超级用户: root 拥有对系统的最高的管理权限
  • 普通用户:系统用户 UID:1-999(RHEL7) 1-499(RHEL6)

本地用户 UID:1000+ 500+

UID:即每个用户的身份标示,类似于每个人的身份证号码.

  • 虚拟用户:伪用户 一般不会用来登录系统的,它主要是用于维持某个服务的正常运行


下图是用户和组的关系:

一对一:一个用户可以存在一个组中; 一对多:一个用户可以存在多个组中

多对一:多个用户可以存在一个组中; 多对多:多个用户可以存在多个组中

1.2 配置文件


名 称

帐号信息

说 明

用户配置文件

/etc/passwd

记录了每个用户的一些基本属性,并且对所有用户可读,每一行记录对应一个用户,每行记录通过冒号进行分隔

用户组文件

/etc/group

用户组的所有信息存放地儿,并且组名不能重复

用户对应的密码信息

/etc/shadow

因为passwd文件对所有用户是可读的,为安全起见把密码从passwd中分离出来放入这个单独的文件,该文件只有root用户拥有读权限,从而保证密码安全性


第2章 用户管理

1.2.1 用户命令

命令:useradd

useradd -m -g "初始组" -G "附加组" -s "登陆的shell" "用户"

  • -m:创建用户主目录/home/[用户名];(注:在自己的主目录内,即使不是root用户也可以读写文件、安装程序等)
  • -g:设置用户初始组的名称或数字ID;该组必须是存在的;如果没有设置该选项,useradd会根据/etc/login.defs文件中的USERGROUPS_ENAB环境变量进行设置。默认USERGROUPS_ENAB yes 会用和用户名相同的名字创建群组,GID 等于 UID.
  • -G:用户要加入的附加组列表;使用逗号分隔多个组,不要添加空格;如果不设置,用户仅仅加入初始组。
  • -s:用户默认登录shell的路径;启动过程结束后,默认启动的登录shell在此处设定;请确保使用的shell已经安装,默认是 。
  • 有时候需要禁止某些用户执行登录动作,例如用来执行系统服务的用户。将shell设置成 /sbin/nologin 就可以禁止用户登录。

1.2.2 添加登录用户

例:添加一个名为harry的用户,并使用bash使用登录的shell

[root@panda ~]# useradd -s /bin/bash harry

说明:此命令会自动创建harry 组,并成为 harry 的默认登录主组。

用户帐户的全部信息被保存在/etc/passwd文件。这个文件以如下格式保存了每一个系统帐户的所有信息 (字段以“:”分割)

/etc/passwd 每个字段的作用:

[root@panda ~]# head -1 /etc/passwd

root:x:0:0:root:/root:/bin/bash

用户名 : 密码占位符 : UID : 用户所属组的GID : 用户描述 : 用户主目录(bash中"~"代表那个) : 登录后使用的shell

linux中任何一个命令的操作都必须有一个用户的身份;任何一个程序的运行必须要有一个特定的用户;任何一个文件必须要有一个特定的用户;访问一个文件或目录必须受限于一个用户;

1.2.3 指定用户UID

[root@panda ~]# useradd -u 1100 xuegod-2

[root@panda ~]# ls /home

miao xuegod-1 xuegod-2

[root@panda ~]# tail -2 /etc/passwd

xuegod-1:x:1005:1005::/home/xuegod-1:/bin/bash

xuegod-2:x:1100:1100::/home/xuegod-2:/bin/bash

1.2.4 指定用户主目录

[root@panda ~]# useradd -d /mnt/xuegod-3 xuegod-3

useradd: cannot set SELinux context for home directory /tmp/xuegod-3

1.2.5 指定用户的起始组

[root@panda ~]# id xuegod-1

uid=1005(xuegod-1) gid=1005(xuegod-1) groups=1005(xuegod-1)

[root@panda ~]# useradd -g xuegod-1 xuegod-4

[root@panda ~]# id xuegod-4

uid=1102(xuegod-4) gid=1005(xuegod-1) groups=1005(xuegod-1)

[root@panda ~]# grep "god-1\|god-4" /etc/passwd

xuegod-1:x:1005:1005::/home/xuegod-1:/bin/bash

xuegod-4:x:1102:1005::/home/xuegod-4:/bin/bash

1.2.6 指定用户附加组

我们也叫它为补充组,用户可以是0个或多个补充组的成员

其中属于补充组的成员,我们可以在/etc/group中最后一个字段中查看,如下

[root@panda ~]# cat /etc/group

root:x:0:

bin:x:1:

daemon:x:2:

sys:x:3:

adm:x:4:

tty:x:5:

disk:x:6:

lp:x:7:

mem:x:8:

kmem:x:9:

wheel:x:10:miao

补充组成员的身份主要用于帮助确保用户具有对系统中文件及其它资源的访问权限

[root@panda ~]# useradd hr

[root@panda ~]# useradd fd

[root@panda ~]# id hr

uid=1001(hr) gid=1001(hr) groups=1001(hr)

[root@panda ~]# id fd

uid=1002(fd) gid=1002(fd) groups=1002(fd)

[root@panda ~]# usermod -G wheel hr

[root@panda ~]# id hr

uid=1001(hr) gid=1001(hr) groups=1001(hr),10(wheel)

[root@panda ~]# usermod -G fd hr

[root@panda ~]# id hr

uid=1001(hr) gid=1001(hr) groups=1001(hr),1002(fd)

[root@panda ~]# usermod -aG wheel hr

[root@panda ~]# id hr

uid=1001(hr) gid=1001(hr) groups=1001(hr),10(wheel),1002(fd)

1.2.7 创建用户的另外的命令

[root@panda ~]# adduser market

[root@panda ~]# grep market /etc/passwd /etc/group /etc/shadow

/etc/passwd:market:x:1004:1004::/home/market:/bin/bash

/etc/group:market:x:1004:

/etc/shadow:market:!!:17258:0:99999:7:::

1.2.8 删除用户

语法:userdel 【参数】用户名

参数:

-r 删除用,同时删除用户家目录和mail spool下的用户目录

[root@panda ~]# ls /home

[root@panda ~]# userdel –r xuegod-1

1.2.9 密码的文件

[root@panda ~]# tail -4 /etc/passwd

xuegod-1:x:1005:1005::/home/xuegod-1:/bin/bash

xuegod-2:x:1100:1100::/home/xuegod-2:/bin/bash

xuegod-3:x:1101:1101::/tmp/xuegod-3:/bin/bash

xuegod-4:x:1102:1005::/home/xuegod-4:/bin/bash

[root@panda ~]# tail -4 /etc/shadow

xuegod-1:!!:17258:0:99999:7:::

xuegod-2:!!:17258:0:99999:7:::

xuegod-3:!!:17258:0:99999:7:::

xuegod-4:!!:17258:0:99999:7:::

[root@panda ~]# passwd xuegod-1

Changing password for user xuegod-1.

New password:

BAD PASSWORD: The password is shorter than 8 characters

Retype new password:

passwd: all authentication tokens updated successfully.

[root@panda ~]# grep xuegod-1 /etc/shadow

xuegod-1:$6$bfeWip/u$S1KmpF5UWUO0Nl5hdNw1QA0MyO1Mwgc5YszcIFk6ydWcPveBYFY3j3/mqD9M6.sU2PkCrTDguR9TwuCFBJBds1:17258:0:99999:7:::

列说明:

xuegod-1:$6$bfeWip/u$S1KmpF5UWUO0Nl5hdNw1QA0MyO1Mwgc5YszcIFk6ydWcPveBYFY3j3/mqD9M6.sU2PkCrTDguR9TwuCFBJBds1:17258:0:99999:7:::

格式说明如下(9个冒号分隔的字段):


1

name

登录名称,这个必须是系统中的有效账户名

2

password

已加密密码,查看帮助说明:盐

man 5 passwd

man 5 shadow

man 5 group

man 3 crypt

3

lastchange

最近一次更改密码的日期,以距离1970/1/1的天数表示

4

min-age

不能更改密码的最少天数,最近更改过后几天才可以更改;如果为0表示“最短期限要求”

5

maxage

密码过期时间,必须更改密码前的最多天数

6

warning

密码即将到期的警告期,以天数表示,0表示“不提供警告”

7

inactive

宽限天数,密码到期后

8

expire

账号过期时间,以距离1970/1/1的天数计算

9

blank

预留字段


扩展:

另外一种添加密码

[root@panda ~]# echo 123456|passwd --stdin xuegod-2

1.2.10 修改密码信息(扩展)

  • useradd在创建用户时,会参照的文件如下:

[root@panda ~]# vim /etc/login.defs

[root@panda ~]# cat /etc/login.defs |grep -v "^#\|^#34;

MAIL_DIR /var/spool/mail

PASS_MAX_DAYS 99999

PASS_MIN_DAYS 0

PASS_MIN_LEN 5

PASS_WARN_AGE 7

UID_MIN 1000

UID_MAX 60000

SYS_UID_MIN 201

SYS_UID_MAX 999

GID_MIN 1000

GID_MAX 60000

SYS_GID_MIN 201

SYS_GID_MAX 999

CREATE_HOME yes

UMASK 077

USERGROUPS_ENAB yes

ENCRYPT_METHOD SHA512

[root@panda ~]# vim /etc/default/useradd

[root@panda ~]# cat !$

cat /etc/default/useradd

# useradd defaults file

GROUP=100

HOME=/home

INACTIVE=-1

EXPIRE=

SHELL=/bin/bash

SKEL=/etc/skel

CREATE_MAIL_SPOOL=yes

  • 密码的年龄问题 password aging

下图显示了密码过期的相关参数,可以通过chage对其进行调整,以实施密码过期策略

命令:chage

它是用来更改用户密码过期信息,用到的几个参数如下:

  • -m:密码可更改的最小天数。为0时代表任何时候都可以更改密码
  • -M:密码保持有效的最大天数
  • -W:用户密码到期前,提前收到警告信息的天数
  • -E:帐号到期的日期。过了这天,此帐号将不可用
  • -d:上一次更改的日期,为0表示强制在下次登录时更新密码
  • -I:停滞时期。如果一个密码已过期这些天,那么此帐号将不可用
  • -l:(list)列出当前的设置,由非特权用户来确定他们的密码或帐号何时过期

[root@panda ~]# chage -l xuegod-1

Last password change : Apr 02, 2017

Password expires : never

Password inactive : never

Account expires : never

Minimum number of days between password change : 0

Maximum number of days between password change : 99999

Number of days of warning before password expires : 7

我们修改用户xuegod-1的密码信息:让这个用户在首次登录系统时更改其密码,之后每30天被要求更改密码,还要求这个账户在90天后到期,禁止使用

[root@panda ~]# chage -d 0 -M 30 -W 3 xuegod-1

[root@panda ~]# chage -l xuegod-1

[root@panda ~]# date -d "+90 days"

[root@panda ~]# chage -E "2017-07-05" xuegod-1

[root@panda ~]# date -s 2017-7-6

1.2.11 修改用户信息

语法:usermod 【参数】用户名

常用参数:

  • -u UID
  • -d 宿主目录
  • -g 起始组 #只能有一个
  • -G 附加组 #可以有多个
  • -s 登录shell
  • -L 锁定

举例如下:

例1:修改UID

例2:修改shell

[root@panda ~]# tail -1 /etc/passwd

zabbix:x:1105:1105::/home/zabbix:/sbin/nologin

[root@panda ~]# usermod -s /bin/bash zabbix

[root@panda~]# tail -1 /etc/passwd

zabbix:x:1105:1105::/home/zabbix:/bin/bash

再次尝试登录

例3:修改登录用户名

[root@panda~]# usrmod -l xuegod-1 zabbix

例4:更改用户主目录

[root@panda~]# usrmod -d /my/new/home –m username

-m选项会自动创建新目录并移动内容

例5:添加用户说明信息

[root@panda~]# chfn [用户名]

(这样将会以交互式模式启动chfn),查看用户具体信息用finger(需要安装这个包)

此外,也可以通过下面这种方式添加GECOS(用户的全名)

[root@panda~]# usermod -c "Comment" username


第3章 组分类

根据帐号的功能:超级用户组(root)  GID:0

        普通用户组

        系统用户组 GID:1-999 redhat6 是1-499

        本地用户 组 GID:1000+ redhat6 是500+

组的配置文件

/etc/group

[root@panda ~]# tail -5 /etc/group

miao:x:1000:

fd:x:1002:

xuegod-1:x:1005:xuegod-2

xuegod-2:x:1100:

xuegod-3:x:1101:

组名:组密码占位符:用户组的GID:用户名:组成员

将多个用户加入到指定的组:

[root@tianyun~]# gpasswd -a jack wheel //usermod -aG hr zhuzhu

[root@tianyun~]# gpasswd -M zhuzhu,maomao100 hr

[root@panda ~]# gpasswd -d xuegod-2 xuegod-1 --->删除用户xuegod-2从组xuegod-1中

[root@panda ~]# gpasswd -a xuegod-2 xuegod-1 --->添加用户xuegod-2到组xuegod-1

3.1 控制添加用户规则的文件

当添加新的用户帐户时,默认会执行下列操作

  • 它的主目录就会被创建(一般是"/home/用户名",除非你特别设置)
  • 一些隐藏文件 如.bash_logout, .bash_profile 以及 .bashrc 会被复制到用户的主目录。
  • 会创建一个和用户名同样的组(注:除非你给新创建的用户指定了组)

3.2 解决模板文件被删之后显示不正常的问题

删除后出现的情况

进行恢复:

扩展:

  • 加上 - ,在切换时会把环境变量一起进行切换
  • 不加 -,保留原本的环境变量

第4章 查看用户信息相关命令:

id :显示当前有效用户的UID和GID信息

[root@xuegod1611 ~]#

[root@xuegod1611 ~]# id san

uid=1001(san) gid=1001(san) groups=1001(san)

w:用于显示已经登录系统的用户列表,并显示正在执行的指令与程序

[root@xuegod1611 ~]# w

22:10:02 up 3:17, 4 users, load average: 0.00, 0.01, 0.05

USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT

root pts/0 192.168.1.107 18:53 2.00s 1.08s 0.00s w

root pts/1 192.168.1.107 22:09 46.00s 0.06s 0.06s -bash

zabbix pts/2 192.168.1.107 22:09 5.00s 0.06s 0.06s -bash

who:显示目前登录系统的用户信息

[root@xuegod1611 ~]# who

(unknown) :0 2016-12-03 18:52 (:0)

root pts/0 2016-12-03 18:53 (192.168.1.107)

root pts/1 2016-12-03 22:09 (192.168.1.107)

zabbix pts/2 2016-12-03 22:09 (192.168.1.107)

whoami:打印当前有效的用户名称

[root@xuegod1611 ~]# whoami

root

[root@xuegod1611 ~]# who am i

root pts/0 2016-12-03 18:53 (192.168.1.107)

finger:查找并显示用户信息

安装一个包

[root@xuegod1611 ~]# yum -y install finger

Loaded plugins: langpacks, product-id, search-disabled-repos, subscription-manager

This system is not registered to Red Hat Subscription Management. You can use subscription-manager to register.

rhel7-server | 4.1 kB 00:00:00

Resolving Dependencies

--> Running transaction check

---> Package finger.x86_64 0:0.17-52.el7 will be installed

--> Finished Dependency Resolution

Dependencies Resolved

=====================================================================================

Package Arch Version Repository Size

=====================================================================================

Installing:

finger x86_64 0.17-52.el7 rhel7-server 26 k

Transaction Summary

=====================================================================================

Install 1 Package

Total download size: 26 k

Installed size: 32 k

Downloading packages:

Running transaction check

Running transaction test

Transaction test succeeded

Running transaction

Warning: RPMDB altered outside of yum.

Installing : finger-0.17-52.el7.x86_64 1/1

rhel7-server/productid | 1.6 kB 00:00:00

Verifying : finger-0.17-52.el7.x86_64 1/1

Installed:

finger.x86_64 0:0.17-52.el7

Complete!

[root@xuegod1611 ~]# finger zabbix

Login: zabbix Name:

Directory: /home/zabbix Shell: /bin/bash

On since Sat Dec 3 22:09 (CST) on pts/2 from 192.168.1.107

4 minutes 13 seconds idle

No mail.

No Plan.

[root@xuegod1611 ~]# finger root

Login: root Name: root

Directory: /root Shell: /bin/bash

On since Sat Dec 3 18:53 (CST) on pts/0 from 192.168.1.107

1 second idle

On since Sat Dec 3 22:09 (CST) on pts/1 from 192.168.1.107

5 minutes 9 seconds idle

Mail last read Sat Dec 3 19:48 2016 (CST)

No Plan.

给普通用户进行提权操作的两种方法:

  1. 通过su切换用户
  2. 在普通用户下以root身份授权普通用户执行命令

[root@panda ~]# vim /etc/sudoers --->在RHEL7中默认是打开wheel这个功能的

## Allows people in group wheel to run all commands

%wheel ALL=(ALL) ALL

## Same thing without a password

# %wheel ALL=(ALL) NOPASSWD: ALL

上面两个区别就是要不要输入密码在使用sudo时。有%表示一个组的名字,不带是一个用户的名字

[root@panda ~]# useradd xuegod-1 -G wheel

[root@panda ~]# id xuegod-1

[xuegod-1@panda ~]$ useradd liumang --->提示没有权限

[xuegod@panda ~]$ sudo useradd liumang

[xuegod@panda ~]$ id liumang

第5章 实战:RHEL7恢复root密码

首先关闭SELINUX

[root@xuegod1611 ~]# getenforce

Disabled

然后重启,按↑↓键,进入如下界面,选择第一项,按下e键进行编辑

在此界面找到ro这一项,并进行修改,改为rw init=/sysroot/bin/sh

改完之后,按下Ctrl+X进入紧急模式

原理:启动一个shell环境,系统并没有真正的启动

换根,修改密码

注:当前目录默认是根(/)

chroot命令用来在指定的根目录下运行指令

chroot,即 change root directory (更改 root 目录)。在 linux 系统中,系统默认的目录结构都是以/,即是以根 (root) 开始的。而在使用 chroot 之后,系统的目录结构将以指定的位置作为/位置

在经过 chroot 命令之后,系统读取到的目录和文件将不在是旧系统根下的而是新根下(即被指定的新的位置)的目录结构和文件,

如何之前系统启用了selinux,必须运行以下命令,否则将无法正常启动系统:touch /.autorelabel

重启系统

先退出当前根,执行/bin/sh shutdown –r now


进入system虚拟机后,重启按E进入编辑启动菜单,找到内核项,在后面加入(rd.break console=tty0)

crtl+x

重启后的那个界面,我们挂载一下根目录,因为你输入一个df命令都不存在。所以要挂载

mount -o remount,rw /sysroot

chroot /sysroot

passwd

touch /.autorelabel

Exit

reboot


如果对你有帮助的话,欢迎关注转发点赞收藏

相关推荐

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文件系统访问存储在硬盘中的文件。如果你...

取消回复欢迎 发表评论: