linux命令合集

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


前言

shell快捷键

命令执行:	
    !! 					执行上一条命令
    !num 				执行历史命令中的第num行命令
    Ctrl 关键字 		  执行内容匹配的命令
    命令行切换
	Ctrl + A 			光标迅速回到行首
	Ctrl + E			光标迅速回到行尾
	Ctrl + k			删除光标到行尾内容
	Ctrl + u			删除光标到行首内容
	Ctrl + y			粘贴删除的内容
	Ctrl + c			临时终止命令行命令
	Esc + b				移动到当前单词的开头
	Esc + f				移动到当前单词的结尾

grep命令

grep options 'keys' filename
OPTIONS:
    -i: 不区分大小写
    -v: 查找不包含指定内容的行,反向选择
    -w: 按单词搜索
    -o: 打印匹配关键字
    -c: 统计匹配到的次数
    -n: 显示行号
    -r: 逐层遍历目录查找
    -A: 显示匹配行及后面多少行	
    -B: 显示匹配行及前面多少行
    -C: 显示匹配行前后多少行
    -l:只列出匹配的文件名
    -L:列出不匹配的文件名
    -e: 使用正则匹配
    -E:使用扩展正则匹配
    ^key:以关键字开头
    key$:以关键字结尾
    ^$:匹配空行
    --color=auto :可以将找到的关键词部分加上颜色的显示
    grep 高亮显示
centos7中已经为大家设置了,存放在/etc/profile.d/colorgrep.sh文件中,如若大家使用的系统中没有设置颜色输出,可以使用以下方法来自行设置

临时设置:
 alias grep='grep --color=auto'			//只针对当前终端和当前用户生效

永久设置:
1)全局(针对所有用户生效)
vim /etc/bashrc
alias grep='grep --color=auto'
source /etc/bashrc

2)局部(针对具体的某个用户)
vim ~/.bashrc
alias grep='grep --color=auto'
source ~/.bashrc

 grep -i root 					忽略大小写匹配包含root的行
 grep -w ftp 					精确匹配ftp单词
 grep -wo ftp 					打印匹配到的关键字ftp
 grep -n root 					打印匹配到root关键字的行好
 grep -ni root 				忽略大小写匹配统计包含关键字root的行
 grep -nic root 				忽略大小写匹配统计包含关键字root的行数
 grep -i ^root 					忽略大小写匹配以root开头的行
 grep bash$  					匹配以bash结尾的行
 grep -n ^$  					匹配空行并打印行号
 grep ^# /etc/vsftpd/vsftpd.conf		匹配以#号开头的行
 grep -v ^# /etc/vsftpd/vsftpd.conf	匹配不以#号开头的行
 grep -A 5 mail  				匹配包含mail关键字及其后5行
 grep -B 5 mail 				匹配包含mail关键字及其前5行
 grep -C 5 mail 				匹配包含mail关键字及其前后5行

tail命令

linux tail命令用途是依照要求将指定的文件的最后部分输出到标准设备,通常是终端,通俗讲来,就是把某个档案文件的最后几行显示到终端上,假设该档案有更新,tail会自己主动刷新,确保你看到最新的档案内容。

tail [ -f ] [ -c Number | -n Number | -m Number | -b Number | -k Number ] [ File ]
参数解释:
-f 该参数用于监视File文件增长。
-c Number 从 Number 字节位置读取指定文件
-n Number 从 Number 行位置读取指定文件。
-m Number 从 Number 多字节字符位置读取指定文件,比方你的文件假设包括中文字,假设指定-c参数,可能导致截断,但使用-m则会避免该问题。
-b Number 从 Number 表示的512字节块位置读取指定文件。
-k Number 从 Number 表示的1KB块位置读取指定文件。
File 指定操作的目标文件名称
上述命令中,都涉及到number,假设不指定,默认显示10行。Number前面可使用正负号,表示该偏移从顶部还是从尾部開始计算。
tail可运行文件一般在/usr/bin/以下。
二、tail命令使用方法演示例子

1、tail -f filename
说明:监视filename文件的尾部内容(默认10行,相当于增加参数 -n 10),刷新显示在屏幕上。退出,按下CTRL+C。

2、tail -n 20 filename
说明:显示filename最后20行。

3、tail -r -n 10 filename
说明:逆序显示filename最后10行。

补充:
跟tail功能相似的命令还有:
cat 从第一行開始显示档案内容。
tac 从最后一行開始显示档案内容。
more 分页显示档案内容。
less 与 more 相似,但支持向前翻页
head 仅仅显示前面几行
tail 仅仅显示后面几行
n 带行号显示档案内容
od 以二进制方式显示档案内容

head命令

Linux head 命令读取前 N 行并将其打印到标准输出。默认情况下,它将文件的前十行输出到标准输出。但是,可以通过在命令行上传递额外的参数来修改这一点。head 命令与 tail 命令相反,后者打印给定文件的最后 N 行。

