用户管理、组管理、权限管理、文本处理工具应用示例

用户管理、组管理、权限管理、文本处理工具应用示例

  • 1.复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其他用户均没有任何访问权限

     [root@localhost ~]# cp -a /etc/skel/ /home/tuser1/
     [root@localhost ~]# chmod -R go= /home/tuser1
     [root@localhost home]# ls -l
     total 4
     drwx------.  3 archlinux archlinux   78 Jul  1 20:04 archlinux
     drwx------. 14 njy       njy       4096 Jul 16 05:13 njy
     drwx------.  3 root      root        78 Jul  9 05:32 tuser1
  • 2.编辑/etc/group文件,添加组hadoop

     [root@localhost ~]# vim /etc/group
     [root@localhost ~]# echo "hadoop:x:1003:" >> /etc/group 
     [root@localhost ~]# cat /etc/group 
     njy:x:1000:
     gentoo:x:1001:archlinux
     archlinux:x:1002:njy
     hadoop:x:1003:
  • 3.手动编辑/etc/passwd文件新增一行,添加用户hadoop,其基本组ID为hadoop组的id号,其家目录为/home/hadoop

     [root@localhost ~]# vim /etc/passwd
     [root@localhost ~]# echo "hadoop:x:1002:1003:hadoop:/home/hadoop:/bin/bash" >> /etc/passwd
     [root@localhost ~]# cat /etc/passwd 
     njy:x:1000:1000:centos1:/home/njy:/bin/bash
     archlinux:x:1001:1002::/home/archlinux:/bin/bash
     hadoop:x:1002:1003:hadoop:/home/hadoop:/bin/bash
  • 4.复制/etc/skel目录为/home/hadoop,要求修改hadoop目录的属组和其他用户没有任何访问权限

     [root@localhost home]# cp -a /etc/skel/ /home/hadoop/
     [root@localhost home]# chmod -R go= /home/hadoop
     [root@localhost home]# ls -l
     total 4
     drwx------.  3 archlinux archlinux   78 Jul  1 20:04 archlinux
     drwx------.  3 root      root        78 Jul  9 05:32 hadoop
     drwx------. 14 njy       njy       4096 Jul 16 05:13 njy
     drwx------.  3 root      root        78 Jul  9 05:32 tuser1
  • 5.修改/home/hadoop目录及其内部所有文件的属主为hadoop,属组为hadoop

     [root@localhost home]# chown -R hadoop:hadoop hadoop
     [root@localhost home]# ls -l
     total 4
     drwx------.  3 archlinux archlinux   78 Jul  1 20:04 archlinux
     drwx------.  3 hadoop    hadoop      78 Jul  9 05:32 hadoop
     drwx------. 14 njy       njy       4096 Jul 16 05:13 njy
     drwx------.  3 root      root        78 Jul  9 05:32 tuser1
  • 6.显示/proc/meminfo文件中以大写或小写S开头的行;用两种方式

     [root@localhost home]# cat /proc/meminfo |grep "^[sS]"
     SwapCached:            0 kB
     SwapTotal:       2098172 kB
     SwapFree:        2098172 kB
     Shmem:              7300 kB
     Slab:             114724 kB
     SReclaimable:      62128 kB
     SUnreclaim:        52596 kB
     [root@localhost home]# cat /proc/meminfo |grep -i "^s"
     SwapCached:            0 kB
     SwapTotal:       2098172 kB
     SwapFree:        2098172 kB
     Shmem:              7300 kB
     Slab:             114724 kB
     SReclaimable:      62128 kB
     SUnreclaim:        52596 kB
  • 7.显示/etc/passwd文件中其默认的shell为非/sbin/nologin的用户

     [root@localhost home]# cat /etc/passwd|grep -v "/sbin/nologin$"|cut -d: -f1
     root
     sync
     shutdown
     halt
     njy
     archlinux
     hadoop
  • 8.显示/etc/passwd文件中其默认的shell为/bin/bash的用户

     [root@localhost home]# cat /etc/passwd|grep "/bin/bash$"|cut -d: -f1
     root
     njy
     archlinux
     hadoop
  • 9.找出/etc/passwd文件中的一位数或者两位数

     [root@localhost home]# cat /etc/passwd|grep -o -E "[[:digit:]]{1,2}"
  • 10.显示/boot/grub/grub.conf中至少一个空白字符开头的行

     [root@localhost home]# cat /boot/grub/grub.conf |grep "^[[:space:]]\+"
  • 11.显示/etc/rc.d/rc.sysinit文件中以#开头,后面至少跟一个空白字符,而后又至少一个非空白字符的行

     [root@localhost home]# cat /etc/rc.d/rc.sysinit|grep "^#[[:space:]]\+[^[:space:]]\+"
  • 12.打出netstat -tan命令执行结果中以‘LISTEN’,后跟空白字符结尾的行

     [root@localhost home]# netstat -tan|grep "LISTEN.*[[:space:]]\+$"
      tcp        0      0 0.0.0.0:111             0.0.0.0:*               LISTEN
      tcp        0      0 192.168.122.1:53        0.0.0.0:*               LISTEN
      tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN
      tcp        0      0 127.0.0.1:631           0.0.0.0:*               LISTEN
      tcp        0      0 127.0.0.1:25            0.0.0.0:*               LISTEN
      tcp6       0      0 :::111                  :::*                    LISTEN
      tcp6       0      0 :::22                   :::*                    LISTEN
      tcp6       0      0 ::1:631                 :::*                    LISTEN
      tcp6       0      0 ::1:25                  :::*                    LISTEN
  • 13.添加用户bash,testbash,basher,nologin(此一个用户的shell为/sbin/nologin),而后找出当前系统上其用户名和默认shell相同的用户信息

      [root@localhost home]# useradd bash
      [root@localhost home]# useradd testbash
      [root@localhost home]# useradd basher
      [root@localhost home]# useradd -s /sbin/nologin nologin
      [root@localhost home]# cat /etc/passwd|grep -E "^([[:alpha:]]+\>).*\1$"
      sync:x:5:0:sync:/sbin:/bin/sync
      shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
      halt:x:7:0:halt:/sbin:/sbin/halt
      bash:x:1003:1004::/home/bash:/bin/bash
      nologin:x:1006:1007::/home/nologin:/sbin/nologin

