tshark抓包1
sudo tshark -s 512 -i eth0 -n -f 'tcp dst port 80' -R 'http.host and http.request.uri' -T fields -e http.host -e http.request.uri -l | tr -d '\t'
查看CPU的型号1
cat /proc/cpuinfo | grep name | cut -f2 -d: |uniq -c
查看CPU 几核几线程1
2grep 'processor' /proc/cpuinfo |sort -u |wc -l
grep 'core id' /proc/cpuinfo |sort -u |wc -l
以人性化的展示文件大小1
du -h file
文本按照列进行合并1
paste -d" " file1 file2 >> newFile
查看端口被哪个进程占用 以80端口为例:1
sudo lsof -i: 80
端口扫描:1
nmap ip
删除txt文本中的第一列的命令:1
sed -i -r -e "s/^[[:space:]]+//" -e "s/^[^[:space:]]+[[:space:]]+//" *.txt
把log.txt中的前600行追加到log1.txt中去
1 | sed -n '1,600 p' log.txt > log1.txt |
查看文件的编码:
1 | enca -L zh filename.java |
解压/压缩 命令:
后缀为gz:
1 | 解压:gzip -d FileName.gz |
后缀为.tar.gz
1 | 解压:tar zxvf FileName.tar.gz |
压缩为zip
1 | zip -r myfile.zip myfile/* |
后缀为.bz2
1 | 解压:bzip2 -d fleName.bz2 |
后缀为.rar
1 | 解压:rar a FileName.rar |
后缀为.tgz
1 | 解压:tar zxvf FileName.tgz |
linux 查看外网ip1
2curl ifconfig.me
curl http://members.3322.org/dyndns/getip
在控制台打开某个文件窗口
1 | nautilus /home/*** |
输出某一列
1 | cat ××.txt |awk '{print $1}' >> out.txt |
循环读取文件夹中的文件并保存为新的文件
1 | for file in * |
windows文件拷贝到linux乱码时 指定编码1
iconv -f GBK -t UTF-8 file1 -o file2
批量转码shell1
2
3
4
5
6#!/bin/sh
for i in *
do
iconv -f gb2312 -t utf-8 $i >tmp
cp tmp $i
done
文本去空格1
sed s/[[:space:]]//g
文本文件内容洗牌1
cat in.txt | awk 'BEGIN{srand()}{print rand()"\t"$0}' | sort -k1,1 -n | cut -f2- > out.txt
去引号1
2sed 's/"//g'
tr -d '"'
1 | awk -F ',' '{print $14,$15}' cup14w15w >> newcup |
1 | cat tag3 | awk '{if($0 ~ /ag/) print " "; else print "C"$0+1 }' >> tag5 |
shell中一行变一列1
cat inputFile |tr "\n" " "
1.检查远程端口是否对bash开放:
1 | echo >/dev/tcp/8.8.8.8/53 && echo "open" |
2.让进程转入后台:
1 | Ctrl + z |
3、将进程转到前台:
1 | fg |
4.产生随机的十六进制数,其中n是字符数:
1 | openssl rand -hex n |
5.在当前shell里执行一个文件里的命令:
1 | source /home/user/file.name |
6.截取前5个字符:
1 | ${variable:0:5} |
7.SSH debug 模式:
1 | ssh -vvv user@ip_address |
8.SSH with pem key:
1 | ssh user@ip_address -i key.pem |
9.用wget抓取完整的网站目录结构,存放到本地目录中:
1 | wget -r --no-parent --reject "index.html*" http://hostname/ -P /home/user/dirs |
10.一次创建多个目录:
1 | mkdir -p /home/user/{test,test1,test2} |
11.列出包括子进程的进程树:
1 | ps axwef |
12.创建 war 文件:
1 | jar -cvf name.war file |
13.测试硬盘写入速度:
1 | dd if=/dev/zero of=/tmp/output.img bs=8k count=256k; rm -rf /tmp/output.img |
14.测试硬盘读取速度:
1 | hdparm -Tt /dev/sda |
15.获取文本的md5 hash:
1 | echo -n "text" | md5sum |
16.检查xml格式:
1 | xmllint --noout file.xml |
17.将tar.gz提取到新目录里:
1 | zxvf package.tar.gz -C new_dir |
18.使用curl获取HTTP头信息:
1 | curl -I http://www.example.com |
19.修改文件或目录的时间戳(YYMMDDhhmm):
1 | touch -t 0712250000 file |
20.用wget命令执行ftp下载:
1 | wget -m ftp://username:password@hostname |
21.生成随机密码(例子里是16个字符长):
1 | LANG=c < /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c${1:-16};echo; |
22.快速备份一个文件:
1 | cp some_file_name{,.bkp} |
23.访问Windows共享目录:
1 | smbclient -U "DOMAIN\user" //dc.domain.com/share/test/dir |
24.执行历史记录里的命令(这里是第100行):
1 | !100 |
25.解压:
1 | unzip package_name.zip -d dir_name |
26.输入多行文字(CTRL + d 退出):
1 | cat > test.txt |
27.创建空文件或清空一个现有文件:
1 | \> test.txt |
28.与Ubuntu NTP server同步时间:
1 | ntpdate ntp.ubuntu.com |
29.用netstat显示所有tcp4监听端口:
1 | netstat -lnt4 | awk '{print $4}' | cut -f2 -d: | grep -o '[0-9]*' |
30.qcow2镜像文件转换:
1 | qemu-img convert -f qcow2 -O raw precise-server-cloudimg-amd64-disk1.img \precise-server-cloudimg-amd64-disk1.raw |
31.重复运行文件,显示其输出(缺省是2秒一次):
1 | watch ps -ef |
32.所有用户列表:
1 | getent passwd |
33.Mount root in read/write mode:
1 | mount -o remount,rw / |
34.挂载一个目录(这是不能使用链接的情况):
1 | mount --bind /source /destination |
35.动态更新DNS server:
1 | nsupdate < <EOF |
36.递归grep所有目录:
1 | grep -r "some_text" /path/to/dir |
37.列出前10个最大的文件:
1 | lsof / | awk '{ if($7 > 1048576) print $7/1048576 "MB "$9 }' | sort -n -u | tail |
38.显示剩余内存(MB):
1 | free -m | grep cache | awk '/[0-9]/{ print $4" MB" }' |
39.打开Vim并跳到文件末:
1 | vim + some_file_name |
40.Git 克隆指定分支(master):
1 | git clone git@github.com:name/app.git -b master |
41.Git 切换到其它分支(develop):
1 | git checkout develop |
42.Git 删除分支(myfeature):
1 | git branch -d myfeature |
43.Git 删除远程分支
1 | git push origin :branchName |
44.Git 将新分支推送到远程服务器:
1 | git push -u origin mynewfeature |
45.打印历史记录中最后一次cat命令:
1 | !cat:p |
46.运行历史记录里最后一次cat命令:
1 | !cat |
47.找出/home/user下所有空子目录:
1 | find /home/user -maxdepth 1 -type d -empty |
48.获取test.txt文件中第50-60行内容:
1 | < test.txt sed -n '50,60p' |
49.运行最后一个命令(如果最后一个命令是mkdir /root/test, 下面将会运行: sudo mkdir /root/test):
1 | sudo !! |
50.创建临时RAM文件系统 – ramdisk (先创建/tmpram目录):
1 | mount -t tmpfs tmpfs /tmpram -o size=512m |
51.Grep whole words:
1 | grep -w "name" test.txt |
52.在需要提升权限的情况下往一个文件里追加文本:
1 | echo "some text" | sudo tee -a /path/file |
53.列出所有kill signal参数:
1 | kill -l |
54.在bash历史记录里禁止记录最后一次会话:
1 | kill -9 $$ |
55.扫描网络寻找开放的端口:
1 | nmap -p 8081 172.20.0.0/16 |
56.设置git email:
1 | git config --global user.email "me@example.com" |
57.To sync with master if you have unpublished commits:
1 | git pull --rebase origin master |
58.将所有文件名中含有”txt”的文件移入/home/user目录:
1 | find -iname "*txt*" -exec mv -v {} /home/user \; |
59.将文件按行并列显示:
1 | paste test.txt test1.txt |
60.shell里的进度条:
1 | pv data.log |
61.使用netcat将数据发送到Graphite server:
1 | echo "hosts.sampleHost 10 `date +%s`" | nc 192.168.200.2 3000 |
62.将tabs转换成空格:
1 | expand test.txt > test1.txt |
63.Skip bash history:
1 | < space >cmd |
64.去之前的工作目录:
1 | cd - |
65.拆分大体积的tar.gz文件(每个100MB),然后合并回去:
1 | split –b 100m /path/to/large/archive /path/to/output/files |
66.使用curl获取HTTP status code:
1 | curl -sL -w "%{http_code}\\n" www.example.com -o /dev/null |
67.设置root密码,强化MySQL安全安装:
1 | /usr/bin/mysql_secure_installation |
68.当Ctrl + c不好使时:
1 | Ctrl + \ |
69.获取文件owner:
1 | stat -c %U file.txt |
70.block设备列表:
1 | lsblk -f |
71.找出文件名结尾有空格的文件:
1 | find . -type f -exec egrep -l " +$" {} \; |
72.找出文件名有tab缩进符的文件
1 | find . -type f -exec egrep -l $'\t' {} \; |
73.用”=”打印出横线:全选复制放进笔记
1 | printf '%100s\n' | tr ' ' = |
参考文献
[1] http://www.techbar.me/linux-shell-tips/
[2] http://linuxtools-rst.readthedocs.io/zh_CN/latest/base/index.html
[3] http://man.linuxde.net/tee