文件内容查询

直接查询文件内容

查阅一个文件的内容可以使用指令cat/tac/nl。

# [cat|tac|nl] 文件

区别:

1.cat是直接把文件内容输出到屏幕上,并且从第一行开始输出到末行

2.tal和cat相同,只不过tal是从末行反过来开始输出到第一行

3.nl则是可以添加行号打印,第一行可以显示1/01/001...

可翻页查询

more

空格键 :翻下一页

enter : 翻下一行

/字符串 :向下查找该字符串

:f :显示出文件名和目前显示行数

q :离开

b : 往回翻页

less

空格键|[pagedown] :翻下一页

[pageup]: 翻上一页

/字符串 :向下查找该字符串

?字符串 :向上查找该字符串

q :离开

g : 跳转到第一行

G : 跳转到末行

文件截取

当文件过大,内容过多时,我们可以抽取其中某几行来查看。

head(取出前面几行)

# head [-n number] 文件

-n : 代表的从头开始显示几行。所以number我们写的是数字,如果要显示前面5行,那么就是

head -n 5 file

tail(取出后面几行)

tail [-n number] 文件

number和上述一样。

但是如果只查看第11-20行呢?我们就可以先取前20行,然后再取后面十行。那么就要用到管道啦。复习一下,管道的线是这个符号 " | ",简称管线。(瞎扯╭(╯^╰)╮)

head -n 20 文件 | tail -n 20

##非纯文本档 od
如果我们需要查看非文本的文件,例如如何查看/usr/bin/passwd这个执行文件内容时。由于执行文件通常是binary file(二进制文件),如果我们使用上面的那些命令查看,就会出现乱码的情况。而查看这些文件我们可以使用od这个指令。
```
od [-t TYPE] 文件
TYPE:
a:使用默认的字符来输出
c:使用ASCII字符来输出
d[size]: (decimal)使用十进制来输出,每个整数占用 size bytes;
f[size]: (floating)使用浮点数来输出,每个整数占用 size bytes;
o[size]: (octal)使用八进制来输出,每个整数占用 size bytes;
x[size]: (hexadecimal)使用十六进制来输出,每个整数占用 size bytes;
```


#文件默认权限和隐藏权限
##文件预设权限: umask
当我们建立文件或者目录时,那么他的权限是多少呢?这个就要使用umask这个指令了,使用方式如下:
```
#umask //查看当前默认的权限值
0002
```


