常用的shell命令整理

时间:2022-01-08 09:50:32

工作快一年了,shell命令也玩了一年了。还是有点积累的,下面是本人常用的。

1、pwd | xargs -i basename {}   获取当前所在目录的名称

2、ps -ef|grep -w  indexd_admin_mcd.pid|grep -v grep|wc -l

ps -ef 查找进程    grep -v  查找不存在  grep -w 强制 PATTERN 仅匹配整个词

查找进程中为 indexd_admin_mcd.pid的进程,并且排除掉grep的进程。最后计数,这样进程的个数。

3、if [ $cn -lt 1 ]   如果cn的值< 1

4、ulimit  -c   最大的core文件的大小,以blocks为单位。    ulimit -c  unlimited  对生成的core文件大小不进行限制。

5、kill

kill -9 pid,是不顾后果的强制终止(如果的你的速度够快,有时候是和ctrl+c是一样的)

kill -15 pid,是先关闭和其有关的程序,再将其关闭

6、crontab

crontab -l    显示crontab中的所有的内容

crontab filename     用新的文件代替crontab里的所有的内容。

所有想在crontab中添加新的自动运行的进程,则先用crontab -l >temp,先将crontab中所有的内容全部重定向到一个新的文件中,然后在这个temp文件后>>追加内容。最后用crontab temp,用temp的文件内容替代crontab的所有的内容。

crontab文件的格式:分  时  日  月  星期

7、$()与‘’的意思相同,获取shell执行后的值,但是用$()会更加的直观。  ${},{}中经常放的是变量,这样在${}就可以精确后面的变量的范围了。

