1、显示/etc目录下,以非字母开头,后面跟了一个字母以及其它任意长度任意字符的文件或目录

1 [root@centos8 etc]#touch 5a.txt 9a.txt
2 [root@centos8 etc]#mkdir 3eeee
3 [root@centos8 etc]#ls -d /etc/[^[:alpha:]][[:alpha:]]*
4 /etc/3eeee /etc/5a.txt /etc/9a.txt

2、复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中。

1 [root@centos8 ~]#mkdir -p /tmp/mytest1
2 [root@centos8 ~]#cd /tmp/mytest1
3 [root@centos8 mytest1]#cp -rf /etc/p[[:alpha:]]*[^[:digit:]] /tmp/mytest1
4 [root@centos8 mytest1]#ls /tmp/mytest1
5 pam.d passwd pbm2ppa.conf pipewire plymouth popt.d prelink.conf.d profile protocols
6 papersize passwd- pinforc pki pnm2ppa.conf postfix printcap profile.d pulse

3、将/etc/issue文件中的内容转换为大写后保存至/tmp/issue.out文件中

 1 [root@centos8 ~]#ls /etc/issue
2 /etc/issue
3 [root@centos8 ~]#cat /etc/issue
4 \S
5 Kernel \r on an \m
6 [root@centos8 ~]#cat /etc/issue |tr a-z A-Z
7 \S
8 KERNEL \R ON AN \M
9 [root@centos8 ~]#cat /etc/issue |tr a-z A-Z >> /tmp/issue.out
10 [root@centos8 ~]#cat /tmp/issue.out
11 \S
12 KERNEL \R ON AN \M

4、请总结描述用户和组管理类命令的使用方法并完成以下练习:

用户管理命令
useradd
usermod
userdel

组帐号维护命令
groupadd
groupmod
groupdel


4.1 useradd 用户创建

useradd 命令可以创建新的Linux用户
格式:

useradd [options] LOGIN

-u UID: 新UID
-g GID: 新主组
-G GROUP1[,GROUP2,...[,GROUPN]]]:新附加组,原来的附加组将会被覆盖;若保留原有,则要同时使
用-a选项
-s SHELL:新的默认SHELL
-c 'COMMENT':新的注释信息
-d HOME: 新家目录不会自动创建;若要创建新家目录并移动原家数据,同时使用-m选项
-l login_name: 新的名字
-L: lock指定用户,在/etc/shadow 密码栏的增加 !
-U: unlock指定用户,将 /etc/shadow 密码栏的 ! 拿掉
-e YYYY-MM-DD: 指明用户账号过期日期
-f INACTIVE: 设定非活动期限,即宽限期


4.2 usermod 用户属性修改

usermod 命令可以修改用户属性
格式:

usermod [OPTION] login

常见选项:

-u UID: 新UID
-g GID: 新主组
-G GROUP1[,GROUP2,...[,GROUPN]]]:新附加组,原来的附加组将会被覆盖;若保留原有,则要同时使
用-a选项
-s SHELL:新的默认SHELL
-c 'COMMENT':新的注释信息
-d HOME: 新家目录不会自动创建;若要创建新家目录并移动原家数据,同时使用-m选项
-l login_name: 新的名字
-L: lock指定用户,在/etc/shadow 密码栏的增加 !
-U: unlock指定用户,将 /etc/shadow 密码栏的 ! 拿掉
-e YYYY-MM-DD: 指明用户账号过期日期
-f INACTIVE: 设定非活动期限,即宽限期

4.3 userdel 删除用户

userdel 可删除Linux 用户
格式:

userdel [OPTION]... Login

常见选项:

-f, --force 强制
-r, --remove 删除用户家目录和邮箱

4.4 groupadd 创建组

格式:

groupadd [OPTION]... group_name

常见选项:

-g GID 指明GID号;[GID_MIN, GID_MAX]
-r 创建系统组,CentOS 6之前: ID<500,CentOS 7以后: ID<1000

4.5 groupmod 组属性修改

格式:

groupmod [OPTION]... group

常见选项:

-n group_name: 新名字
-g GID: 新的GID

4.6 groupdel 删除组

格式:

groupdel [options] GROUP

常见选项:

-f, --force 强制删除,即使是用户的主组也强制删除组,但会导致无主组的用户不可用无法登录

4.7 查看用户相关的ID信息

id 命令可以查看用户的UID,GID等信息

id [OPTION]... [USER]

常见选项

