圣凤凌霜 发表于 2018-8-20 06:57:25

最牛B的 Linux Shell 命令(二)

  1. 更友好的显示当前挂载的文件系统
mount | column -t  这条命令适用于任何文件系统,column 用于把输出结果进行列表格式化操作,这里最主要的目的是让大家熟悉一下 columnt 的用法。
  下面是单单使用 mount 命令的结果:
# mount  
/dev/hda1 on / type ext3 (rw)
  
proc on /proc type proc (rw)
  
sysfs on /sys type sysfs (rw)
  
devpts on /dev/pts type devpts (rw,gid=5,mode=620)
  
tmpfs on /dev/shm type tmpfs (rw)
  
/dev/xvdb1 on /data type ext3 (rw)
  
none on /proc/sys/fs/binfmt_misc type binfmt_misc (rw)
  而加了 column -t 命令后就成为这样了:
# mount|column -t  
/dev/hda1   on/                         typeext3         (rw)
  
proc      on/proc                     typeproc         (rw)
  
sysfs       on/sys                      typesysfs      (rw)
  
devpts      on/dev/pts                  typedevpts       (rw,gid=5,mode=620)
  
tmpfs       on/dev/shm                  typetmpfs      (rw)
  
/dev/xvdb1on/data                     typeext3         (rw)
  
none      on/proc/sys/fs/binfmt_misctypebinfmt_misc(rw)
  另外你可加上列名称来改善输出结果
$ (echo "DEVICE - PATH - TYPE FLAGS" && mount) | column -t  
DEVICE                  -   PATH   -   TYPE   FLAGS
  
/dev/root               on/      typeext3   (rw)
  
/proc                     on/proctypeproc   (rw)
  
/dev/mapper/lvmraid-homeon/hometypeext3   (rw,noatime)
  列2和列4并不是很友好,我们可以用 awk 来再处理一下
$ (echo "DEVICE PATH TYPE FLAGS" && mount | awk '$2=$4="";1') | column -t  
DEVICE                  PATH   TYPE   FLAGS
  
/dev/root               /      ext3   (rw)
  
/proc                     /procproc   (rw)
  
/dev/mapper/lvmraid-home/homeext3   (rw,noatime)
  最后我们可以设置一个别名,为 nicemount
$ nicemount() { (echo "DEVICE PATH TYPE FLAGS" && mount | awk '$2=$4="";1') | column -t; }  试一下
$ nicemount  
DEVICE                  PATH   TYPE   FLAGS
  
/dev/root               /      ext3   (rw)
  
/proc                     /procproc   (rw)
  
/dev/mapper/lvmraid-home/homeext3   (rw,noatime)
  2. 运行前一个 Shell 命令,同时用 “bar” 替换掉命令行中的每一个 “foo”
!!:gs/foo/bar  !! 表示重复执行上一条命令,并用 :gs/foo/bar 进行替换操作。
  关于 !! 这个用法在前一篇文章中已有详细的介绍。
  3. 实时某个目录下查看最新改动过的文件
watch -d -n 1 'df; ls -FlAt /path'  watch 是实时监控工具,-d 参数会高亮显示变化的区域,-n 1 参数表示刷新间隔为 1 秒。
  df; ls -FlAt /path 运行了两条命令,df 是输出磁盘使用情况,ls -FlAt 则列出 /path 下面的所有文件。
  ls -FlAt 的参数详解:
  -F 在文件后面加一个文件符号表示文件类型,共有 /=>@| 这几种类型, 表示可执行文件,/ 表示目录,= 表示接口( sockets) ,> 表示门, @ 表示符号链接, | 表示管道。
  -l 以列表方式显示
  -A 显示 . 和 ..
  -t 根据时间排序文件
  4. 通过 SSH 挂载远程主机上的文件夹
