一起养成写作习惯!这是我参与「掘金日新计划 · 4 月更文挑战」的第3天,点击查看活动详情。
10、cat指令
语法: cat [选项][文件]
tac [选项][文件] :从下至上打印
功能: 查看目标文件的内容
常用选项:
▶ 空 ,无价值
在屏幕上输入并且输出
▶ -b ,对非空输出行编号
▶ -n ,对输出的所有行编号
▶ -s ,不输出多行空行
注意 cat 不适合查看大文件的内容 (比如有一个一万行的文本,此时要看第一行的内容,就要不断往上翻阅)
11、more指令
语法: more [选项][文件]
功能: 类似 cat
常用选项:
▶ -n ,对输出的所有行编号 (注意这里的 n 是具体数字)
如果 more -具体数字,首次 Enter 后就向下翻阅具体数字行
如果 more ,Enter 后就默认向下翻阅一行
more 的动作指令
▶ Ctrl + f、空格键 ,向下翻阅一页
▶ Ctrl + b、b ,向上翻阅一页
▶ = ,输出当前行的行号
:f ,输出文件名和当前行的行号
▶ v ,调用 vim 编辑器
▶ ! 命令 ,调用并执行 Shell 命令
▶ q ,退出 more
▶ / 关键字 ,可以查看至关键字的那一页,且只能往下查找
❗ cat和more的区别 ❕
两者的功能类似,但是使用场景不同
cat 适合查看小文件、more 适合查看大文件 (more 查看时最多一次可查看一页)
如果想要测试可以用以下命令生成数据
❗ 管道 ❕
这里我们想分页查看系统日志信息 (dmesg命令),就要通过管道。其中 “|” 就是管道,而管道的作用就是把 dmesg 这个命令的输出经过管道传递给 more 处理
看一段命令
这里把 dmesg 的输出通过管道传输并使用命令 grep -i (不分大小写筛选) error,再通过管道传输并使用命令 more -3 (以 3 行显示)
❗ 日志 ❕
日记:记录人的生活信息,用来进行差错性排查 (根据你的日记,确定你当前的状态)。
日志:相当于程序的日记,时间、日志等级 (warning、error、fatal 等)、内容。
❗ 输入、输出、追加重定向 ❕
当我们直接使用 printf 打印一串字符时它会直接在屏幕显示;
使用重定向 > 可以让这内容输出到你想要输入的文件里,改变了原本输出的轨迹这就叫输出重定向。注意输出重定向,如果没有文件会新建一个文件写入;如果有文件会清空原始文件,然后写入。每次输出重写向都是新文件,文件内容只有最后输出的文件。
如果想保留原始文件可以使用追加重定向 >>,如果指定的文件不存在,则用法同输出重定向;如果指定的文件存在,则往原文件里内容后追加新内容。
输入重定向,先输入重定向,再从文件里读
❓ 如何快速清空文件内容 ❔
为什么呢 —— 本质上是因为输出重定向会清空文件内容
12、less指令
▶ less 也是对文件或其它输出进行分页显示的工具,应该说是 linux 正统查看文件内容的工具,功能极其强大。
▶ less 的用法比起 more 更加的有弹性。使用了 less 时,就可以使用 [pageup][pagedown]、方向键的上下等按键的功能来往前往后翻看文件,更容易用来查看一个文件的内容。
▶ 除此之外,在 less 里头可以拥有更多的搜索功能,不止可以向下搜,也可以向上搜。
语法: less [参数] 文件
功能: less 与 more 类似,但使用 less 可以更加随意浏览文件,且 less 在查看之前不会加载整个文件。
常用选项:
▶ -i ,忽略搜索时的大小写
▶ -N ,显示每行的行号
▶ /字符串 ,向下搜索“字符串”的功能
▶ ?字符串 ,向上搜索“字符串”的功能
▶ n ,重复前一个搜索(与 / 或 ? 有关)
▶ N ,反向重复前一个搜索(与 / 或 ? 有关)
▶ q ,quit
❗ more 和 less ❕
对于 more 和 less,在以后都建议使用 less,因为对于功能 more 有的 less 有,less 有的 more 没有。
13、head指令
head 与 tail 就像它的名字一样的浅显易懂,它们是用来显示开头或结尾某个数量的文字区块,head 用来显示档案的开头至标准输出中,而 tail 当然就是看档案的结尾。
语法: head [参数]... [文件]...
功能: head 用来显示档案的开头至标准输出中,默认 head 命令打印其相应文件的开头 10 行,当然也可以指定。
常用选项:
▶ -n<行数> ,显示的行数
14、tail指令
tail 命令从指定点开始将文件写到标准输出,使用 tail 命令的 -f 选项可以方便的查阅正在改变的日志文件,tail -f filename 会把 filename 里最尾部的内容显示在屏幕上,并且不刷新,使你看到最新的文件内容。
语法: tail[必要参数][选择参数][文件]
功能: 用于显示指定文件末尾内容,不指定文件时,作为输入信息进行处理。常用查看日志文件
常用选项:
▶ -f ,循环读取
▶ -n<行数> ,显示行数
❓ 想查看文件的中间十行 ❔
【这个文件有一万行数据,要取 4995 - 5005 之间的数据】
方法一:需要临时文件
先取前 5005 行数据到 temp 文件里
再取 temp 文件的最后十行
方法二:不需要临时文件
这里利用了管道的功能,先取前 5005 行到管道作为 tail 10 的要取的对象
❓ 想查看文件的中间十行,并逆置这十行 ❔
再上面的基础上利用了 tac 命令进行逆置
15、时间相关指令
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 的午夜) (北京时间 12:00) 开始到现在所经过的秒数,不考虑闰秒
❓ 这里为什么不是以 12:00 开始 ❔
因为时差 —— 格林威治标准时间是零时区的地方时,北京是东 8 区,差 8 小时,比北京晚 8 小时
❓ 为什么要有时间戳 ❔
1️⃣ 因为是累计的秒数,是递增且不重复的,比较适合进行查找,尤其是范围查找
2️⃣ 存储空间相对较小 (次因)
❓ 时间戳有没可能会溢出 ❔
unsigned short ➡ unsigned int ➡ unsigned long long
时间戳有可能会溢出,且溢出了,影响非常大
❓ 有解决方案吗 ❔
目前没有,除非有新技术,目前的解决方案就是尽可能的将存储时间戳的字节数增大。
当然历史上也曾经发生过 —— 计算机 2000 年问题,又叫做 “千年虫”、“千年危机”。在某些使用了计算机程序的智能系统(包括计算机系统、自动控制芯片等)中,由于其中的年份 (千禧年之前的程序员) 只使用两位十进制数来表示,因此当系统进行跨世纪的日期处理运算时,就会出现错误的结果,进而引发各种各样的系统功能紊乱甚至崩溃。千禧年跨年之时就是时间戳溢出之时,所以当时就改了位宽。下次时间戳溢出的时间是 2038 年。
16、cal指令
cal 命令可以用来显示公历 (阳历) 日历。公历是现在国际通用的历法,又称格列历,通称阳历。“阳历” 又名 “太阳历”,系以地球绕行太阳一周为一年,为西方各国所通用,故又名 “西历”。
语法: cal [参数][月份][年份]
功能: 用于查看日历等时间信息,如只有一个参数,则表示年份 (1-9999),如有两个参数,则表示月份和年份
常用选项:
▶ -3 ,显示系统前一个月,当前月,下一个月的月历
▶ -j ,显示在当年中的第几天(一年日期按天算,从1月1号算起,默认显示当前月在一年中的天数)
▶ -y ,显示当前年份的日历
17、find指令:
▶ Linux 下 find 命令在目录结构中搜索文件,并执行指定的操作。
▶ Linux 下 find 命令提供了相当多的查找条件,功能很强大。由于 find 具有强大的功能,所以它的选项也很多,其中大部分选项都值得我们花时间来了解一下。
▶ 即使系统中含有网络文件系统 (NFS),find 命令在该文件系统中同样有效,只你具有相应的权限。
▶ 在运行一个非常消耗资源的 find 命令时,很多人都倾向于把它放在后台执行,因为遍历一个大的文件系统可能会花费很长的时间 (这里是指 30G 字节以上的文件系统)。
语法: find pathname -options
功能: 用于在文件树中查找文件,并作出相应的处理 (可能访问磁盘)
常用选项:
▶ -name ,按照文件名查找文件
❗ which 、whereis、find ❕
which 专门查找命令所在路径的命令 (系统路径中)
whereis 相比 which 更搜索的范围更广 (系统路径中)
find 命令相比 which、whereis 查看速度会更慢,因为它是在全局中 (包括磁盘) 查找
❗ 别名 ❕
这里的 alias 就是起别名的命令,这里把 ls --color=auto 起别名为 ls
注意自己写的这种别名只在当前终端有效
18、grep指令
语法: grep [选项] 搜寻字符串 文件
功能: 文本 行过滤工具,在文件中搜索字符串,将找到的行打印出来
常用选项:
▶ -i ,忽略大小写的不同,所以大小写视为相同
▶ -n ,输出行号
▶ -v ,反向选择,亦即显示出没有 '搜寻字符串' 内容的那一行
▶ -E ,支持正则表达式
19、zip/unzip指令
语法: zip 压缩文件.zip 目录或文件
功能: 将目录或文件压缩成 zip 格式
常用选项:
▶ -r, 递归处理,将指定目录下的所有文件和子目录一并处理
语法: unzip 压缩文件
功能: 将压缩文件解压
常用选项:
▶ -d,指定解压路径
20、tar指令 :
打包/解包,不打开它,直接看内容
语法: tar [-cxtzjvf] 文件与目录 .... 参数
常用选项:
▶ -c :建立一个压缩文件的参数指令(create 的意思);
▶ -x :解开一个压缩文件的参数指令!
▶ -t :查看 tarfile 里面的文件!
▶ -z :是否同时具有 gzip 的属性?亦即是否需要用 gzip 压缩?
▶ -j :是否同时具有 bzip2 的属性?亦即是否需要用 bzip2 压缩?
▶ -v :压缩的过程中显示文件!这个常用,但不建议用在背景执行过程!
▶ -f :使用档名,请留意,在 f 之后要立即接档名喔!不要再加参数!
▶ -C : 解压到指定目录
❗ 常见的组合命令 ❕
这里把 test 压缩成 temp.tgz 文件
这里把 temp.tgz 解压
这里把 test.tgz 解压并指明解压至 tmp 下
这里把 test 压缩成 temp.tgz 文件并显示执行过程
这里把 temp.tgz 解压并显示执行过程
❓ 为什么要有压缩包 ❔
压缩包的本质是多个文件 (普通文件+目录) 转换成一个文件 (压缩包)。 所以压缩包的作用是:
1️⃣ 减少因为网络或其它原因导致文件丢失的情况
2️⃣ 减少存储或传送成本
21、bc指令
bc 命令是 Linux 中的计算器,它可以很方便的进行浮点、整数运算,quit 就可以退出计算
22、uname指令
语法: uname [选项]
功能:uname 用来获取电脑和操作系统的相关信息
补充说明:uname 可显示 linux 主机所用的操作系统的版本、硬件的名称等基本信息
常用选项:
▶ -r ,查看内核版本
▶ -a 或 –all ,详细输出所有信息,依次为内核名称,主机名,内核版本号,内核版本,硬件名,处理器类型,硬件平台类型,操作系统名称
❓ 应用层面的版本 ❔