-u: 显示UID
-g: 显示GID
-G: 显示用户所属的组的ID
-n: 显示名称,需配合ugG使用

4.8 切换用户或以其他用户身份执行命令

su: 即 switch user,命令可以切换用户身份,并且以指定用户的身份执行命令

格式:

su [options...] [-] [user [args...]]

常见选项:

-l --login su -l UserName 相当于 su - UserName
-c, --command <command> pass a single command to the shell with -c

4.9 设置密码

passwd 可以修改用户密码
格式:

passwd [OPTIONS] UserName

常用选项:

-d:删除指定用户密码
-l:锁定指定用户
-u:解锁指定用户
-e:强制用户下次登录修改密码
-f:强制操作
-n mindays:指定最短使用期限
-x maxdays:最大使用期限
-w warndays:提前多少天开始警告
-i inactivedays:非活动期限
--stdin:从标准输入接收用户密码,Ubuntu无此选项

4.10 修改用户密码策略

chage 可以修改用户密码策略
格式:

chage [OPTION]... LOGIN

常用选项:

-d LAST_DAY #更改密码的时间
-m --mindays MIN_DAYS
-M --maxdays MAX_DAYS
-W --warndays WARN_DAYS
-I --inactive INACTIVE #密码过期后的宽限期
-E --expiredate EXPIRE_DATE #用户的有效期
-l 显示密码策略

4.11 临时切换主组
newgrp 命令可以临时切换主组, 如果用户本不属于此组,则需要组密码
格式:

newgrp [-] [group]

4.12 更改和查看组成员
groupmems 可以管理附加组的成员关系
格式

groupmems [options] [action]

常见选项

-g, --group groupname #更改为指定组 (只有root)
-a, --add username #指定用户加入组
-d, --delete username #从组中删除用户
-p, --purge #从组中清除所有成员
-l, --list #显示组成员列表

4.13 groups 可查看用户组关系

格式

#查看用户所属组列表
groups [OPTION].[USERNAME]...

 

(1)、创建组distro,其GID为2019;

1 [root@centos8 ~]#groupadd -g 2019  distro

(2)、创建用户mandriva, 其ID号为1005;基本组为distro;

1 [root@centos8 ~]#useradd -u 1005 -g distro mandriva
2 useradd: user 'mandriva' already exists
3 [root@centos8 ~]#getent passwd mandriva
4 mandriva:x:1001:1001::/home/mandriva:/bin/bash

(3)、创建用户mageia,其ID号为1100,家目录为/home/linux;

1 [root@centos8 ~]#useradd -u 1100 -d /home/linux mageia
2 [root@centos8 ~]#getent passwd mageia
3 mageia:x:1100:1100::/home/linux:/bin/bash

(4)、给用户mageia添加密码,密码为mageedu,并设置用户密码7天后过期

1 [root@centos8 ~]#passwd mageia
2 Changing password for user mageia.
3 New password:
4 BAD PASSWORD: The password is shorter than 8 characters
5 Retype new password:
6 passwd: all authentication tokens updated successfully.
7 [root@centos8 ~]#chage -E 7 mageia

(5)、删除mandriva,但保留其家目录;

1 [root@centos8 ~]#userdel mandriva
2 [root@centos8 ~]#id mandriva
3 id: ‘mandriva’: no such user
4 [root@centos8 ~]#getent passwd mandriva
5 [root@centos8 ~]#ll /home
6 total 4
7 drwx------. 16 brucelebron brucelebron 4096 Jan 10 09:53 brucelebron
8 drwx------ 3 mageia mageia 78 Jan 13 21:06 linux
9 drwx------ 3 1001 1001 78 Jan 13 20:40 mandriva

(6)、创建用户slackware,其ID号为2002,基本组为distro,附加组peguin;

1 [root@centos8 ~]#groupadd peguin
2 [root@centos8 ~]#useradd -u 2002 -g distro -G peguin slackware
3 [root@centos8 ~]#id slackware
4 uid=2002(slackware) gid=2019(distro) groups=2019(distro),2020(peguin)

(7)、修改slackware的默认shell为/bin/tcsh;

1 [root@centos8 ~]#usermod -s /bin/tcsh slackware
2 [root@centos8 ~]#getent passwd slackware
3 slackware:x:2002:2019::/home/slackware:/bin/tcsh

(8)、为用户slackware新增附加组admins,并设置不可登陆。

1 [root@centos8 ~]#usermod  -G admins slackware
2 [root@centos8 ~]#usermod -s /sbin/nologin slackware
3 [root@centos8 ~]#su slackware
4 This account is currently not available.

