目录操作类,文件操作类,文本处理

一、shell如何处理命令

  • 1.shell会根据在命令中出现的空格字符,将命令划分为多个部分
  • 2.判断第一个字段是内部命令还是外部命令
内部命令:内置于shell的命令(shell builtin)
外部命令:通过安装其他应用程序或服务而安装来的命令

路径:为了查找或定位某个文件所必需经过的目录的层次结构
相对路径:从工作目录开始查找的路径
. 当前的工作目录
.. 当前的工作目录的父目录
根的父目录还是根
绝对路径:从根(/)开始查找的路径

变量:内存空间
变量值:存放在内存空间中的数据
空变量:NULL
环境变量PATH(路径),绝对路径:PATH=PATH1:PATH2:PATH3:...
  • 3.判断其他的字段是选项还是参数,判断正确与否,如果正确就执行,如果错误就返回错误信息
  • 4.在命令书写过程中按回车键将书写的内容提交给shell执行
  • 5.如果想要在提交shell之前取消命令就用ctrl+C

 

二、文件查看,操作

帮助类
man,help,info,whereis,which,whatis
目录操作类
ls,pwd,cd,mkdir,rmdir
文件操作类
nano,touch,rm,cp,mv,stat
文件查看类
cat,tac,head,tail,less,more
文本处理
cut,sort,uniq,tr,sed,awk

1、查看

  • ls–>list
列表显示目录的内容
用法:

ls [OPTION]... [FILE]...
[]:可选的内容
{}:必选的内容
|:多选一

默认的参数就是工作目录

选项:

-l: 长格式输出
-rw-------. 1 root root 1211 May 11 06:03 anaconda-ks.cfg

第一位表示文件的类型:
-:表示普通文件(f,file)
b:表示块设备文件(block)
c:字符设备文件(charact)
d:目录文件
l:符号链接文件(symbol link)
p:管道文件(pipe)
s:套接字文件(socket)
第二到第十位:文件的权限位,三组权限位,每组包括三个权限字符,rwx,读写执行。若没有权限就使用-代替
第二段的数字1:表示文件被硬链接的次数
第三段:文件的所有者,root
第四段:文件见的所属组,root
第五段:文件的大小,默认以byte为单位进行显示
第六段:时间戳(访问时间,修改时间,改变时间)
访问时间:access timestamp
修改时间:modified timestamp(改的是数据内容,对数据的内容进行编辑,叫修改)    
改变时间:change timestamp(metadata,元数据,对元数据的编辑叫改变)
第七段:文件名
在linux中,以.字符作为文件名第一个字符的文件,就是隐藏文件

-a: 显示所有文件,包括隐藏文件

-A: 显示所有文件,包括隐藏文件,但不包括.和..

-h: 以人类方便读的方式显示

-d: 以文件夹的属性代替内部子文件的属性输出

-r: 倒序显示

-R: 递归显示(recursive)

-Z: 显示文件安全上下文

 

  • cat 
查看文件
-n:给所有行编号 -b: 不对空白行编号
tac cat的倒序显示

 

  • head
从头开始查看,默认前十行 
head -n 3 :查看前三行 还可以直接写成 head -3
head -c 50:查看50字节
head -c 1b:查看一个扇区512字节的内容

 

  • tail
从结尾开始查看。选项类比head
-f :实时监控的文件末尾的内容变化

 

  • more
分页显示文件内容 只能往后看

 

  • less
  • whereis
显示命令的二进制文件,帮助手册路径

 

  • which
查看文件在哪,只显示二进制文件路径

 

  • whatis
只显示帮助手册路径

 

  • stat
查看文件属性(访问时间,修改时间,改变时间)

 

  

 

2、目录操作

  • pwd

显示工作目录(绝对路径)默认的工作目录是/root,root用户的家(宿主目录),默认用户登录的第一个目录就是宿主目录

 

  • cd

切换工作目录
如果没有参数,那么默认的参数是用户的宿主目录
cd ~ :切换到宿主目录
cd – :切换到上一次使用的工作目录

 

  • mkdir

创建目录

mkdir [OPTION]... DIRECTORY...
选项: -p :在创建子目录之前,先创建父母录
-v :显示创建文件夹详细的过程
命令展开功能,使用{},中间用逗号分隔

 

  • rmdir

