一些“简单”的linux命令(r2笔记46天)

有些linux命令看起来极其简单,只包含2个字符,但确有很强的功能性。看起来还是有些陌生的命令,不过在工作中别忘记它们的存在。

ab

这条命令式做为性能测试所广泛用到的一下子就有了一种高大上的感觉,来一个例子,对百度的某一个网页执行并发100,时长5秒,发送10000次请求的测试 [ora11g@rac1 ~]$ ab -n 10000 -c 100 -t 5 http://image.baidu.com/channel/game This is ApacheBench, Version 2.3 <$Revision: 655654 $> Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/ Licensed to The Apache Software Foundation, http://www.apache.org/ Benchmarking image.baidu.com (be patient) Finished 31 requests Server Software: Apache Server Hostname: image.baidu.com Server Port: 80 Document Path: /channel/game Document Length: 53002 bytes Concurrency Level: 100 Time taken for tests: 5.032 seconds Complete requests: 31 Failed requests: 0 Write errors: 0 Total transferred: 3889626 bytes HTML transferred: 3843863 bytes Requests per second: 6.16 [#/sec] (mean) Time per request: 16231.568 [ms] (mean) Time per request: 162.316 [ms] (mean, across all concurrent requests) Transfer rate: 754.89 [Kbytes/sec] received Connection Times (ms) min mean[+/-sd] median max Connect: 17 48 63.6 40 384 Processing: 1605 3580 880.3 3815 4970 Waiting: 128 651 652.4 328 2129 Total: 1623 3629 872.0 3864 5019 Percentage of the requests served within a certain time (ms) 50% 3859 66% 4125 75% 4364 80% 4369 90% 4409 95% 4951 98% 5019 99% 5019 100% 5019 (longest request)

ac

[ora11g@rac1 ~]$ ac total 3738.65 将显示每个用户的总的连接时间: [ora11g@rac1 ~]$ ac -p dbtgr 57.75 ora10g 0.01 ora11g 48.28 ogg 22.08 jeanron 907.77 root 2.83 grid 2699.92 total 3738.66 grid 35.64 May 20 total 35.64 grid 78.35 May 21 total 78.35 grid 6.34 May 22 total 6.34 grid 19.00 May 23 total 19.00 grid 9.66 May 24 total 9.66 grid 23.49 May 26 total 23.49 grid 71.23 May 27 total 71.23 grid 57.33 May 28 total 57.33 grid 32.51 May 29 total 32.51 grid 100.73 Today total 100.73

at

三天后的下午 5点钟执行 /bin/ls [ora11g@rac1 ~]$ at 5pm+3 days at> ls at> <EOT> job 2 at 2014-06-04 17:00

bc

