博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
文件 / I/O重定向 / 用户和用户组
阅读量:6709 次
发布时间:2019-06-25

本文共 8686 字,大约阅读时间需要 28 分钟。

文件管理

在Linux中有这么一条哲学思想

一切皆文件

在Linux中,所有在系统中存放的数据都会映射为文件。

文件系统与目录结构

文件系统

  • 文件和目录被组织成为一个倒树状
  • 从根目录开始,用“/”表示
  • 文件名称区分大小写
  • 隐藏文件用“ . ”表示
  • 路径分隔 “/”
  • 文件有两类数据
    元数据:metadata
    数据:data
  • 文件系统分层结构 : LSB (Linux Standard Base)
  • 文件存放位置推荐遵循 FHS 协议

文件名规则

  • 文件名最长255个字节
  • 包括路径在内文件名称最长4095个字节
  • 蓝色-->目录 绿色-->可执行文件 红色-->压缩文件 浅蓝色-->链接文
    件 灰色-->其他文件
  • 除了斜杠和NUL,所有字符都有效.但使用特殊字符的目录名和文件不推荐使用,
    有些字符需要用引号来引用它们
  • 标准Linux文件系统(如ext4),文件名称大小写敏感

文件系统结构

  • /boot:引导文件存放目录,内核文件(vmlinuz)、引导加载器(bootloader, grub)
    都存放于此目录
  • /bin:所有用户使用的基本命令;不能关联至独立分区,OS启动即会用到的程序
  • /sbin:管理类的基本命令;不能关联至独立分区,OS启动即会用到的程序
  • /lib:启动时程序依赖的基本共享库文件以及内核模块文件(/lib/modules)
  • /lib64:专用于x86_64系统上的辅助共享库文件存放位置
  • /etc:配置文件目录
  • /home/USERNAME:普通用户家目录
  • /root:管理员的家目录
  • /media:便携式移动设备挂载点
  • /mnt:临时文件系统挂载点
  • /dev:设备文件及特殊文件存储位置

    b: block device,随机访问

    c: character device,线性访问

  • /opt:第三方应用程序的安装位置
  • /srv:系统上运行的服务用到的数据
  • /tmp:临时文件存储位置

还有两个特殊的目录

  • /proc: 用于输出内核与进程信息县官的虚拟文件系统
  • /sys: 当前系统上的硬件设备相关信息虚拟文件系统

文件类型

  • - 普通文件
  • d 目录文件
  • b 块设备
  • c 字符设备
  • l 符号链接文件
  • p 管道文件pipe
  • s 套接字文件socket

绝对路径和相对路径

  • 绝对路径
    以正斜杠开始
    完整的文件的位置路径
    可用于任何想指定一个文件名的时候
  • 相对路径名
    不以斜线开始
    指定相对于当前工作目录或某目录的位置
    可以作为一个简短的形式指定一个文件名
  • 基名:basename
  • 目录名:dirnam

文件相关命令

cd 命令

切换用户当前工作目录

补充说明

cd命令 用来切换工作目录至dirname。 其中dirName表示法可为绝对路径或相对路径。若目录名称省略,则变换至使用者的home directory(也就是刚login时所在的目录)。另外,~也表示为home directory的意思,.则是表示目前所在的目录,..则表示目前目录位置的上一层目录。

语法

cd (选项) (参数)

选项

  • -p 如果要切换到的目标目录是一个符号连接,直接切换到符号连接指向的目标目录
  • -L 如果要切换的目标目录是一个符号的连接,直接切换到字符连接名代表的目录,而非符号连接所指向的目标目录。
  • - 当仅实用"-"一个选项时,当前工作目录将被切换到环境变量"OLDPWD"所表示的目录。