删除目录(只能删除空目录)若一个目录只有.和..,那么就认为这个目录为空
rmdir [OPTION]… DIRECTORY…

 

  • rm

移除

rm [OPTION]... FILE...
选项:-r:可以删除目录
-f:强制删除

 

  • type

区分命令为内部命令还是外部命令

获得帮助
内部命令:help 内部命令
外部命令:
man 外部命令 
info
--help

 

3、文件编辑

 

  • echo

-n:不输出换行符号
-e:使得反斜杠生效

  • nano
文本编辑工具,增强版的pico
^:脱字符
1.一般在编辑模式中相当于ctrl键
2.在其他的用途中,有不同的意义,如:可以取反,可以表示行首
默认有换行符,一个换行符相当于一个字节
ctrl+o保存
ctrl+x退出

 

  • touch

改变文件的时间戳。当文件不存在时,会创建文件
-a:只修改文件的访问时间
-m:只修改文件的修改时间
-c:不创建文件

 

4、时间命令

  • clock

硬件时间

  • date

系统时间

设置时间:
1.date 月日时分年.秒
date 091703282015
Thu Sep 17 03:28:00 CST 2015
2.date -s ”年/月/日 时:分:秒”
date -s "2015/09/17 15:32:11"
Thu Sep 17 15:32:11 CST 2015
3.date +%Y

 

  • hwclock
RTC:实时时钟
-s 把硬件时间同步到系统时间
-w 把系统时间同步到硬件时间

touch的时间默认来源于系统时间

 

  • bc  计算器
  • cal:日历

 

5、文本处理

  • cut
remove sections from each line of files
-d 指明分隔符号,默认空格
-f 指明操作区域 -f 1 第一列
eg:cut -d : -f 1 /etc/passwd
cut -d : -f 7 /etc/passwd | sort | uniq -c

 

  • sort
sort lines of text files 排序,默认顺序ASCII编码
-n : 按数字大小排列,从小到大
-r : 倒序
-t : 指明分隔符号
-k : 指明操作区域
-u : 如果存在多个重复的内容则显示为一行,相当于uniq命令

sort -n -t : -k 3 /etc/passwd

 

  • uniq
类似于 sort -u
-c :统计连续的重复行的数量
-u :只输出唯一的行,(不连续重复出现的)

 

  • tr
字符集转换
tr \'ab\' \'AB\' < /etc/passwd 对位替换

 

  • wc
字计数器
wc - print newline, word, and byte counts for each file
-l 只显示行数
-w 只显示字数
-c 只显示字符数
wc /etc/passwd
30 54 1427 /etc/passwd

 

三、文件类型介绍

  • 通过颜色来区分文件类型

黑色或白色:普通文件
黄色:设备文件
深蓝色:目录文件
浅蓝色:符号链接
棕色:管道
紫色:套接字文件
红色:软件包,压缩包
绿色:可执行文件FI

file命令 查看文件类型

FHS:文件系统层级标准

 

/:根目录
/bin:通常存放普通的命令,这些命令可以被所有用户执行,二进制文件
/sbin:超级用户的bin,通常存放管理类命令,只有root才可以执行
/boot:存放着跟系统启动有关的文件,引导系统的程序,内核,ramfs镜像
/dev:存放设备文件目录

每个设备文件都有俩个设备号:主设备号,次设备号
主设备号:当前设备所使用的驱动程序的数字编号,MAJOR
次设备号:使用相同驱动程序的不同设备编号,MINO

设备文件又分为两类:
块设备文件:用于进行数据的存储和交换的设备,随机访问,比如:硬盘,光驱,内存
字符设备文件:用于进行数据的传输和处理的设备,线性访问,比如:网卡,总线,键盘

/etc:配置文件
/home:所有普通用户的家目录的根目录,每个用户的家目录名称都默认与用户名相同,
但是此目录不包括root用户的家目录
/root:root用户的家目录,宿主目录
/lib:库文件存放目录
/lib/modules:内核专用的库

库文件分为两类:
静态库:.a
动态库:.so 
内核专用库:.ko

ldd 查看命令用了哪些库

 