很简洁的计算器 Copyright 1991-1994, 1997, 1998, 2000, 2004, 2006 Free Software Foundation, Inc. This is free software with ABSOLUTELY NO WARRANTY. For details type `warranty'. 7+8 15 9*5 45

cc

这个精简的命令背后的后盾就是gcc [ora11g@rac1 bin]$ ll cc lrwxrwxrwx. 1 root root 3 Mar 13 2013 cc –> gcc

dc

逆波兰表达式,比如像查看55*11的结果。 [ora11g@rac1 bin]$ dc 55 11 * p 605 q

du

查看目录的大小,k为k bytes,h代表m bytes [ora11g@rac1 test]$ du -sk . 10968 . [ora11g@rac1 test]$ du -sh . 11M

ex, vi的一种灵活的实现,比如显示第2,3行。查看当前行

[ora11g@rac1 ~]$ vi -E a.lst "a.lst" 3L, 43C Entering Ex mode. Type "visual" to go to Normal mode. :2,3 this is a test line2 := 3 :.= 3 :q [ora11g@rac1 ~]$ ex a.lst "a.lst" 3L, 43C Entering Ex mode. Type "visual" to go to Normal mode. :2,3 this is a test line2 :.= 3 := 3 :q [ora11g@rac1 ~]$

id

查看用户的id和归属的组信息 [ora11g@rac1 test]$ id uid=505(ora11g) gid=501(dba) groups=501(dba)

nl

如果输出的时候需要显示行号,nl也是一个不错的选择。效果和cat -n等价 -bash-4.1$ cat a.txt This price is $5.00 This price is $6.00 this is good -bash-4.1$ nl a.txt 1 This price is $5.00 2 This price is $6.00 3 this is good -bash-4.1$ cat -n a.txt 1 This price is $5.00 2 This price is $6.00 3 this is good

nm

查找共享库中的函数 比如我查看oracle中的一些文件中的函数,可以这样 cd $ORACLE_HOME/rdbms R ----Read only symbol 。比如在代码中有一个const MAXDATA = 110; 则MAXDATA就是一个Read only symbol; N ----一个调试符号; D ----一个已经初始化的变量的符号。比如代码中int i = 1和char *str = "Hello"则i和str都是这种类型的符号 ; T ----Text段的符号。子程序都是这种符号,比如文件中实现了一个函数function,则function就是这种符号; U ----未定义的符号。如果文件中引用了不存在的函数,则这些未定义的函数就是这种类型; S ----未初始化的符号。比如全局变量int s ; 则s就是这种类型的符号。 [ora11g@rac1 lib]$ nm mapsga.o 0000000000000000 r _2__STRING.0.0 0000000000000048 r _2__STRING.1.0 000000000000006c r _2__STRING.10.0 000000000000007c r _2__STRING.11.0 00000000000000c8 r _2__STRING.12.0 0000000000000080 r _2__STRING.13.0 0000000000000098 r _2__STRING.14.0 00000000000000ec r _2__STRING.15.0 0000000000000114 r _2__STRING.16.0 00000000000000a8 r _2__STRING.17.0 00000000000000c4 r _2__STRING.18.0 0000000000000104 r _2__STRING.19.0 000000000000000c r _2__STRING.2.0 000000000000015c r _2__STRING.20.0 000000000000013c r _2__STRING.21.0 00000000000000dc r _2__STRING.22.0 00000000000000fc r _2__STRING.23.0 0000000000000000 r _2__STRING.24.0 0000000000000074 r _2__STRING.3.0 0000000000000018 r _2__STRING.4.0 00000000000000a0 r _2__STRING.5.0 0000000000000024 r _2__STRING.6.0 0000000000000038 r _2__STRING.7.0 000000000000004c r _2__STRING.8.0 000000000000005c r _2__STRING.9.0 U __intel_new_proc_init U exit U fflush U getchar U ksmgsgp_ 0000000000000000 T main 000000000000034a T mapsga_gtln 00000000000003e6 T mapsga_help_msg 0000000000000420 T mapsga_parse U skgsdsegmap U skgsdsegunmap U slosDep2Mesg U slzgetevar U slzprintf U strncat U strncpy

od

显示文件内容为八进制,和它的全名Octal dump是一致的。 [ora11g@rac1 test]$ cat a T 30 b 3 c 50 d 9 e 10 f 2 g 1 h 200 [ora11g@rac1 test]$ od a 0000000 020124 030063 061012 031440 061412 032440 005060 020144 0000020 005071 020145 030061 063012 031040 063412 030440 064012 0000040 031040 030060 000012 0000045 命令中各选项的含义: - A 指定地址基数,包括: d 十进制 o 八进制(系统默认值) x 十六进制 n 不打印位移值 - t 指定数据的显示格式,主要的参数有: c ASCII字符或反斜杠序列 d 有符号十进制数 f 浮点数 o 八进制(系统默认值为02) u 无符号十进制数 x 十六进制数 [ora11g@rac1 test]$ od -Ax -tcx1 a 000000 T 3 0 \n b 3 \n c 5 0 \n d 54 20 33 30 0a 62 20 33 0a 63 20 35 30 0a 64 20 000010 9 \n e 1 0 \n f 2 \n g 1 \n h 39 0a 65 20 31 30 0a 66 20 32 0a 67 20 31 0a 68 000020 2 0 0 \n 20 32 30 30 0a

pr

这个命令是一个很强大的命令,可以完成特殊的行列转换,可以把文件的内容显示为多个垂直列。 和word的分栏功能有些类似。 cat a T 30 b 3 c 50 d 9 e 10 f 2 g 1 h 200 [ora11g@rac1 test]$ pr -h "this is a test for pr" -3 a 2014-07-05 00:56 this is a test for pr Page 1 T 30 d 9 g 1 b 3 e 10 h 200 c 50 f 2

ss

ss命令可以用来获取socket统计信息,它可以显示和netstat类似的内容。 但ss的优势在于它能够显示更多更详细的有关TCP和连接状态的信息,而且比netstat更快速更高效。 [ora11g@rac1 test]$ ss State Recv-Q Send-Q Local Address:Port Peer Address:Port ESTAB 0 52 192.168.3.140:ssh 192.168.3.1:58555 ESTAB 0 0 192.168.3.140:ssh 192.168.3.1:50641 [ora11g@rac1 test]$ ss -i State Recv-Q Send-Q Local Address:Port Peer Address:Port ESTAB 0 52 192.168.3.140:ssh 192.168.3.1:58555 cubic rto:388 rtt:158.75/54 ato:40 cwnd:3 send 220.7Kbps rcv_rtt:202359 rcv_space:20552 ESTAB 0 0 192.168.3.140:ssh 192.168.3.1:50641 cubic rto:357 rtt:141.25/49.75 ato:40 cwnd:5 send 413.5Kbps rcv_rtt:19010 rcv_space:11956 [ora11g@rac1 test]$

tr

tr一般作为sed的精简实现,常用作字符大小写转换。简单的字符替换 像下面的例子,直接将文件a的内容全部转换为大写 [ora11g@rac1 test]$ cat a |tr '[a-z]' '[A-Z]' T 30 B 3 C 50 D 9 E 10 F 2 G 1 H 200

uz

从.gz文件夹中得到文件的目录结构,免去了解压.gz文件然后使用tar -tf这样的步骤,直接一步搞定 [ora11g@rac1 test]$ uz ext_datapump.tar.gz|less Extracting from "ext_datapump.tar.gz". ./ext_datapump/ ./ext_datapump/compare/ ./ext_datapump/compare/tmp_compare.sh ./ext_datapump/compare/batch_compare.sh ./ext_datapump/compare/a.log ./ext_datapump/compare/sqls/

wc

这个命令可以查看文件包含多少行,含有多少字符等等 [ora11g@rac1 test]$ cat test.sh |wc -l 27

xz

xz 是一个使用 LZMA压缩算法的无损数据压缩文件格式。 和gzip与bzip2一样,同样支持多文件压缩,但是约定不能将多于一个的目标文件压缩进同一个档案文件。 xz utils 是 lzma utils 的下一代lzma utils 改名 xz utils。 压缩时 xz utils 耗时比 bzip2 长一倍, 压缩时 xz utils 耗时是 lzma utils 一半, 压缩时 xz utils 生成文件体积是 bzip2 的一半, 压缩时 xz utils 生成文件体积比 lzma utils 略大, 解压时 xz utils 耗时是 bzip2 的三分之一, 解压时 xz utils 速度比 lzma utils 略快, 解压时 xz utils 耗时仅比 gzip 多一倍。 压缩时 xz utils 使用 *.xz 格式 生成文件 比 *.lzma 格式 略大, 压缩时 xz abc.zip 压缩后生成abc.zip.xz文件 解压时,使用xz -d abc.zip.xz 文件就会成为abc.zip

原文发布于微信公众号 - 杨建荣的学习笔记(jianrong-notes)

原文发表时间:2014-07-27

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Spring相关

第2章—装配Bean—自动化装配Bean

CD和CDPlayer,如果你不将CD放入(注入)到播放器中,那么CD播放器其实是没多大用处的,所以说,CD播放器是依赖于CD才能完成它的使命.

692
来自专栏技术墨客

Java数据校验详解

一个健壮的系统都要对外部提交的数据进行完整性、合法性的校验。即使开发一个不面对最终用户的工具包,也需要对传入的数据进行缜密的校验来防止引发底层难以追踪的问题。各...

2131
来自专栏极客编程

用Java为Hyperledger Fabric(超级账本)开发区块链智能合约链代码之部署与运行示例代码

您已经定义并启动了本地区块链网络,而且已构建 Java shim 客户端 JAR 并安装到本地 Maven 存储库中,现在已准备好在之前下载的 Hyperled...

1131
来自专栏JackieZheng

学习SpringMVC——说说视图解析器

  各位前排的,后排的,都不要走,咱趁热打铁,就这一股劲我们今天来说说spring mvc的视图解析器(不要抢,都有位子~~~)   相信大家在昨天那篇如何获取...

24510
来自专栏javathings

Spring 中 Bean 的作用域(必背)

Bean 的作用域,这里的作用域并不是程序代码中,变量的作用范围,而是指对象的创建的模式。Spring 5 之后有如下几个方式:

1242
来自专栏技术墨客

Java数据校验详解

一个健壮的系统都要对外部提交的数据进行完整性、合法性的校验。即使开发一个不面对最终用户的工具包,也需要对传入的数据进行缜密的校验来防止引发底层难以追踪的问题。各...

1152
来自专栏Gaussic

Spring MVC绑定 List 对象参数 原

       最近做的一个小小的项目碰上了如何用 post 传递一整个 list 的问题,在解决这个问题的同时,也顺带升级一下 Spring 的版本,并精简一下...

1441
来自专栏美团技术团队

这个Spring高危漏洞,你修补了吗?

前言 2009年9月Spring 3.0 RC1发布后,Spring就引入了SpEL(Spring Expression Language)。对于开发者而言,引...

1K11
来自专栏Kirito的技术分享

解析Spring中的ResponseBody和RequestBody

spring,restful,前后端分离这些关键词都是大家耳熟能详的关键词了,一般spring常常需要与前端、第三方使用JSON,XML等形式进行交互,你也一定...

2.5K17
来自专栏机器学习从入门到成神

临界区、互斥量、信号量

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/sinat_35512245/articl...

1442

扫码关注云+社区