实用的Linux命令行技巧

2017-08-06  本文已影响0人  Matrix0x7C

自从熟悉了shell之后,感觉一发不可收拾,痴迷于各种一行命令搞定复杂任务的奇技淫巧。在感叹666的同时,也将其记录下来,以备使用。

1. zsh

第一个就是从bash切换到zsh,并且安装oh-my-zsh配置,github上面可以搜索到。
zsh的优点在于:

  1. 更友好的补全操作
  2. 更方便的历史命令查找
    只需要输入curl,连续按下↑键,就能依次查找所有curl的历史命令,非curl开头的命令不会出现,也就是说是按照前缀匹配的。
  3. 更炫酷的命令提示符,极大地满足装逼欲望
    我会告诉你这个是我使用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。

  1. 上一条命令
    快速执行上一条命令
sudo !!

获得上一条命令的输出

echo $(!!)
上一篇下一篇

猜你喜欢

热点阅读