在本指南中,我们将重点关注 Linux head 命令,并介绍该命令的几个用例。

命令语法
$ head [options] files(s)

(1) 显示文件的前十行
不带任何参数,显示文件的前十行

$ head asian_countries.txt

(2) 显示文件名标记
使用 -v 选项,可以在打印文件中的行之前显示文件名标记,如下所示

$ head -v asian_countries.txt

(3) 显示多个文件的输出
另外,您可以在一个命令中传递多个文件,如下所示。这一次,每个文本文件的名称首先打印在行之前,第一个文件的输出位于下一个文件之前。

$ head asian_countries.txt europe_countries.txt

(4) 显示前 N 行
使用 -n 选项定义想要显示的行,后跟想要打印的行数。例如,要打印前 5 行,可以执行以下命令

$ head -n 5 asian_countries.txt

(5) 将输出重定向到文件
您可以使用重定向操作符 (>) 将 head 命令的输出保存到文本文件或日志文件中,而不是打印到标准输出。如果文件不存在,则创建它,并存储输出。请注意,这将覆盖文件中的所有内容。

将 asian_countries.txt 文件的前四行内容保存到 output.txt 文件中

$ head -n 4 asian_countries.txt > output.txt
为了防止文件被覆盖,使用双大于操作符 (>>) 将输出追加到文件中。

在下面的命令中,我们将 europe_countries.txt 文件的前四行输出附加到 output.txt 文件,而不覆盖它。

$ head -n 4 europe_countries.txt >> output.txt

6) 配合管道使用
使用管道命令打印 n 行数。例如,您可以在 /etc 目录中打印前 15 个条目,如下所示

$ ls /etc | head -n 15

您还可以通过管道将 head 命令的输出传递给其他命令,例如 sort 命令,以便更好地进行格式化。

$ head -n 5 asian_countries.txt | sort > output2.txt

tr命令

字符转换、替换、删除

用法:tr [选项]... SET1 [SET2]
从标准输入中替换、缩减和/或删除字符,并将结果写到标准输出。

  -c, -C, --complement          首先补足SET1
  -d, --delete                  删除匹配SET1 的内容,并不作替换
  -s, --squeeze-repeats 		如果匹配于SET1 的字符在输入序列中存在连续的
                                重复,在替换时会被统一缩为一个字符的长度
  -t, --truncate-set1           先将SET1 的长度截为和SET2 相等
      --help            		显示此帮助信息并退出
      --version         		显示版本信息并退出
      
用法1:把commands命令输出做为tr输入进行处理
commands | tr  'string1'  'string2'

用法2:把文件中的内容输入给tr进行处理
tr  'string1'  'string2' < filename

用法3:把文件中的内容输入给tr进行处理,需要使用到选项

xargs命令

命令结果传递

作用:
    xargs 可以将管道或标准输入(stdin)数据转换成命令行参数,也能够从文件的输出中读取数据。
    xargs 一般是和管道一起使用。

命令格式:
	somecommand |xargs -item  command

OPTIONS:
    -a file 从文件中读入作为sdtin
    -E flag flag必须是一个以空格分隔的标志,当xargs分析到含有flag这个标志的时候就停止。
    -p 当每次执行一个argument的时候询问一次用户。
    -n num 后面加次数,表示命令在执行的时候一次用的argument的个数,默认是用所有的。
    -t 表示先打印命令,然后再执行。
    -i 或者是-I,将xargs接收的每项名称,逐行赋值给 {},可以用 {} 代替。
    -r no-run-if-empty 当xargs的输入为空的时候则停止xargs,不用再去执行了。
    -d delim 分隔符,默认的xargs分隔符是回车,argument的分隔符是空格,这里修改的是xargs的分隔符。


注意:linux命令格式一般为
    命令    命令选项     参数
    上一个命令的输出就是下一个命令的参数  这句话结合命令语法  应该知道输出的内容在下一个命令的位置了吧。

脚本实践

cat get_netinfo.sh

获取ip地址信息
ifconfig eth0 | grep -w inet | awk '{print $2}' | xargs echo "IP: "

获取掩码地址信息
ifconfig eth0 | grep -w inet | awk '{print $4}' | xargs echo "NetMask: "

获取广播地址信息
ifconfig eth0 | grep -w inet | awk '{print $6}' | xargs echo "Broadcast: "

获取MAC地址信息
ifconfig eth0 | grep ether | awk '{print $2}' |xargs echo "MAC Address: "

执行脚本
/bin/bash get_netinfo.sh
IP:  10.0.0.12
NetMask:  255.255.255.0
Broadcast:  10.0.0.255
MAC Address:  00:0c:29:23:23:8c

总结

  • 7
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值