5、创建用户user1、user2、user3。在/data/下创建目录test

1 [root@centos8 ~]#mkdir -p /data/test
2 [root@centos8 ~]#useradd user1;useradd user2;useradd user3;
3 useradd: user 'user1' already exists
4 useradd: user 'user2' already exists
5 useradd: user 'user3' already exists

(1)、目录/data/test属主、属组为user1

1 [root@centos8 data]#chown user1:user1 /data/test
2 [root@centos8 data]#ll
3 total 0
4 drwxr-xr-x 2 user1 user1 6 Jan 13 21:49 test

(2)、在目录属主、属组不变的情况下,user2对文件有读写权限

1 [user2@centos8 data]$echo hello >> a.txt
2 bash: a.txt: Permission denied
3 [user2@centos8 data]$exit
4 exit
5 [root@centos8 data]#setfacl -m u:user2:rw a.txt
6 [root@centos8 data]#su - user2 -c "echo hello >> a.txt
7 > hello

(3)、user1在/data/test目录下创建文件a1.sh, a2.sh, a3.sh, a4.sh,设置所有用户都不可删除1.sh,2.sh文件、除了user1及root之外,所有用户都不可删除a3.sh, a4.sh

 1 [user1@centos8 root]$cd /data/test
2 [user1@centos8 test]$touch a{1..4}.sh
3 [user1@centos8 test]$ll
4 total 0
5 -rw-rw-r-- 1 user1 user1 0 Jan 13 22:47 a1.sh
6 -rw-rw-r-- 1 user1 user1 0 Jan 13 22:47 a2.sh
7 -rw-rw-r-- 1 user1 user1 0 Jan 13 22:47 a3.sh
8 -rw-rw-r-- 1 user1 user1 0 Jan 13 22:47 a4.sh
9 [user1@centos8 test]$chattr +i a1.sh a2.sh
10 chattr: Operation not permitted while setting flags on a1.sh
11 chattr: Operation not permitted while setting flags on a2.sh
12 [user1@centos8 test]$chmod o+x a3.sh a4.sh
13 [user1@centos8 test]$chmod o+t a3.sh a4.sh

(4)、user3增加附加组user1,同时要求user1不能访问/data/test目录及其下所有文件

 1 [root@centos8 ~]#usermod user3 -G user1
2 [root@centos8 ~]#id user3
3 uid=2005(user3) gid=2005(user3) groups=2005(user3),2003(user1)
4 [root@centos8 ~]#setfacl -m u:user:- /data/test
5 setfacl: Option -m: Invalid argument near character 3
6 [root@centos8 ~]#setfacl -m u:user1:- /data/test
7 [root@centos8 ~]#getfacl /data/test/
8 getfacl: Removing leading '/' from absolute path names
9 # file: data/test/
10 # owner: user1
11 # group: user1
12 user::rwx
13 user:user1:---
14 group::r-x
15 mask::r-x
16 other::r-x

(5)、清理/data/test目录及其下所有文件的acl权限

1 [root@centos8 ~]#setfacl -b /data/test/
2 [root@centos8 ~]#getfacl /data/test/
3 getfacl: Removing leading '/' from absolute path names
4 # file: data/test/
5 # owner: user1
6 # group: user1
7 user::rwx
8 group::r-x
9 other::r-x