sshfs name@server:/path/to/folder /path/to/mount/point  这条命令可以让你通过 SSH 加载远程主机上的文件系统为本地磁盘,前提是你需要安装 FUSE 及 sshfs 这两个软件。
  译者注:关于 sshfs 实际上我之前写过一篇文章介绍过,详见在 Ubuntu 上使用 sshfs 映射远程 ssh 文件系统为本地磁盘(http://wowubuntu.com/sshfs.html)。
  卸载的话使用 fusermount 或 umount 命令:
$ fusermount -u /path/to/mount/point  
# umount /path/to/mount/point
  5. 通过 DNS 来读取 Wikipedia 的词条
  1
  dig +short txt .wp.dg.cx
  这也许是最有趣的一条技巧了,David Leadbeater 创建了一个 DNS 服务器,通过它当你查询一个 TXT 记录类型时,会返回一条来自于 Wikipedia 的简短的词条文字,这是他的介绍。
  这里有一个样例,来查询 “hacker” 的含义:
$ dig +short txt hacker.wp.dg.cx  
"Hacker may refer to: Hacker (computer security), someone involved
  
in computer security/insecurity, Hacker (programmer subculture), a
  
programmer subculture originating in the US academia in the 1960s,
  
which is nowadays mainly notable for the free software/” “open
  
source movement, Hacker (hobbyist), an enthusiastic home computer
  
hobbyist http://a.vu/w:Hacker"
  这里使用了 dig 命令,这是标准的用来查询 DNS 的系统管理工具,+short 参数是让其仅仅返回文字响应,txt 则是指定查询 TXT 记录类型。
  更简单的做法是你可以为这个技巧创建一个函数:
wiki() { dig +short txt $1.wp.dg.cx; }  
#然后试试吧:
  
wiki hacker
  
"Hacker may refer to: Hacker (computer security), …"
  如果你不想用 dig ,也可以用 host 命令:
host -t txt hacker.wp.dg.cx  另外在Twitter上看过某人的创意,用普通的dns来作为程序版本更新的查询服务器:设定域名software-version-check.example.com的A记录为1.2.40.3,对比自己的版本号,嗯,有更新了!
  6. 用 Wget 的递归方式下载整个网站
wget --random-wait -r -p -e robots=off -U Mozilla www.example.com  参数解释:
  –random-wait 等待 0.5 到 1.5 秒的时间来进行下一次请求
  -r 开启递归检索
  -e robots=off 忽略 robots.txt
  -U Mozilla 设置 User-Agent 头为 Mozilla
  其它一些有用的参数:
  –limit-rate=20K 限制下载速度为 20K
  -o logfile.txt 记录下载日志
  -l 0 删除深度(默认为5)
  -wait=1h 每下载一个文件后等待1小时
  7. 复制最后使用的命令中的参数
or   这个快捷键只能工作于 shell 的 emacs 编辑模式,它可以从最后使用的命令行中复制参数到当前命令行中,下面是一个样例:
$ echo a b c  
a b c
  
$ echo
  
$ echo c
  你可以重复执行该快捷键,以便获取自已需要的参数,
  以下是样例:
$ echo 1 2 3  
1 2 3
  
$ echo a b c
  
a b c
  
$ echo
  
$ echo c
  
$ echoagain
  
$ echo 3

  另外,假如你想指定第1个或第2个,或者是第 n 个参数的话,可以按>  以下是样例:
$ echo a b c  
a b c
  
$ echo
  
$ echo a
  
a
  
$ echo
  
$ echo b
  
b
  查看Emacs Editing Mode Keyboard Shortcuts(http://www.catonmat.net/blog/bash-emacs-editing-mode-cheat-sheet/)一文获取更多类似的快捷键。
  8. 执行一条命令但不保存到 history 中
$ command  这条命令可运行于最新的 Bash shell 里,在其它 shell 中没测试过。
  通过在命令行前面添加一个空格,就可以阻止这条命令被保存到 bash history (~/.bash_history) 文件中,这个行为可以通过 $HISTIGNORE shell 变量来控制。我的设置是 HISTIGNORE=”&:[ ]*” ,表示不保存重复的命令到 history 中,并且不保存以空格开头的命令行。$HISTIGNORE 中的值以冒号分隔。
  如果你的命令内包含密码,比如mysqladmin,不把它记录在历史当中是好主义。
  深入了解的话,可进一步看此文The Definitive Guide to Bash Command Line History(http://www.catonmat.net/blog/the-definitive-guide-to-bash-command-line-history/)
  9. 显示当前目录中所有子目录的大小
du -h --max-depth=1  –max-depth=1 参数可以让 du 命令显示当前目录下 1 级子目录的统计信息,当然你也可以把 1 改为 2 ,进一步显示 2 级子目录的统计信息,可以灵活运用。而 -h 参数则是以 Mb 、G 这样的单位来显示大小。
  译者注:在此推荐一个小工具 ncdu ,可以更方便的达到此效果。
  10. 显示消耗内存最多的 10 个运行中的进程,以内存使用量排序
ps aux | sort -nk +4 | tail  显然这并不是最好的方法,但它确实用起还不错。
  这是一个典型的管道应用,通过 ps aux 来输出到 sort 命令,并用 sort 排序列出 4 栏,再进一步转到 tail 命令,最终输出 10 行显示使用内存最多的进程情况。
  假如想要发现哪个进程使用了大量内存的话,我通常会使用 htop 或 top 而非 ps 。
  11. 用 python 快速开启一个 SMTP 服务
python -m smtpd -n -c DebuggingServer localhost:1025  这是一个用 Python 标准库 smtpd (用 -m smtpd 指定) 实现在简易 SMTP 服务,运行于 1025 端口 。
  另外三个参数的解释:
  -n 参数让 Python 不要进行 setuid ( 改变用户)为 “nobody” ,也就是说直接用你的帐号来运行
  -c DebuggingServer 参数是让 Python 运行时在屏幕上输出调试及运行信息
  * localhost:1025 参数则是让 Python 在本地的 1025 端口上开启 SMTP 服务
  另外,假如你想让程序运行于标准的 25 的端口上的话,你必须使用 sudo 命令,因为只有 root 才能在 1-1024 端口上开启服务。如下:
sudo python -m smtpd -n -c DebuggingServer localhost:25  *********************************************四**************************
  1.查看ascii码表
man 7 ascii  很多人初学编程都会接触到ascii码的概念,有时候为了查某个符号的ascii值,可能还得翻箱倒柜找出当年的课本?Linux Manpage里面其实包含了很多类似的实用资料,上述命令就能很详细的方式解释ascii编码,当然这里还有在线版。
  man命令的第二个参数是区域码,用来区分索引词的范围,比如printf,在C标准库里面的printf跟bash当中的printf是不同的,前者的查询是man 3 printf,后者是man 1 printf。如果这个区域码省略,就会从1开始搜索,直到找到为止。
  命令man man可以看到详细的解释。
  manpages里面还有一些有趣而且实用的资料,可能鲜为人知:
  man 1 intro – 一篇对从未接触过Linux的用户的简明教程。
  man 2 syscalls – 内核系统请求的列表,按内核版本注释分类,系统编程必备。
  man 2 select_tut – 关于select()系统请求的教程。
  man 3 string – 在头文件内的所有函数。
  man 3 stdio – 关于头文件的使用,标准输入/输出库的说明。
  man 3 errno – 所有errorno的取值及说明。(C语言内类似其他语言的异常告知机制)
  man 4 console_codes – Linux的终端控制码及其使用解释。
  man 4 full – 介绍/dev/full这个总是处于“满”状态的磁盘。(对应/dev/null这个总是空的设备)
  man 5 proc – 介绍/proc下的文件系统。
  man 5 filesystems – 各种Linux文件系统。
  第7区里面的资料通常最酷:
  man 7 bootparam – 详细解释内核启动参数。
  man 7 charsets – 解释各种语言的编码集。(gbk,gb2312等)
  man 7 glob – 解释glob文件名管理机制的工作过程。
  man 7 hier – 解释Linux文件系统结构各个部分的作用。
  man 7 operator – C语言的运算符的列表。
  man 7 regex – 介绍正则表达式。
  man 7 suffixes – 常见文件后缀名的列表跟解释。
  man 7 time – Linux的时钟机制解释。
  man 7 units – 数值单位及其数值的解释。
  man 7 utf8 – 描述UTF-8编码。
  man 7 url – 解释URL、URI、URN等的标准。
  2.简易计时器
time read  运行命令开始算起,到结束时按一下Enter,就显示出整个过程的时间,精确到ms级别。
  time是用来计算一个进程在运行到结束过程耗费多少时间的程序,它的输出通常有三项:
# time ll  
总计 924
  
-rw-r--r-- 1 root root 697856 12-19 16:19 ?????????-20131219.doc
  
-rw-r--r-- 1 root root   79 12-17 16:41 cpms.sh
  
-rw-r--r-- 1 root root   76 12-18 16:27 delms.sh
  
-rw-r--r-- 1 root root 222990 12-19 16:20 mscfqk.zip
  
drwxr-xr-x 2 root root   4096 12-11 17:37 test
  
real    0m0.003s
  
user    0m0.001s
  
sys   0m0.001s
  
#
  real指整个程序对真实世界而言运行所需时间,user指程序在用户空间运行的时间,sys指程序对系统调用锁占用时间。
  read本来是一个读取用户输入的命令,常见用法是read LINE,用户输入并回车后,键入的内容就被保存到$LINE变量内,但在键入回车前,这个命令是一直阻塞的。
  可见time read这命令灵活地利用了操作系统的阻塞。用这个命令来测试一壶水多久煮滚应该是不错的。
  3.远程关掉一台Windows机器
net rpc shutdown -I IP_ADDRESS -U username%password  Windows平台上的net命令是比较强大的,因为其后台是一个RPC类的系统服务,大家应该看过win下用net use \\ip\ipc$ *这样一个命令建立IPC空连接,***主机的事情。
  Linux下的net命令是samba组件的程序,通常包含在smbclient内,可以跟windows主机的文件、打印机共享等服务进行通讯,但是也支持rpc命令。
  上述命令就是在远程Windows主机上执行了shutdown命令。当然这不一定成功,关系到win主机上面的安全设置。net命令能够控制到win主机就是了。
  4.在一个子shell中运行一个命令
(cd /tmp && ls)  当然这只是演示,要查看目录当然可以ls /tmp。
  好处就是不会改变当前shell的目录,以及如果命令中设计环境变量,也不会对当前shell有任何修改。
  在Shell编程中还有很多使用上引号来括住一个命令:`ls /tmp`,这也是子shell过程。可是上引号的方法无法嵌套,而使用小括号的方法可以,一个比较纠结的例子是:
echo $(echo -e \\x$(printf "%x" 65))  5.利用中间管道嵌套使用SSH
ssh -t host_A ssh host_B  如果目标机器host_B处于比较复杂的网络环境,本机无法直接访问,但另外一台host_A能够访问到host_B,而且也能被本机访问到,那上述命令就解决了方便登录host_B的问题。
  但理论上这个过程是可以无限嵌套的,比如:
ssh -t host1 ssh -t host2 ssh -t host3 ssh -t host4 ...  嗯那神马FBI CIA的,有本事来捉我吧~
  6.清空屏幕
;  这个跟之前介绍的reset命令重置终端的作用有些类似,其实都只是发送一段控制序列,让终端的显示复位。
  还可以这样运行:
tput clear  tput是专门用来控制终端的一个小工具,也挺强大的,详细信息运行man tput查看。
  7.我想知道一台服务器什么时候重启完
ping -a IP  系统管理员最常做的事情是重启系统。但是服务器的重启过程往往得花上好几分钟,什么你的服务器4个scsi卡?16个硬盘?系统是Redhat?还完全安装所有组件?好吧,它重启的时间都够你吃顿饭了,所以我很想知道它什么时候回来。
  ping命令有个audible ping参数,-a,当它终于ping通你的服务器时会让小喇叭叫起来。
  8.列出你最常用的10条命令
history | awk '{a[$2]++}END{for(i in a){print a " " i}}' | sort -rn | head  这行命令组合得很妙:
  history输出用户了命令历史;awk统计并输出列表;sort排序;head截出前10行。
  9.检查Gmail新邮件
curl -u you@gmail.com --silent "https://mail.google.com/mail/feed/atom" |  perl -ne \
  '
  print "Subject: $1 " if /(.+?)/ && $title++;
  print "(from $1)\n" if /(.+?)/;
  '
  Gmail的一个特色是支持Atom feed输出邮件列表,所以总是见到很多Gmail邮件提醒器之类的,因为开发特简单,atom很方便。
  这里只是利用了perl的正则来解析atom(sed/awk也能做到)。
  10.用Telnet看《星球大战》
telnet towel.blinkenlights.nl  没什么好解释的,就是ASCII艺术之一。如果你有ipv6连接,还能看到彩色版的。牛吧?


页: [1]
查看完整版本: 最牛B的 Linux Shell 命令(二)