文件管理和用户组权限管理小结

文件管理


QQ截图20170715205030

文件系统结构
/boot: 引导文件存放目录,内核文件,引导加载器都存放在此目录
/bin:供所有用户使用的基本命令,不能关联至独立分区,os启动即会用到的程序
/sbin:管理类的基本命令:不能关联至独立分区,os启动即会用到的程序
/etc:配置文件目录
/home:普通用户家目录
/root:管理员的家目录
/dev: 设备文件及特殊文件存储位置
        b:block device 随机访问
        c:character device 线型访问
/srv :系统上运行的服务用到的数据
/tmp:临时文件存储位置
/usr:包含了系统用户工具和程序
/var:存放一些服务启动之后需要提取的数据
文件类型
-:普通文件
d:目录文件
b:块文件
c:字符设备
l: 符号链接文件
p:管道文件pipe
s: 套接字文件socker

用户组和权限管理

QQ截图20170720193106

/etc/passwd
查看:getent passwd [username]
username
密码位:x
pwconv (默认) 将密码映射到了/etc/shadow
pwunconv 将密码保存到/etc/passwd中,删除/etc/shadow文件
UID:
每个用户都有一个UID,UID为0时,说明是管理员帐户。
CentOS6 1-499为系统用户,预留
CentOS7 1-999为系统用户,预留
GID:
主要组:每个有且仅有一个主要组,当用户创建时,自动创建一个与用户同名的组作为主要组。
辅助组:用户可以有零个或多个辅助组。
描述位
chfn username 设置用户的描述
finger username (默认没有安装) 查看用户的信息
家目录
usermod -d /home/magedunew magedu
默认的登录Shell
usermod -s /sbin/nologin magedu
chsh -s /sbin/nologin magedu
/etc/shadow
查看:getent shadow [username]
username
密码位: sha512 sha256 md5  $id$salt$password
authconfig –passalgo=sha256 –update
!!用户被锁定
usermod -L 锁定用户
usermod -U 解锁用户 -p password
密码上一次的修改日期(从1970-1-1到修改的时间经过了多少天来表示)
密码最小存活期
密码最大存活期
密码过期之前提前多少天提醒用户(在正确登录时)
密码过期之后多少天帐户过期(在正确登录时)
帐户过期时间(自1970-1-1到该天经过了多少天来表示)
保留位
命令
whatis
   QQ截图20170715204348
cp
      -i 覆盖前提示
      -n 不覆盖
      -r -R 递归
      -d 复制软链接属性
      -p = –perserv=mode,owner,timestamp
      -a 包含-dr –perserv=all
      -f 当覆盖时,如目的文件的缺少写权限时,强制删除目的文件,并新建再填充内容。当有-n时,无效
mv
      -i 覆盖前提示
      -f 不提示,强制覆盖,抵消-i的作用
输入输出重定向
      0标准输入             <
      1标准输出             >

      2标准错误输出      2>

      标准输出及标准错误输出 > 2>&1 或&> 或&> /dev/null

      将错误输出转为正常输出 2>&1
      将正确输出转为错误输出 1>&2
      > 当文件不存在时创建,当文件存在时覆盖
      >> 当文件不存在时创建,当文件存在时追加
       防止覆盖
           set -C
             取消
           Set +C
            临时取消
                >| 
tr命令
           tr -s ” 多个中取一个
           tr -d ” 删除
           tr -t ” ” 转换时,前后参数对称
          tr -c ” 取反
| 管道符
          | 将正确结果重定向给下一条命令
          2>&1 | 或 |&  全部结果重定向
tee
          1 |tee -a 文件名 |命令2     将命令1 的输出保存并作为命令2的输入
                                         -a 追加,如不加-a,当文件已存在时,则覆盖
chage -l username 显示帐户的密码信息
           -d 指定密码的上次修改时间(yyyy-mm-dd)
           -d 0 则强制用户下次登录时必须修改密码
          -E 指定账户的过期时间
          -I 密码过期之后多少天帐户过期
          -m 设置最小存活时间
          -M 设置最大存活时间
          -W 设置密码过期前的提醒时间
chage username 交互式修改用户的密码策略
重点笔记
硬链接本质,一个文件,多个名字
软连接,快捷方式


课后作业

1、如何实现只显示指定目录下的隐藏文件

QQ截图20170719194909

2、只显示/etc下的非隐藏目录

QQ截图20170719200040

3、将当前系统登录用户的信息转换为大写后保存至/tmp/who.out文件中
     一个linux用户给root发邮件,要求邮件标题为”help”,邮件正文如下:
    Hello, I am 用户名,The system version is here,please help me to
    check it ,thanks!

   操作系统版本信息

QQ截图20170720161513

QQ截图20170720162246

4、将/root/下文件列表,显示成一行,并文件名之间用空格隔开

QQ截图20170720162635

5、计算1+2+3+..+99+100的总和

QQ截图20170720163248

6、处理字符串“xt.,l 1 jr#!$mn 2 c*/fe 3 uz 4”,只保留其中的数字和空格

QQ截图20170720164715

7、将文件中每个单词(由字母组成)显示在独立的一行,并无空行

QQ截图20170720172326

  QQ截图20170720171212


8、将指定文件中的0-9分别代替成a-j

 QQ截图20170720170633

9、将当前系统登录用户的信息转换为大写后保存至/tmp/who.out文件中

QQ截图20170720151746

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

(0)
jieranjieran
上一篇 2017-07-23
下一篇 2017-07-23

相关推荐

  • Linux系统分区管理

    管理分区     查看系统中的分区4种方式 [root@localhost ~]# ls /dev/sd* [来自内存] [root@localhost ~]# cat /proc/partitions [root@localhost ~]# lsblk /dev/sda  /dev/sda1  /dev/sda2  /dev/sda3 …

    Linux干货 2017-12-02
  • 权限

    用户组和管理权限

    2017-11-30
  • N22期-第五周博客作业

    1、显示当前系统上root、fedora或user1用户的默认shell; [root@localhost jimmy]# egrep '^(root|fedora|user1)\>' /etc/passwd | cut -d: -f7 /bin/bas…

    Linux干货 2016-09-10
  • 六.Linux博客-2016年8月2日用户、权限

    格式说明: 操作 概念 命令 说明及举例 六.用户、权限 创建用户、修改用户、删除用户 useradd 创建一个用户 useradd -r 创建系统用户,系统用户不创建家目录 useradd -D /etc/default/useradd 默认设置配置文件 newusers +文件 批量创…

    Linux干货 2016-08-24
  • 引导加载程序grub的使用详解

    引导加载程序grub的使用详解 为运行于虚拟机上的CentOS 6添加一个新硬件,提供两个主分区 为硬盘建两个主分区;并为其安装grub 为硬盘的第一个主分区提供内核和ramdisk文件;为第二个分区提供rootfs 为rootfs提供bash、ls、cat程序以及所依赖的库文件 为grub提供配置文件 将新的硬盘设置为第一启动项并能够正常启动目标主机 1.…

    Linux干货 2017-09-04
  • 第九周脚本练习

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; awk -F: ‘{if($NF!=”/sbin/nologin”) print $1}’ /etc/passwd | wc -l 2、写一个脚本 (1) 获取当前主机的主机名,保存于ho…

    Linux干货 2017-03-30