自从熟悉了shell之后,感觉一发不可收拾,痴迷于各种一行命令搞定复杂任务的奇技淫巧。在感叹666的同时,也将其记录下来,以备使用。
1. zsh
第一个就是从bash切换到zsh,并且安装oh-my-zsh配置,github上面可以搜索到。
zsh的优点在于:
- 更友好的补全操作
- 更方便的历史命令查找
只需要输入curl,连续按下↑键,就能依次查找所有curl的历史命令,非curl开头的命令不会出现,也就是说是按照前缀匹配的。 - 更炫酷的命令提示符,极大地满足装逼欲望
我会告诉你这个是我使用zsh的主要原因吗?
2. Ctrl R
还在用history加grep?
这个命令用过一次就再也不会忘记,当你想查找历史命令时,直接按Ctrl+R,然后输入历史命令中包含的字符,你会发现shell会自动动态匹配历史命令,匹配到之后直接回车即可。
结合zsh的前缀查找,能够最快的查找到已经执行过的命令。
3. tcpdump
一般我们是用tcpdump抓完包,保存到文件,然后再把文件下载下来,使用wireshark来分析。
但是有的时候,我们中间会经历很多跳板机,并且我们有的时候只需要看http协议交互内容,不关注tcp的建链和拆链过程,有什么办法可以快速的查看抓包的内容呢?
tcpdump -qns 0 -A -r request.pcap
4. sort -h
对于磁盘紧张的我,经常会使用du -sh *来查看文件夹下面哪个文件夹占用空间最大。一个烦恼就是需要人肉查找占用空间最大的文件。
因为du -sh *的输出结果是带单位的,比如1k,4M这种,简单的du -sh *|sort,并不能得到正确的结果。
其实sort提供了一个-h的选项,专门用于这种情况,可以对带单位的大小进行排序。示例如下:
➜ /usr du -sh * | sort -h
0 games
0 src
8.0K local
232K include
8.9M sbin
90M bin
208M share
236M lib
5. uniq -c
uniq的正确性来源于输入的有序性,所以用uniq之前都要sort一把。
对一段文本去重并计数,或者快速检查一段文本中是否有重复行。
cat a b | sort | uniq > c # c is a union b
cat a b | sort | uniq -d > c # c is a intersect b
cat a b b | sort | uniq -u > c # c is set difference a - b
6. grep的几个使用姿势
先讲最常用的几个
grep -R,递归搜索文件夹下的所有文件。
grep -i,匹配时忽略大小写
grep -n,输出时包含行号
grep -A n,同时输出匹配行的后面n行。A代表after
grep -B n,同时输出匹配行的前面n行。B代表before
grep一个淫荡的技巧是不输出grep所在的那个进程。
就像这样
ps aux | grep [c]hroium
原理就是正则表达式”[c]hroium”的语义是字符串”chroium”,但是从形式上二者已经不一样了。于是grep拿正则表达式”[c]hroium”来匹配字符串”[c]hroium”,比较结果很明显是“chroium”!=”[c]hroium”,所以grep的进程就不会输出。
另外一个选项就是-L,输出不包含匹配行的文件名。
比如想搜一下哪些文件里面没有包含abc。
grep -L abc *.go
还有-o选项,只输出匹配的文本,在使用正则的时候会很有用。
7. sed
sed用来重命名。
find . -name "*.c"|sed 'p;s/.c$/.go/'|xargs -L 2 mv
其实rename也能做这个事情,但是有的系统上面装的不是perl版的rename,不能使用sed的语法来进行替换。这个时候还是要祭出sed。
- 上一条命令
快速执行上一条命令
sudo !!
获得上一条命令的输出
echo $(!!)
网友评论