## 文件隐藏属性
**chattr(配置文件隐藏属性)**
除了rwx的那9个权限外,还有隐藏属性(真是难受),该指令只在Ext2/Ext3/Ext4 的Linux文件系统生效,其他的文件系统可能无法完全支持该指令(现在都9102年了,不知道完全支持不呢...)
```
# chattr [+-=] [options] 文件或目录
选项:
+ : 增加某一个参数
- : 移除某一个参数
= : 重新设置参数。

参数(options)

a : 该文件只能增加数据,不能删除数据,也不能修改数据,只有root用户能设定该参数。

i : 该文件不能删除、改名、设定连结,还无法写入或新增数据!只有root用户能设定该参数。

...

eg:

sudo chattr +a file1 //把file1文件设置隐藏属性i

rm -f test

rm: cannot remove 'test': Operation not permitted //提示不能执行该操作哦,因为设置了隐藏属性i,是不能删除该文件的。

<br>
**lsattr(显示文件隐藏属性)**
使用chattr设置了隐藏属性后,就可以使用lsattr查看啦

lsattr [-adR] 文件或目录

a : 查看隐藏文件属性

d : 如果是目录,仅列出目录本身的属性、而非目录内的文件属性

R : 连同子目录也一并列出

<br>
## 文件特殊权限: SUID,SGID,SBIT
其实除了rwx的文件权限外,还有特殊权限s和t,s和t的作用分别放到第十三章和第十六章说明(按照我这个写博客的进度不知道要等到猴年马月,有想了解的童靴就去搜搜)。
<br>
### Set UID
当s这个标志出现在文件拥有者的x权限上时,例如 [-rwsr-xr-x],此时就被称为Set UID,简称SUID特殊权限,SUID的特殊功能如下:
> SUID权限仅对二进制程序有效
> 执行者对改程序需要具有x的执行权限
> 本权限仅在执行该程序的过程中有效
> 执行者将具有该程序拥有者的权限 ### Set GID
当s标志在所属组的x标志上,例如 [-rwx--s--x],此时成为Set GID,简称SGID。对于文件有以下功能:
> SGID对二进制程序有用
> 执行者需要具备相应的x权限
> 执行该程序的用户则会获得该程序群组的支持 对于目录有以下功能
> 用户若对目录有r和x权限,则能进入该目录
> 用户在此目录下的有效群组将会变成该目录的群组(有效群组是用户创建文件的时候,文件默认所属的群组)
> 用途:若用户具有w权限,则用户所建立的新文件的群组则与该目录的群组相同。 ### Sticky Bit
简称SBIT,只对目录有效:
> 用户对于此目录具有w,x权限
> 用户在此目录下建立文件,只有自己和root用户有权限删除文件。 SUID/SGID/SBIT 权限设定
> 4 为 SUID
> 2 为 SGID
> 1 为 SBIT 第五章讲过了修改权限的命令,至于添加特殊权限则如下操作:

chmod 4755 filename //这里的4为SUID的特殊权限 后面的755就和以前的一样

<br>
### 观察文件类型:file
如果需要知道某个文件是属于什么类型,例如是属于ASCII、binary还是其它的文件。就是用这个类型

$ file test_file

test_file: ASCII text //返回ASCII 的纯文本文件

<br>
# 指令与文件的搜索
## 指令查询 which

$ which [-a] command

-a : 将所有PATH目录中可以知道的指令列出

例如:

$ which service

/usr/sbin/service

<br>
## 文件名查询 find

格式: find [PATH] [option]

$ find /home mtime 0 //查看home目录下24小时之内被修改的文件

$ find /home -user vagrant //查询home目录下用户为vagrant的目录或文件

/home/vagrant

/home/vagrant/.cache

...

$ find /home -name test_file //查询home目录下名为test_file的文件

/home/vagrant/test_file


#结语
> 看了鸟哥的Linux的第六章后,我差不多把文章讲到的命令有写上了,不过比较详细的东西可能并没有在文章这里写到,而且我个人觉得写这篇文章消耗我比较长的时间,
> 最大的原因是不管什么命令都写上去,反正书里说到的就写。后面越写我就越发现,文章不能照搬书里的内容,应该把比较常用的内容写到上面才比较合适。
> 不然的话还不如看我文章的小伙伴看书去比较好,所以我往后的文章可能会尽可能的写现实当中比较常用的东西(我自己觉得常用的东西,可能不是真的常用)。
> 好了,文章毕竟写得多才会有积累,写得会更快,但是更快的情况下我会尽可能的保证内容的正确性。
> 文章若有不足之处,请在评论区留言指出或邮件发送到15915126689@163.com,谢谢大家。

鸟哥的Linux私房菜笔记第六章(二)的更多相关文章

  1. 鸟哥的Linux私房菜笔记第六章(一)

    目录与路径 相对路径与绝对路径 上一章简单的提到绝对路径和相对路径 绝对路径:路径的写法一定是由根目录(/)写起的,例如:/home/user 这个目录 相对路径:路径的写法不是由根目录(/)写起,例 ...

  2. 鸟哥的Linux私房菜笔记第四章

    前言 对着<鸟哥的Linux私房菜-基础版>做了简化笔记.不想让自己知其然而不知其所然.所以写个博客让自己好好巩固一下,当然不可能把书中的内容全部写下来.在这里就简化一点把命令写下来. 让 ...

  3. 鸟哥的Linux私房菜笔记第五章,文件权限与目录配置(二)

    Linux目录配置的依据--FHS 因为利用Linux来开发产品的公司太多,例如,CentOS.Ubuntu.ReHat...,导致了配置文件存放的目录没有统一的标准.后来就有了FHS(Filesys ...

  4. 鸟哥的linux私房菜——第十六章学习(程序管理与 SELinux 初探)

    第十六章.程序管理与 SE Linux 初探 在 Linux 系统当中:"触发任何一个事件时,系统都会将他定义成为一个程序,并且给予这个程序一个 ID ,称为 PID,同时依据启发这个程序的 ...

  5. 鸟哥的Linux私房菜——第十六章:学习Shell Scripts

    视频链接:http://www.bilibili.com/video/av10565321/ 1. 什么是 Shell Script       (shell写的脚本)1.1 干嘛学习 shell s ...

  6. 鸟哥的 Linux 私房菜Shell Scripts篇(二)

    参考: http://linux.vbird.org/linux_basic/0340bashshell-scripts.php#script_be http://www.runoob.com/lin ...

  7. 学习鸟哥的Linux私房菜笔记(1)——Linux系统入门

    今天在阿里云申请了一个centos系统的云服务器,以前对linux了解的只是皮毛,记了几个命令还给忘了,整了半天都弄不好,作为一个做过javaweb开发的coder实在是惭愧啊,决定从今天开始学习Li ...

  8. [置顶] 学习鸟哥的Linux私房菜笔记(6)——过滤器、输入输出及管道

    一.过滤器 Linux中的应用工具分为三种: 交互工具 过滤器 编辑器 能够接受数据,过滤再输出的工具,称之为过滤器 对过滤器和进程,存在着输入源与输出对象 二.输入.输出.重定向 输入:过滤器的数据 ...

  9. 学习鸟哥的Linux私房菜笔记(17)——Linux引导流程

    一.系统引导流程 第一步:固件fireware(CMOS/BIOS)--POST加点自检(与操作系统无关) 这一步主要是检查硬盘等硬件是否能正常工作 CMOS:是固化在主板上,详细:http://sc ...

随机推荐

  1. Delphi url 编码及转码及特殊字符串替换--百度和腾讯用的就是这个

    先介绍一下,Delphi中处理Google的URL编码解码,其中就会明白URL编码转换的方法的 从delphi的角度看Google(谷歌)URL编码解码方式 在网上搜索了一下,似乎没有什么关于goog ...

  2. Qt的QWaitCondition(允许线程在一定条件下唤醒其他线程,这样对不间断上传可能比较适用)

    对生产者和消费者问题的另一个解决办法是使用QWaitCondition,它允许线程在一定条件下唤醒其他线程.其中wakeOne()函数在条件满足时随机唤醒一个等待线程,而wakeAll()函数则在条件 ...

  3. 【原创】ABAP根据文件路径获取文件所在目录(续)

    在上一篇文章<ABAP根据文件路径获取文件所在目录>中,我主要的思路是采用 “SPLIT dobj AT sep INTO TABLE result_tab” 句型将文件全路径按分隔符“\ ...

  4. SpringBoot整合Redis注意的一些问题

    1:ERR value is not an integer or out of range 1-1:背景 使用redisTemplate.opsForValue().increment(key, de ...

  5. Laravel --- 查询字段中使用表达式

    比如: select id, name, count(post) from ... 在laravel中: $user = $this ->select( 'id', 'name', DB::ra ...

  6. Spring Bean的3种装配方式

    Bean常用的装配方式有3种: 基于xml的装配 基于Annotation(注解)的装配 基于Java类的装配 基于xml的装配 在xml文件中配置Bean. 如果依赖很多,xml配置文件会很臃肿,后 ...

  7. 【React】react学习笔记03-React组件对象的三大属性-state

    今天晚上学习了React中state的使用,特做此记录,对于学习的方式,博主仍然推荐直接复制完整代码,对着注释观察现象!: 上文中,我列举了两种React自定义组件的声明,这里我拿方式二进行举例: / ...

  8. ComboBox过滤

    在View层完成数据筛选,无需改变ViewModel层的数据,这样就不必担心在其它地方的使用了. 从路由事件 TextBoxBase.TextChanged 中获取输入的文本,并设置视图的过滤器就可以 ...

  9. 基于Dapper的开源Lambda扩展LnskyDB 2.0已支持多表查询

    LnskyDB LnskyDB是基于Dapper的Lambda扩展,支持按时间分库分表,也可以自定义分库分表方法.而且可以T4生成实体类免去手写实体类的烦恼. 文档地址: https://lining ...

  10. Qt实现炫酷启动图-动态进度条

    目录 一.简述 二.动效进度条 1.光效进度条 2.延迟到达进度条 3.接口说明 三.启动图 1.实现思路 2.背景图切换 四.测试 1.构造启动图 2.背景图 3.其他信息 4.事件循环 五.源码 ...