实例
cd 进入用户主目录;
cd ~ 进入用户主目录;
cd - 返回进入此目录之前所在的目录;
cd .. 返回上级目录(若当前目录为“/“,则执行完后还在“/";".."为上级目录的意思);
cd ../.. 返回上两级目录;
cd !$ 把上个命令的参数作为cd参数使用。

ls 命令

说明

显示指定工作目录下之内容(列出目前工作目录所含之档案及子目录)。

参数 :

  •   -a 显示所有档案及目录 (ls内定将档案名或目录名称开头为"."的视为隐藏档,不会列出)
  •   -l 除档案名称外,亦将档案型态、权限、拥有者、档案大小等资讯详细列出
  •   -r 将档案以相反次序显示(原定依英文字母次序)
  •   -t 将档案依建立时间之先后次序列出
  •   -A 同 -a ,但不列出 "." (目前目录) 及 ".." (父目录)
  •   -F 在列出的档案名称后加一符号;例如可执行档则加 "*", 目录则加 "/"
  •   -R 若目录下有档案,则以下之档案亦皆依序列出

      实例:

  • 列出目前工作目录下所有名称是 s 开头的档案,愈新的排愈后面 :
      ls -ltr s*
  • 将 /bin 目录以下所有目录及档案详细资料列出 :
      ls -lR /bin
  • 列出目前工作目录下所有档案及目录;目录于名称后加 "/", 可执行档于名称后加 "*" :
      ls -AF

    stat

  • 文件:metadata, data

三个时间戳:

access time 访问时间, atime 读取文件内容

modify time 修改时间, mtime,改变文件内容(数据)

change time 改变时间, ctime,元数据发生改变


文件通配符

  • *匹配零个或多个字符
  • ? 匹配任何单个字符
  • ~ 当前用户家目录
  • ~mage 用户mage家目录
  • ~+ 当前工作目录
  • ~- 前一个工作目录
  • [0-9] 匹配数字范围
  • [a-z]:字母
  • [A-Z]:字母
  • [wang] 匹配列表中的任何的一个字符
  • [^wang] 匹配列表中的所有字符以外的字符
  • [:digit:]:任意数字,相当于0-9
  • [:lower:]:任意小写字母
  • [:upper:]: 任意大写字母
  • [:alpha:]: 任意大小写字母
  • [:alnum:]:任意数字或字母
  • [:blank:]:水平空白字符
  • [:space:]:水平或垂直空白字符
  • [:punct:]:标点符号
  • [:print:]:可打印字符
  • [:cntrl:]:控制(非打印)字符
  • [:graph:]:图形字符
  • [:xdigit:]:十六进制字符

    mkdir和touch

mkdir 创建目录

补充说明

创建由dirname命名的目录。如果在目录名的前面没有加任何路径名,则在当前目录下创建由dirname指定的目录;如果给出了一个已经存在的路径,将会在该目录下创建一个指定的目录。在创建目录时,应保证新建的目录与它所在目录下的文件没有重名。

注意:在创建文件时,不要把所有的文件都存放在主目录中,可以创建子目录,通过它们来更有效地组织文件。最好采用前后一致的命名方式来区分文件和目录。例如,目录名可以以大写字母开头,这样,在目录列表中目录名就出现在前面。

语法

mkdir (选项)(参数)

选项

  • -Z:设置安全上下文,当使用SELinux时有效;
  • -m<目标属性>或--mode<目标属性>建立+ 目录的同时设置目录的权限;
  • -p或--parents 若所要建立目录的上层目录目前尚未建立,则会一并建立上层目录;
  • --version 显示版本信息。
    参数
    目录:指定要创建的目录列表,多个目录之间用空格隔开。

touch

格式:touch [OPTION]... FILE...

  • -a 仅改变 atime和ctime
  • -m 仅改变 mtime和ctime
  • -t [[CC]YY]MMDDhhmm[.ss] ,指定atime和mtime的时间戳
  • -c 如果文件不存在,则不予创建

cp 命令

复制文件或目录

cp [options] source destcp [options] source... directory

参数:

  • -a 保留所有权限 相当于- dR
  •  -r 若 source 中含有目录名,则将目录下之档案亦皆依序拷贝至目的地。
  •   -f 若目的地已经有相同档名的档案存在,则在复制前先予以删除再行复制。
  • -i 覆盖前提示
  • -n 不覆盖
  • -d 不复制源文件,只复制链接名
  • --backup=numbered 目标存在,覆盖前先备份加数字后缀

    mv

mv [OPTION]... [-T] SOURCE DEST

mv [OPTION]... SOURCE... DIRECTORY

mv [OPTION]... -t DIRECTORY SOURCE...

常用选项:     -i   交互式    -f   强制    -b  目标存在,覆盖前先备份

rm 删除

rm [OPTION]... FILE...

常用选项:

  • -i 交互式
  • -f 强制删除
  • -r 递归
  • --no-preserve-root 删除/
    示例:

    rm -rf /* (危险命令,切勿在生产环境中尝试,Enter前请三思 )


I/O重定向及管道

输入输出重定向及管道程序: 指令+数据    读入数据: Input    输出数据: Output打开的文件都有一个fd; file descriptor (文件描述符)标准输入:keyborad(键盘)  0标准输出:monitor(显示器) 1标准错误输出:monitor       2

I/O重定向:改变标准位置

输出重定向: COMMAND > NEM_POS, COMMAND >> NEM_POS    > 覆盖重定向,目标文件中的原有内容会被清除    >> 追加重定向,新内容会追加至目标文件尾部    # set -C : 禁止将内容覆盖输出至已有文件中        强制覆盖: >|    # set +C: 允许覆盖    2>:覆盖重定向错误输出数据流    2>>追加从定向错误输出数据流    标准输出和错误输出各自定向至不同位置        COMMAND > /PATH/TO/file.out 2> /path/ro/error.out    合并标准输出和错误输出至同一个数据流进行从定向        &> 覆盖重定向        &>> 追加重定向        COMMAND > /PATH/TO/file.out 2> &1        COMMAND >> /PATH/TO/file.out 2>> &1输入重定向: <    tr命令:转换或删除字符        tr [OPTION]... SET1 [SET2]            -d 删除指定字符串    HERE Documentation : <<  (此处生成文档)     Note:单行重定向 与 多行重定向        #cat << EOF        #cat >/path/ro/somefile <

管道:

COMMAND | COMMAND | COMMAND | ...

Note:最后一个命令会在当前shell进程的子shell中执行的tee命令:一路输入两路输出    tee [option]... [file]....    -a 追加

文件处理工具 wc cut sort uniq

wc [option] [file]...    -l: 统计行数    -c: 统计字节数    -w;统计单词数tr: 转换字符或删除字符    tr '集合1' '集合2'    tr -d '字符集合'    tr -dc '字符合集' 除了双引号内的,都删除    \n 换行    \r 回车    \t tab键    \v 纵向tab键cut:     This is a test line.    -d字符:指定分隔符    -f#: 指定要显示字段        单个数字:一个字段        逗号分隔的多个数字:指定多个离散字段        -:连续字段,如3-5;sort: 按字符进行比较    sort [option] file...        -f: 忽略字符大小写;        -n: 比较数值大小;        -t: 指定分隔符        -k: 指定分隔后进行比较字段        -u: 重复的行,只显示一次;uniq: 移除重复的行    -c:显示每行重复的次数    -d:仅显示重复过的行    -u: 仅显示不曾重复的行

总结:

1、   小技巧:    可以使用>>创建空文件,相对于来说,比较安全,防止文件存在覆盖数据,造成数据丢失    set  仅在当前shell 有效    单行从定向:  cat > file    多行重定向:cat <<    ls /erro /boot 2> file.out 2> erro.out        相当于将错误的重定向如file.out中,正确的重定向至erro.out    ls /error /boot > /file.out 2>&1         不管正确还是错误都重定向至file.out    ls /error /boot 2>&1 > file.out中    将错误输出显示至屏幕,正确的重定向至fele.out    (ls /error /boot 2>&1 ) > file.out 正确和错误都重定向    ls /error /boot 2> file.out 1>&2    先将错误的重定向至file.out中,然后把正确的当做错误的重定向至同一个文件中    # 以下四个命令中哪个是结果不一样    1    2    3    42、    tr '[:lower:]' [:upper:]  把所有小写字母转换为大写字母    ls [:lower:]* 代表 以l,o,w,e,r 其中任意一个字符开头的行    ls [[:lower:]]* 代表  所有以字母开头的行

用户组管理

资源分派

Authentication 认证Authorizathin  授权 Accouting   审计token,identity(username/passwd)linxu用户: Username/UID管理员: root, 0普通用户:1-65536(60000)    系统用户 1-499 (centos6) 1-999(centos7)        守护进程获取资源进行权限分配    普通用户 500+

Linux的安全上下文:

运行中的程序,进程(process)

以进程发起者的身份运行:    #root:cat     $tom:cat 进程所能够访问的所有资源的权限取决于程序运行的发起者的身份

Linux组的类别

用户的基本组(主组):    组名同用户组,且包含一个用户,私有组用户的附加组(额外组):

Linux用户和组相关配置文件

  • /etc/passwd保存用户及其属性信息
  • /etc/group 组及其属性信息
  • /etc/shadow 用户密码及其相关属性
  • /etc/gshadow 组密码及其相关属性

/etc/passwd

name:passwd:UID:GID:GECOS:directory:shell用户名:密码:UID:GID:GECOS:主目录:默认shell:

/etc/group

group_name:password:GID:user_list组名:密码:组ID:用户列表(分隔符为逗号)

/etc/shadow

用户名:加密了的密码:最近一次更改密码的日期:密码的最小使用期限:密码的最大使用期限:账号警告时间段:密码禁用期:密码过期日期:保留字段

加密机制:        加密 明文-->密文        解密 密文-->明文        单向加密:提取数据指纹            md5: message digest,128bits            sha1: secure hash algorithm,160bits            sha224:224bits            sha256:256bits            sha384:384bits            sha512:512bits            雪崩效应:初始的条件的微小改变,将会引起结果的巨大改变            定长输出:    密码的复杂性策略;    1、使用数字,大写字母,小写字母及特殊字符中至少3中    2、足够长:    3、使用随机密码:    4、定期更换:不要使用最近曾经使用过的密码

用户和组相关命令

用户创建: useradd

SYNOPSIS           useradd [options] LOGIN           useradd -D           useradd -D [options]    OPTION:          -u UID: [UID_MIN,UID_MAX] 定义在/etc/login.defs    -g GID: 指明用户所属基本组,可为组名,也可以GID    -c "comment" :用户注释信息 (等价于 chfn username)    -d /path/tohome_dir: 以指定的路径为家目录    -s SHELL : 指明用户的默认shell程序,可用列表在/etc/shells文件中 (等同 chsh -s )    -G GROUP1[GROUP2,...[,GROUPN]]:为用户指明附加组,组必须事先存在        -n  不为用户创建私有用户组        -M : 不创建主目录        -e date :指定账户过期时间,格式为:MM/DD/YY        -f days : 帐号过期几日后永久停权。若指定为 -,则立即被停权,若为 -   1,则关闭此功能        -r : 创建系统用户,默认不创建对应的主目录        -p passwd : 为新建用户创建指定登录密码。(此项使用较少)        默认值设定: /etc/default/useradd文件中            useradd -D  \\ 修改默认值

修改用户属性:usermod

SYNOPSIS       usermod [options] LOGINOPTION:    -a: 将用户添加到补充组。仅与-G选项一起使用    -c
<备注>
:修改用户帐号的备注文字; -d
<登入目录>
:修改用户登入时的目录; -e
<有效期限>
:修改帐号的有效期限; -f
<缓冲天数>
:修改在密码过期后多少天即关闭该帐号; -g
<群组>
:修改用户所属的群组; -G
<群组>
;修改用户所属的附加群组; -l
<帐号名称>
:修改用户帐号名称; -L:锁定用户密码,使密码无效; -s
:修改用户登入后所使用的shell; -u
:修改用户ID; -r : 同时删除家目录

创建用户组: groupadd

Groupadd  [-r]  groupname    Option:        -r:创建系统用户组,该类用户组的GID小于500或1000。

修改用户组属性: groupmod

groupmod [options] GROUP    Option       -n : 改变用户组名称     groupmod -n 新用户组名  原用户组名    -g:重新设置用户组GID   groupmod -g new_GID 用户组名称

删除用户组: groupdel

注意:在删除用户组时,被删除的用户组不能某个用户的私有用户组,若要删除,则应先删除私有用户组的账户,然后再删除用户组添加用户到指定组/从指定组移除用户: gpasswd    用法:        gpasswd  -a username group 将指定用户添加到指定组        gpasswd  -d username group 从用户组中移除指定用户设置用户组管理员    gpasswd -A 用户账户 要管理的用户组               命令功能:将指定的用户设置为指定用户组的用户管理员。用户管理员只能对授权的用户组进行用户管理 (添加用户到组或从组中删除用户),无权对其他用户组进行管理。设置账户登录密码: passwd    passwd [用户]    也可以通过标准输出来设置密码        echo "字符串" | passwd --stdin  username                                                                                                                                                    ------------不敢原创,总结了一些笔记

转载于:https://blog.51cto.com/14116879/2368166

你可能感兴趣的文章
如何快速带领实习生进入角色
查看>>
uvm_factory——我们的工厂(一)
查看>>
检测项目
查看>>
STL之vector
查看>>
【模板】Hash拉链法
查看>>
SQL系列(三)—— 注释(comment)
查看>>
C语言中 fputs() fgets() 的使用方法
查看>>
Bzoj3697 采药人的路径
查看>>
一步一步学Remoting之二:激活模式
查看>>
Python集合
查看>>
Deep learning:四十二(Denoise Autoencoder简单理解)
查看>>
Copley-STM32串口+CANopen实现双电机力矩同步
查看>>
关于localstorage的本地缓存以及封装
查看>>
在找一份相对完整的Webpack项目配置指南么?这里有
查看>>
微信小程序 - 入门指引
查看>>
hdu 1002
查看>>
动态规划总结
查看>>
Java垃圾回收基础
查看>>
Django 中CSRF中间件 'django.middleware.csrf.CsrfViewMiddleware',
查看>>
Kali Linux 1.0
查看>>