/media:挂载点,常用块文件的默认挂载点,光驱、硬盘、软驱等设备的默认挂载点
/mnt:挂载点,常用的其他外部设备的自定义挂载点
挂载点:用来链接或者存放分区的文件夹
/proc:伪文件系统,内存信息中的映射
/sys:伪文件系统,将/proc里面的有关硬件设备的信息进行映射
/tmp:临时文件夹,缓存数据的存放地
/var:可变化的文件,如:日志、文件锁等
/usr:通用共享资源,第三方软件的安装目录
/usr/bin
/usr/sbin
/usr/etc
上述目录一般是安装二进制软件包时候使用的

/usr/local/etc/
/usr/local/bin
/usr/local/sbin
上述目录一般是编译源代码安装软件包时候使用的

 

四、文件权限

  • DAC:自主访问控制

                 文件             目录    
r:读 获得文件的内容          查看目录中的文件
w:写 编辑文件的内容          创建,修改删除文件名
x:执行 将文件当作命令执行     可以进入,引用目录,查看详细信息

rwxrwxrwx
第一段:所有者权限
第二段:所有组权限
第三段:其他人权限
  • chmod 修改指定文件的权限位值

chmod 权限位值 文件名
权限位值有两种表示方式:
符号标识:
权限位标识:
u:表示所有者
g:所属组
o:其他人
a:u+g+o
赋值标识:
+:在原有的权限基础上添加新的权限
-:在原有的权限基础上删除权限
=:不管原有的权限如何,直接设定新的权限
权限标识:
r w x 
举例:
chmod u+x textfile 在原有的权限基础上给所有者添加执行的权限
chmod g+x,o+x textfile
chmod a+x textfile 可以写成 chmod +x textfile

数字标识:
r:100 4
w: 010 2
x: 001 1
r-x:5

chmod 500 testfile

若使用符号标识法,可以针对某个权限位单独设置
使用数字标识法,必须完整的写出三个权限位的权限值

 

  • umask 权限遮罩码 002 022

创建新的目录,目录的默认权限 777-umask
创建新的文件,文件的默认权限 666-umask
注意:
文件的最高权限为666,目录的最高权限是777
权限不能使用数字进行换算,必须使用字母;
umask定义的权限是系统默认权限准备丢弃的权限
Umask的来源    
cat /etc/bashrc    
f [ $UID -gt 199 ] && [ "`id -gn`" = "`id -un`" ]; then
    umask 002
else
    umask 022
fi

 

  • chown 改变文件的所有者和所属组

-R 递归修改目录的所有权以及目录中子文件、子目录的所有权
chown USERNAME FILE 只修改文件的所有者
chown :GROUPNAME FILE 只修改文件的所属组
chown USERNAME: FILE 同时修改文件的所有者和所属组,所属组就是用户的主要组
chown USERNAME:GROUPNAME FILE 修改文件的所有者和所属组,所有者是USERNAME,所属组是GROUPNAME
  • chgrp 改变文件的所属组

  • facl 文件系统访问控制列表,对于权限的扩展属性的设定

  • getfacl 查看文件的扩展属性列表
    setfacl 设置文件的扩展属性列表

-m:修改
setfacl -m u:UID或用户名:权限 FILE
setfacl -m g:GID:权限 FILE
-x:撤销修改
setfacl -x u:UID FILE
setfacl -x g:GID FILE

 

特殊权限
    SUID:超级用户权限    s或S  (出现在所有者的执行权限位置)    4     
    SGID:超级组权限     s或S  (出现在所属组的执行权限位置)    2
    Sticky:粘滞位       t或T (出现在其他人的执行权限位置)   1
    如果在设置特殊权限位之前,文件具有执行权限,那么特殊权限就是小写字母,反之大写字母
    
                             文件                                       目录
                            
    SUID    在执行一个具有SUID命令时,执行者会                        没有意义
            以该命令的所有者身份来执行
    SGID    在执行一个具有SGID命令时,执行者会                具有这样权限的目录,在其中
            以该命令的所属组身份来执行(几乎不用)            建立的所有文件,所属组自动继承目录的所属组
    Sticky                 没有意义                           如果用户对于一个有sticky权限的目录有写权限,用户只能修改
                                                              那些所有者为自己的文件
    
    

 

补充:

  • ln:创建链接文件,默认创建硬链接

链接文件的类型:
硬链接:
一个文件的多个文件名
软连接(符号链接):快捷方式(访问路径) 
-s:创建符号链接
-v:显示链接创建过程
注意:创建链接时,最好写绝对路径

 

版权声明:本文为smallmars原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/smallmars/p/8436556.html