原创文章,作者:N27_xiaoni,如若转载,请注明出处:http://www.178linux.com/82365

(0)
N27_xiaoniN27_xiaoni
上一篇 2017-07-23 18:18
下一篇 2017-07-23 19:54

相关推荐

  • 文本处理学习小结

    抽取文本的工具 文件内容:less和cat 文件截取:head和tail 按列抽取:cut 按关键字抽取:grep 文件查看 复制标准输入到标准输出 文件查看命令:cat, tac,rev cat命令: cat [OPTION]… [FILE]… -E: 显示行结束符$ -n: 对显示出的每一行进行编号 -A:显示所有控制符 -b:非…

    Linux干货 2016-08-07
  • Week 1 Linux Intro

    I.  Linux的各种发行版 All Kinds of Linux     在Linux诞生的20多年里,Linux衍变出了许许多多的版本,每个都有自己的名字,但它们的本质和它们的哲学观还是一样的。下面是从外网上扒下来的一张Linux进化图,跨度一直到了2016年。    &n…

    Linux干货 2016-06-26
  • 磁盘冗余阵列 RAID

    一、磁盘冗余阵列 RAID(Redundant Array of Independent Disk)     RAID是一种把多块独立的硬盘(物理硬盘)按不同的方式组合起来形成一个硬盘组(逻辑硬盘),从而提供比单个硬盘更高的存储性能和提供数据备份技术。根据磁盘陈列的不同组合方式,可以将RAID分为不同的级别。 其中提高传输速率和…

    Linux干货 2016-09-07
  • Linux用户和组的相关命令(二、组的相关命令)

    用户和组之间息息相关。创建用户时 ,Linux系统会默认生成一个与用户名相同的组,这个组是用户的私有组,也是用户的主组。对用户来说,主组有且只有一个,但是可以有零个或多个附加组。可以在组内设置组管理员来管理组内的用户列表,组管理员可以删除用户列表内的组员。组管理员不唯一,可以有零个或多个。 关于组及其属性和组密码及其属性的有关信息保存在/etc/group和…

    2017-07-22
  • 用户组管理系列(二):权限设置

    1、权限简介    操作系统中每个文件都拥有特定的权限、所属用户和所属组。权限是操作系统用来限制资源访问的机制,在Linux中权限一般分为读(readable)、写(writable)和执行(excutable),分为三组。分别对应文件的属主(owner),属组(group)和其他用户(other),通过这样的机制来限制哪些用户、哪些组可…

    Linux干货 2016-08-05
  • Linux系统程序包的安装–RPM

           我们知道在操作系统上使用的程序都是有程序员通过开发工具得来的,程序员直接编写的纯文本的文件,我们称之为源代码,由于计算机识别的是二进制程序,因此在完成源代码编写之后,就必须要经过编译,使之成为操作系统可以“看得懂”的二进制程序,这里的编译是通过编译器来进行的操作,编译器的功能就是将源代码程序“转换”为二进…

    2017-04-23

评论列表(1条)

  • 马哥教育
    马哥教育 2017-07-27 00:13

    赞,总结的不错,也没有出现错误,可见是用了心的,继续加油~