${file#*/}:拿掉第一条/及其左边的字符串: dir1/dir2/dir3/my.file.txt

${file##*/}:拿掉最后一条/及其左边的字符串:my.file.txt

${file#*.}:拿掉第一个.及其左边的字符串:file.txt

${file##*.}:拿掉最后一个.及其左边的字符串:txt

${file%/*}:拿掉最后条/及其右边的字符串:/dir1/dir2/dir3

${file%%/*}:拿掉第一条 / 及其右边的字符串:(空值)

${file%.*}:拿掉最后一个 . 及其右边的字符串:/dir1/dir2/dir3/my.file

${file%%.*}:拿掉第一个 . 及其右边的字符串:/dir1/dir2/dir3/my

8、运算

(( A )) 做运算的,A是任何的运算的表达式 A中的变量可用$来替换,也可以不用。

9、if  判断条件中 $#   和$? 是什么意思?

$#  获取参数的数目my.sh p1 "p2 p3" 为例   $#可得到2

$@ 与 $* 均可获得所有的参数 my.sh p1 "p2 p3" p4 $@ 与 $* 得到p1 p2 p3 p4

但是,如果置于 soft quote 中的话:

"$@" 则可得到 "p1" "p2 p3" "p4" 这三个不同的词段(word)

"$*" 则可得到 "p1 p2 p3 p4" 这一整串单一的词段。

10、在 shell command line 中可用 $? 这个变量得到最新的一个 return value ,也就是刚结束的那个行程传回的值。

* 若在 script 里,用 exit RV 来指定其值,若没指定,在结束时以最后一道命令之 RV 为值。

* 若在 function 里,则用 return RV 来代替 exit RV 即可。

11、重定向输出

* 2>&1 就是将 stderr 并进 stdout 作输出

* 1>&2 或 >&2 就是将 stdout 并进 stderr 作输出

ls my.file no.such.file 2>/dev/null

* 若将 FD1 跟 FD2 转到 /dev/null 去,就可将 stdout 与 stderr 弄不见掉。

* 若将 FD0 接到 /dev/null 来,那就是读进 nothing 。

>/dev/null 2>&1   单纯只跑程序,不想看到任何输出结果  除了用 >/dev/null 2>&1 之外,你还可以&>/dev/null

12、tee复制

所谓 tee 命令是在不影响原本 I/O 的情况下,将 stdout 复制一份到档案去。

cm1 | cm2 | tee file | cm3

在预设上, tee 会改写目标档案,若你要改为增加内容的话,那可用 -a 参数达成。

凡举 cat, more, head, tail, wc, expand, tr, grep, sed, awk, ... 等等文字处理工具,搭配起 pipe line 来使用

13、shell程序的参数

$0   当前程序的执行名字

$n   当前程序的第n个参数值,n=1..9

$*   当前程序的所有参数

$#   当前程序的参数个数

$$   当前程序的PID

$!   执行上一个指令的PID

$?  执行上一个指令的返回值

14、date显示时间

date '+%F %T'    2012-08-27 15:52:54   等同于date +"%Y-%m-%d %T"

date -d '-1 days' +"%Y%m%d"    获取前一天的时间

15、if添加的判断的另一个方式

判断参数的个数

01 if (( $# < 1 ))
02 then
03     echo "Usage: $0 worker_id"
04     exit 1
05 fi
06 if (( $# == 1 ))
07 then
08     WORKER_ID=$1
09     MAX_WORKER_ID=$WORKER_ID
10 elif (( $# > 1 ))
11 then
12     echo "Usage: $0 [worker_id]"
13     exit 1
14 else
15     echo "worker count $WORKER_CNT"
16 fi

这样写if的条件的判断就和c语言的一样了,条件运算

16、ipcs  查看共享内存的使用的情况

ipcrm -M  shmid  关闭共享内存

17、make -p

即使data这个文件夹不存在,也可以创建他的子目录,当然同同时,他也被创建。

mkdir -p /data/coredump

18、head  tail

head 是显示一个文件的内容的前多少行;

head  -n  行数值  文件名;

比如我们显示/etc/profile的前10行内容,应该是:

[root@localhost ~]# head -n 10 /etc/profile

tail 工具,显示文件内容的最后几行,用法比较简单;

tail   -n  行数值  文件名;

比如我们显示/etc/profile的最后5行内容,应该是:

[root@localhost ~]# tail  -n 5 /etc/profile

更多:http://blog.csdn.net/carzyer/article/details/4759593

19、创建软链接

ln -sf  a  b     b链向a

20、export  执行的路径

export LD_LIBRARY_PATH=./

21、if  [ expr ];   then … fi

-n str

字符串 str 是否不为空

-z str

字符串是否为空

str1  = str2

str1是否与 str2 相同

str1 != str2

str1是否与 str2 不同

int1 -eq int2

等于

int1 -le  int2

小于等于

int1 -ge int2

大于等于

int1 -lt   int2

小于

int1 -gt  int2

大于

int1 -ne int2

不等于

-b

是否块文件

-p

文件是否为一个命名管道

-c

是否字符文件

-r

文件是否可读

-d

是否一个目录 *

-s

文件的长度是否不为零

-e

文件是否存在 *

-S

是否为套接字文件

-f

是否普通文件 *

-x

文件是否可执行,则为真

-g

是否设置了文件的 SGID 位

-u

是否设置了文件的 SUID 位

-G

文件是否存在且归该组所有

-w

文件是否可写,则为真

-k

文件是否设置了的粘贴位

-t fd

fd 是否是一个与终端相连的打开的文件描述符(fd 默认为 1)

-O

文件是否存在且归该用户所有

22、for循环

1 for((i=1;i<=100;++i))
2 do
3     echo $i
4 done

23、对一行的第一列进行排重,只保留最新的数据。awk的内置的数组进行排重,排重之后在sort

01 filename=$1
02 awk '
03 {
04     cont[$1] = $0;
05 }
06 END {
07     for (key in cont)
08     {
09     print cont[key];
10     }
11 }' $filename | sort -k1

24、显示上次文件的创建的时间

stat -c %Y $file

25、while循环

http://www.linuxidc.com/Linux/2011-02/32239p2.htm

http://www.cnblogs.com/chengmo/archive/2010/10/14/1851434.html

26、查看当前目录下的文件的大小

du -h --max-depth=1

27、# nohup  ./pso > pso.file 2>&1 &

解释:nohup就是不挂起的意思,将pso直接放在后台运行,并把终端输出存放在当前目录下的pso.file文件中。

当客户端关机后重新登陆服务器后,直接查看pso.file文件就可看执行结果(命令:#cat pso.file )。

http://www.cnblogs.com/xianghang123/archive/2011/08/02/2125511.html

28、将大文件分割为指定大小的文件

http://huangyandong.blog.51cto.com/1396940/690276

split -b 1m 20121018_quey.txt

29、对windows上传的文件进行处理,处理特殊字符

dos2unix over_wap_query_seed.20121023.txt

30、将window的^M回车符号换成linux的

tr -s "[\r]" "[\n]" < log.get

tr -s "[\015]" "\n" < log.get

31、在securecrt软件上显示用户名和ip

echo -ne "\e]2;${USER}@$(/sbin/ifconfig eth1 | awk -F"[ :]+" '/inet addr/{print $4}')\a"

如果你是root用户,把下面上面的那句命令行追加到 /etc/profile

如果你是个人账户,在自己的家目录新建一个 .profile 文件,把命令行追加到.profile文件

32、shell保留两位小数

echo "scale=2; 1*100/3" | bc

33、去掉变量的最后一个字符

AA=abcd

echo $AA | cut -c 1-$(expr ${#AA} - 1)

34、linux下如何查询已知进程运行目录

ls -l /proc/PID/cwd

最后为大家分享两个pdf文档,这是我入门学习shell时候用的。

常用的shell命令整理

原创文章,转载请注明: 转载自成长的企鹅

本文链接地址: 常用的shell命令整理

关于我:成长的企鹅简介