N63050 第二周运维作业的更多相关文章

  1. 第二周博客作业 <西北师范大学| 周安伟>

    一,本周助教小结 逐步开始适应助教工作,对学生发布的博客进行点评,查看学生对软件工程前期的准备情况. 二,助教本人博客 https://home.cnblogs.com/u/zaw-315/ 三,学生 ...

  2. 第二周Java课堂作业

    演示一: public class EnumTest { public static void main(String[] args) { Size s=Size.SMALL; Size t=Size ...

  3. 第二周博客作业<西北师范大学|李晓婷>

    1.助教博客链接:https://home.cnblogs.com/u/lxt-/ 2.点评作业内容: https://www.cnblogs.com/dxd123/p/10494907.html#4 ...

  4. 【第二周】【作业五】Scrum 每日站会

    1.首先来看一下什么是Scrum: Scrum是一种敏捷软件开发的方法学,用于迭代式增量软件开发过程.Scrum在英语是橄榄球运动中争球的意思. 虽然Scrum是为管理软件开发项目而开发的,它同样可以 ...

  5. 第二周Java实验作业

    实验二 Java基本程序设计(1) 实验时间 2018-9-6 1.实验目的与要求 (1)进一步熟悉命令行和IDE两种方式下java程序开发的基本步骤: (2)掌握Eclipse集成开发环境下导入Ja ...

  6. 老男孩python自动化运维作业2

    拿到要求真不知道怎么写,不能还要写个商城页面吧: 最后还是用了input()模拟用户操作吧- -!不就操作个字典吗(字典模拟商品数据). python版本: >>>import sy ...

  7. 老男孩python自动化运维作业1

    #!/usr/bin/env pthon #字典操作三级菜单 “b”返回上一级菜单,“q”退出. menu={"BJ":{"cp":{1:1,2:2,3:3}, ...

  8. 《LDAP服务器和客户端的加密认证》RHEL6——第二篇 运维工程师必考

    服务端的配置: (基于原先配好的ldap服务器)打开加密认证: Iptables –F  setenforce 0 1.编辑ldap的配置文件:slapd.conf 2.启动ldap服务器: 3.切换 ...

  9. 20165234 《Java程序设计》第二周课下作业

    1. 教材代码完成情况测试P14 把100改为自己的后四位学号,编译运行Kernighan.java 代码的功能是从给定一个数字,实现从1依次加到此数的和. 如下是我用命令行实现代码的编译与运行. 2 ...

  10. 中型企业的IT运维策略

    如何建设一支能够解决问题.创造价值.有活力的.不断进取的IT运维团队,并带领这支团队?充分发挥这个团队的优势力量,是运维业务有效开展的关 键.运维策略是直接体现运维业务的经济价值所在.好的运维措施.方 ...

随机推荐

  1. Generator(生成器),入门初基,Coroutine(原生协程),登峰造极,Python3.10并发异步编程async底层实现

    普遍意义上讲,生成器是一种特殊的迭代器,它可以在执行过程中暂停并在恢复执行时保留它的状态.而协程,则可以让一个函数在执行过程中暂停并在恢复执行时保留它的状态,在Python3.10中,原生协程的实现手 ...

  2. 使用C语言编程的7个步骤

    版权声明 本文作者:main工作室 本文链接:https://www.cnblogs.com/main-studio/p/17034891.html 版权声明:本文为 博客园 博主「main工作室」的 ...

  3. Python自动化操作sqlite数据库

    你好,我是悦创. 原文首发:https://bornforthis.cn/column/pyauto/ 1. 什么是数据库 数据库是"按照数据结构来组织.存储和管理数据的仓库",是 ...

  4. Hadoop生态元数据管理平台——Atlas2.3.0发布!

    大家好,我是独孤风. 今天我们来聊一下另一个元数据管理平台Apache Atlas.Atlas其实有一些年头了,是在2015年的时候就开源. 相对于Datahub来说,Atlas显得有一些" ...

  5. 《Effective C++》继承与面向对象设计

    Item 32:确定你的public继承塑膜出is-a的关系 如果你令class D以public继承class B,你便是告诉编译器说,每一个类型为D的对象同时也是一种B对象,反之如果你需要一个D对 ...

  6. linux 基础(2) 文件权限及其修改

    文件的权限属性 在 linux 中,每个文件都有唯一的"所属者"(user)和"所属群组"(group).owner 和 group 都对文件有特殊的权限 输入 ...

  7. three.js一步一步来--如何画出构造辅助线

    可以参考下面代码,粘贴上去就有了~ <template> <div class="container"> <h1>初步构造出辅助线</h1 ...

  8. 结构性模式 - 适配器模式Adapter

    学习而来,代码是自己敲的.也有些自己的理解在里边,有问题希望大家指出. 模式的定义与特点 适配器模式(Adapter)的定义如下:将一个类的接口转换成客户希望的另外一个接口,使得原本由于接口不兼容而不 ...

  9. 快速实现一个简单阉割版的HashMap

    简单实现一个底层数据结构为数组 + 链表的HashMap,不考虑链表长度超过8个时变为红黑树的情况. 1.示例图 2.分析需求 put数据时: key值hash后的索引处没有元素,需要创建链表头节点, ...

  10. vue学习笔记(二) ---- vue实例的生命周期

    vue实例的生命周期 什么是生命周期:从Vue实例创建.运行.到销毁期间,总是伴随着各种各样的事件,这些事件,统称为生命周期! 生命周期钩子:就是生命周期事件的别名而已: 生命周期钩子 = 生命周期函 ...