本篇文章主要讲解 重定向 伪造大文件 查日志 管道多级连接 时间指令时间戳 find grep zip压缩指令。证明,Linux皆文件:终端是文件。
目录
3.再次查看系统中的终端文件 与没有新打开终端时对比,我们发现,
01. more (可以打满一屏输出,就停下来,让用户下翻,逐行阅读)(不推荐使用)
02. less指令(重要)(用来查看大文本(日志),有高亮,且可以上下翻阅)
一、铺垫内容
我们先学一个shell命令用于接下来的指令讲解
01. ">" (输出重定向)--类似c语言中文件内容
echo语法:echo " 内容 " [>,>>][文件]
举例:
如图:
终端即是文件,终端文件。echo将内容输入到终端文件中。
从这张图中所运行的指令可知:当我们将我喜欢上学通过“>”输入到 log.txt 文件中时,并创建了 log.txt 文件,log.txt 中的内容就是我们输入的内容,本来该显示到显示器上的数据,显示到文件中,这(>)就是输出重定向。每次进行重定向,都会从文件的开始,写入内容。当我们输入第二条内容到 log.txt 中,log.txt中只有"你好Linux",而"我喜欢上学"没有了,这类似于c语言文件中,文件用“w”。
如图:
我们输入了一个空格到 log.txt 中,于是,log.txt中的内容就是空格,相当于清空了文件,我们再使用 ">log.txt",显示文件内容时直接跳过,说明,文件已经是一个真正的空文件(无空格)。好的现在我们将log.txt删除。
如图:
我们发现,直接使用>log.txt, 也可以将log.txt创建
整理:
">":概念(输出重定向)
1.创建一个空文件:>file
2.清空一个文件:>file
3.将内容重定向进一个文件: echo "文本">file
02. ">>" (追加重定向)(类似于"a")
举例:
如图:
如图我们使用">>"持续输入了六条内容,log.txt内容也是这六条,这就是追加重定向,类似于c语言中文件中以"a"追加输入。
03. "<" 输入重定向
1.概念:本来应该从键盘文件中读取的内容,从普通的log.txt文件中读取。
举例:
如图:
如图:
注意:cat log.txt
cat > log.txt
(这两条指令实现的逻辑)完全不一样
04. 证明终端是一个文件
1.我们先查看系统中的终端文件
2.打开一个新的终端
如何打开一个新终端?(复制会话:创建一个新的进程来建立连接)
我将新打开的终端文件移动到下方
3.再次查看系统中的终端文件 与没有新打开终端时对比,我们发现,
多了一行新内容,这便是我们打开的新终端文件。
4.从原终端向新终端中写入内容
由图我们可看出,原来的终端文件名为0,新终端名为1
因此,我们可证明,终端也是文件!
其实以上的内容都是为了接下来创建大文件做准备:
二、大文件(都是为了查日志!!)
1.使用命令行脚本(shell),制作一个伪大文件
定义一个对应变量 i , i<=10000,一直打印 hello linux i
既然这样,我们可以用到刚刚学到的办法,将这些内容输入到一个文件中:
当我们想要确定的查某一行的内容该是用什么办法呢?接下来我们开始将一些新指令
01. more (可以打满一屏输出,就停下来,让用户下翻,逐行阅读)(不推荐使用)
语法: more [选项][文件]
功能: more命令,功能类似 cat
常用选项:
-num,输出前num行+num,从第num行开始输出一整屏内容
q 退出more
举例:但more指令不推荐使用。
02. less指令(重要)(用来查看大文本(日志),有高亮,且可以上下翻阅)
less 工具也是对文件或其它输出进行分页显示的工具,应该说是linux正统查看文件内容的工具,功能极其强大。
less 的用法比起 more 更加的有弹性。在 more 的时候,我们并没有办法向前面翻, 只能往后面看。
但若使用了 less 时,就可以使用 [pageup][pagedown] 等按键的功能来往前往后翻看文件,更容易用来查看一个文件的内容!
除此之外,在 less 里头可以拥有更多的搜索功能,不止可以向下搜,也可以向上搜。
语法: less [参数] 文件
功能:
less与more类似,但使用less可以随意浏览文件,而more仅能向前移动,却不能向后移动,而且less在查看之前不会加载整个文件。
选项:
-i :忽略搜索时的大小写
-N :显示每行的行号
/字符串:向下搜索“字符串”的功能
?字符串:向上搜索“字符串”的功能
n:重复前一个搜索(与 / 或 ? 有关)
N:反向重复前一个搜索(与 / 或 ? 有关)
q : quit
03. head指令(默认查开头10行)
head 与 tail 就像它的名字一样的浅显易懂,它是用来显示开头或结尾某个数量的文字区块, head 用来显示档案的开头至标准输出中,而 tail 想当然尔就是看档案的结尾。
语法: head [参数]... [文件]...
功能:
head 用来显示档案的开头至标准输出中,默认head命令打印其相应文件的开头10行。
选项:
-n<行数> 显示的行数举例:
如图:
04. tail指令
tail 命令从指定点开始将文件写到标准输出.使用tail命令的-f选项可以方便的查阅正在改变的日志文件,tail -f filename会把filename里最尾部的内容显示在屏幕上,并且不但刷新,使你看到最新的文件内容.
语法: tail[必要参数][选择参数][文件]
功能: 用于显示指定文件末尾内容,不指定文件时,作为输入信息进行处理。常用查看日志文件。
选项
-f 循环读取
-n<行数> 显示行数
如果要查看big.txt中间行呢?9000-9010行 ---11行?
首先假如说我们要查看日志,我们想要知道中间在哪,需要知道日志总共有多少行
05. wc指令 --- 统计文本的行数
06." | " 管道-级联多条指令
" | "----传输数据的媒介:一定要有的:入口,出口,数据传输
如果只想要查找最后10行呢?仍然用管道
07. date (指定格式显示时间)
date显示
date 指定格式显示时间: date +%Y:%m:%d
date 用法: date [OPTION]... [+FORMAT]
1.在显示方面,使用者可以设定欲显示的格式,格式设定为一个加号后接数个标记,其中常用的标记列表如下
%H : 小时(00..23)
%M : 分钟(00..59)
%S : 秒(00..61)
%X : 相当于 %H:%M:%S
%d : 日 (01..31)
%m : 月份 (01..12)
%Y : 完整年份 (0000..9999)
%F : 相当于 %Y-%m-%d
2.在设定时间方面
date -s //设置当前时间,只有root权限才能设置,其他只能查看。
date -s 20080523 //设置成20080523,这样会把具体时间设置成空00:00:00
date -s 01:01:01 //设置具体时间,不会对日期做更改
date -s “01:01:01 2008-05-23″ //这样可以设置全部时间
date -s “01:01:01 20080523″ //这样可以设置全部时间
date-s “2008-05-23 01:01:01″ //这样可以设置全部时间
date -s “20080523 01:01:01″ //这样可以设置全部时间3.时间戳
时间->时间戳: date +%s
时间戳->时间: date -d@1508749502
Unix时间戳(英文为Unix epoch, Unix time, POSIX time 或 Unix timestamp)是从1970年1月1日(UTC/GMT的午夜)开始所经过的秒数,不考虑闰秒
举例:这里有一个蛮重要的概念:时间戳 -(时间戳是会溢出的,并且影响特别大,如果感兴趣可以去了解一下)
08. cal(打印日历,了解即可)
cal命令可以用来显示公历(阳历)日历。公历是现在国际通用的历法,又称格列历,通称阳历。 “阳历”又名“太阳
历”,系以地球绕行太阳一周为一年,为西方各国所通用,故又名“西历”。
命令格式: cal [参数][月份][年份]
功能: 用于查看日历等时间信息,如只有一个参数,则表示年份(1-9999),如有两个参数,则表示月份和年份
常用选项:
-3 :显示系统前一个月,当前月,下一个月的月历-j 显示在当年中的第几天(一年日期按天算,从1月1号算起,默认显示当前月在一年中的天数)
-y : 显示当前年份的日历
cal -y 2024
09. find(查看指定文件,非常重要)
Linux下find命令在目录结构中搜索文件,并执行指定的操作。
Linux下find命令提供了相当多的查找条件,功能很强大。由于find具有强大的功能,所以它的选项也很多,其中大部分选项都值得我们花时间来了解一下。
即使系统中含有网络文件系统( NFS), find命令在该文件系统中同样有效,只你具有相应的权限。
在运行一个非常消耗资源的find命令时,很多人都倾向于把它放在后台执行,因为遍历一个大的文件系统可能会花费很长的时间(这里是指30G字节以上的文件系统)。
语法: find pathname -options
功能: 用于在文件树种查找文件,并作出相应的处理(可能访问磁盘)
常用选项:
-name 按照文件名查找文件find是真正的在系统的树状结构中进行文件查找的!
10.grep指令(行文本过滤工具)
grep参考文档
语法: grep [选项] 搜寻字符串 文件
功能: 在文件中搜索字符串,将找到的行打印出来
常用选项:
-i :忽略大小写的不同,所以大小写视为相同
-n :顺便输出行号
-v :反向选择,亦即显示出没有 '搜寻字符串' 内容的那一行
11. zip/unzip指令:
语法: zip 压缩文件.zip 目录或文件
功能: 将目录或文件压缩成zip格式
常用选项:
-r 递 归处理,将指定目录下的所有文件和子目录一并处理
举例:
将test2目录压缩: zip test2.zip test2/*
解压到tmp目录: unzip test2.zip -d /tmp
结语:
随着这篇关于题目解析的博客接近尾声,我衷心希望我所分享的内容能为你带来一些启发和帮助。解题的过程往往充满挑战,但正是这些挑战让我们不断成长和进步。我在准备这篇文章时,也深刻体会到了学习与分享的乐趣。
在此,我要特别感谢每一位阅读到这里的你。是你的关注和支持,给予了我持续写作和分享的动力。我深知,无论我在某个领域有多少见解,都离不开大家的鼓励与指正。因此,如果你在阅读过程中有任何疑问、建议或是发现了文章中的不足之处,都欢迎你慷慨赐教。 你的每一条反馈都是我前进路上的宝贵财富。同时,我也非常期待能够得到你的点赞、收藏,这将是对我莫大的支持和鼓励。当然,我更期待的是能够持续为你带来有价值的内容,让我们在知识的道路上共同前行。