用途:
连接文件或标准输入并打印。
这个命令常用来显示文件内容,或者将几个文件连接起来显示,或者从标准输入读取内容并显示,它常与重定向符号配合使用。
命令格式:
cat [选项] [文件]
命令功能:
cat
主要有三大功能:
cat filename
cat > filename
只能创建新文件,不能编辑已有文件。cat file1 file2 > file
命令参数:
简写 | 含义 | 解释 |
---|---|---|
-A | --show-all |
等价于-vET |
-b | --number-nonblank |
对非空输出行编号 |
-e | 等价于-vE |
|
-E | --show-ends |
在每行结束处显示$ |
-n | --number |
对输出的所有行编号,由1开始对所有输出的行数编号 |
-s | --squeeze-blank |
有连续两行以上的空白行,就代换为一行的空白行 |
-t | 与-vT 等价 |
|
-T, | --show-tabs |
将跳格字符显示为^I |
-u | (被忽略) | |
-v, | --show-nonprinting |
使用^ 和M- 引用,除了LFD 和TAB 之外 |
简介:
awk
是一个强大的文本分析工具,相对于grep
的查找,sed
的编辑,awk
在其对数据分析并生成报告时,显得尤为强大。简单来说awk
就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行各种分析处理。
awk
有3个不同版本: awk
、nawk
和gawk
,未作特别说明,一般指gawk
,gawk
是 AWK 的 GNU 版本。
使用方法:
awk '{pattern + action}' {filenames}
其中pattern
表示 AWK
在数据中查找的内容,而 action
是在找到匹配内容时所执行的一系列命令。花括号{}
不需要在程序中始终出现,但它们用于根据特定的模式对一系列指令进行分组。 pattern
就是要表示的正则表达式,用斜杠括起来。
基本功能:
awk
语言的最基本功能是在文件或者字符串中基于指定规则浏览和抽取信息,awk
抽取信息后,才能进行其他文本操作。完整的awk
脚本通常用来格式化文本文件中的信息。
通常,awk
是以文件的一行为处理单位的。awk
每接收文件的一行,然后执行相应的命令,来处理文本。
简介:
sed
是一种在线编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space
);
接着用sed
命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。
文件内容并没有 改变,除非你使用重定向存储输出。
基本功能:
Sed
主要用来自动编辑一个或多个文件;简化对文件的反复操作;编写转换程序等。
nl
命令在linux系统中用来计算文件中行号。
nl
可以将输出的文件内容自动的加上行号!其默认的结果与 cat -n
有点不太一样, nl
可以将行号做比较多的显示设计,包括位数与是否自动补齐 0 等等的功能。
简介:
rm
是常用的命令,该命令的功能为删除一个目录中的一个或多个文件或目录,它也可以将某个目录及其下的所有文件及子目录均删除。对于链接文件,只是删除了链接,原有文件均保持不变。
rm是一个危险的命令,使用的时候要特别当心,尤其对于新手,否则整个系统就会毁在这个命令(比如在/(根目录)下执行rm * -rf)。所以,我们在执行rm之前最好先确认一下在哪个目录,到底要删除什么东西,操作时保持高度清醒的头脑。
命令格式:
rm [选项] 文件…
命令功能:
删除一个目录中的一个或多个文件或目录,如果没有使用- r选项,则rm不会删除目录。如果使用 rm 来删除文件,通常仍可以将该文件恢复原状。
命令参数:
简写 | 含义 | 解释 |
---|---|---|
-f | --force |
忽略不存在的文件,从不给出提示。 |
-i | --interactive |
进行交互式删除 |
-r | -R , --recursive |
指示rm将参数中列出的全部目录和子目录均递归地删除。 |
-v | --verbose |
详细显示进行的步骤 |
--help |
显示此帮助信息并退出 | |
--version |
输出版本信息并退出 |
grep(global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。
grep match_pattern file_name
grep "match_pattern" file_name
grep -v "match_pattern" file_name
统计文件或者文本中包含匹配字符串的行数 -c 选项:
grep -c "text" file_name
输出包含匹配字符串的行数 -n 选项:
grep "text" -n file_name
cat file_name | grep "text" -n
tcpdump命令是一款sniffer工具,它可以打印所有经过网络接口的数据包的头信息,也可以使用-w
选项将数据包保存到文件中,方便以后分析。
tcpdump
将监视第一个网络接口上所有流过的数据包 tcpdump
ip
,例如截获所有210.27.48.1 的主机收到的和发出的所有的数据包 tcpdump host 210.27.48.1
tcpdump host 210.27.48.1 and \ (210.27.48.2 or 210.27.48.3 \)
tcpdump tcp port 23 host 210.27.48.1
strace
命令是一个集诊断、调试、统计与一体的工具,我们可以使用strace
对应用的系统调用和信号传递的跟踪结果来对应用进行分析,以达到解决问题或者是了解应用工作过程的目的。当然strace
与专业的调试工具比如说gdb
之类的是没法相比的,因为它不是一个专业的调试器。
strace
的最简单的用法就是执行一个指定的命令,在指定的命令结束之后它也就退出了。在命令执行的过程中,strace
会记录和解析命令进程的所有系统调用以及这个进程所接收到的所有的信号值。
chmod
命令用来变更文件或目录的权限。在UNIX系统家族里,文件或目录权限的控制分别以读取、写入、执行3种一般权限来区分,另有3种特殊权限可供运用。用户可以使用chmod
指令去变更文件与目录的权限,设置方式采用文字或数字代号皆可。符号连接的权限无法变更,如果用户对符号连接修改权限,其改变会作用在被连接的原始文件。
diff
命令在最简单的情况下,比较给定的两个文件的不同。如果使用“-”代替“文件”参数,则要比较的内容将来自标准输入。diff
命令是以逐行的方式,比较文本文件的异同处。如果该命令指定进行目录的比较,则将会比较该目录中具有相同文件名的文件,而不会对其子目录文件进行任何比较操作。
more
命令是一个基于vi编辑器文本过滤器,它以全屏幕的方式按页显示文本文件的内容,支持vi中的关键字定位操作。more
名单中内置了若干快捷键,常用的有H(获得帮助信息),Enter(向下翻滚一行),空格(向下滚动一屏),Q(退出命令)。
less
命令的作用与more
十分相似,都可以用来浏览文字档案的内容,不同的是less
命令允许用户向前或向后浏览文件,而more
命令只能向前浏览。用less
命令显示文件时,用PageUp键向上翻页,用PageDown键向下翻页。要退出less
程序,应按Q键。
paste
命令用于将多个文件按照列队列进行合并。
head
命令用于显示文件的开头的内容。在默认情况下,head
命令显示文件的头10行内容。
tail
命令用于输入文件中的尾部内容。tail
命令默认在屏幕上显示指定文件的末尾10行。如果给定的文件不止一个,则在显示的每个文件前面加一个文件名标题。如果没有指定文件或者文件名为“-”,则读取标准输入。
注意:如果表示字节或行数的N值之前有一个”+”号,则从文件开头的第N项开始显示,而不是显示文件的最后N项。N值后面可以有后缀:b表示512,k表示1024,m表示1 048576(1M)。
uniq
命令用于报告或忽略文件中的重复行,一般与sort命令结合使用。
sort
命令是在Linux里非常有用,它将文件进行排序,并将排序结果标准输出。sort
命令既可以从特定的文件,也可以从stdin中获取输入。
who
命令是显示目前登录系统的用户信息。执行who
命令可得知目前有那些用户登入系统,单独执行who
命令会列出登入帐号,使用的终端机,登入时间以及从何处登入或正在使用哪个X显示器。
netstat
命令用来打印Linux中网络系统的状态信息,可让你得知整个Linux系统的网络情况。
ipcs
命令用于报告Linux中进程间通信设施的状态,显示的信息包括消息列表、共享内存和信号量的信息。
ipcrm
命令移除一个消息对象。或者共享内存段,或者一个信号集,同时会将与ipc对象相关链的数据也一起移除。当然,只有超级管理员,或者ipc对象的创建者才有这项权利啦