1,查看端口及程序占用情况:
netstat -tlunp | grep ntp
统计ip连接数量:
netstat -nat|awk '{print$5}'|awk -F : '{print$4}'|sort|uniq -c|sort -rn
2,启动shell脚本后台执行(并将执行日志放入到默认的nohup.log):
nohup ./love.sh &
3,Linux命令:要设置当前日期或时间,可用:
date -d mm/dd/yy 及 date -s hh:mm:ss
4,在linux中删除大量文件时,直接用rm会出现:-bash: /bin/rm: 参数列表过长,的错误:
rm test* -rf 改为:
find . -name "test*" | xargs rm -rf "test*"
5查看当前目录下的所有目录的大小,k表示单位(M,G)
ls|xargs du -skh
-s 仅显示总计
-h 以k、m、g为单位,提高信息的可读性。kb、mb、gb是以1024为换算单 位, -h以1000为换算单位
6,查看磁盘占用情况
df -lh
7, 查看调度
crontab -l
8,清理缓存,避免权限不足的问题
echo 3 >/proc/sys/vm/drop_caches
9,查看端口占用情况
netstat -ntlp
10,跨主机copy
scp local_file remote_username@remote_ip:remote_folder
11后台执行程序,并且重定向到日志文件:
nohup java -jar recommend.jar 8 >> D:/home/data/recommend/new/info.log &
scp -r recommend/ root@192.168.1.239:/home/data
12:遍历目录下所有的文件中是否含有【192.168.13.5】字符串。
find . |xargs grep -ri "192.168.13.5" -l
13:shell脚本参数引用:
如下转自:http://blog.youkuaiyun.com/wzygis/article/details/17792403
$$
Shell本身的PID(ProcessID)
$!
Shell最后运行的后台Process的PID
$?
最后运行的命令的结束代码(返回值)
$-
使用Set命令设定的Flag一览
$*
所有参数列表。如"$*"用「"」括起来的情况、以"$1 $2 … $n"的形式输出所有参数。
$@
所有参数列表。如"$@"用「"」括起来的情况、以"$1" "$2" … "$n" 的形式输出所有参数。
$#
添加到Shell的参数个数
$0
Shell本身的文件名
$1~$n
添加到Shell的各参数值。$1是第1参数、$2是第2参数…。
我们先写一个简单的脚本,执行以后再解释各个变量的意义
# touch variable
# vi variable
脚本内容如下:
#!/bin/sh
echo "number:$#"
echo "scname:$0"
echo "first :$1"
echo "second:$2"
echo "argume:$@"
保存退出
赋予脚本执行权限
# chmod +x variable
执行脚本
# ./variable aa bb
number:2
scname:./variable
first: aa
second:bb
argume:aa bb
通过显示结果可以看到:
$# 是传给脚本的参数个数
$0 是脚本本身的名字
$1是传递给该shell脚本的第一个参数
$2是传递给该shell脚本的第二个参数
$@ 是传给脚本的所有参数的列表
14:set -e
你写的每个脚本都应该在文件开头加上set
-e,这句语句告诉bash如果任何语句的执行结果不是true则应该退出。这样的好处是防止错误像滚雪球般变大导致一个致命的错误,而这些错误本应该在之前就被处理掉。如果要增加可读性,可以使用set
-o errexit,它的作用与set -e相同。
-a:标示已修改的变量,以供输出至环境变量。
-b:使被中止的后台程序立刻回报执行状态。
-C:转向所产生的文件无法覆盖已存在的文件。
-d:Shell预设会用杂凑表记忆使用过的指令,以加速指令的执行。使用-d参数可取消。
-e:若指令传回值不等于0,则立即退出shell。
-f:取消使用通配符。
-h:自动记录函数的所在位置。
-H Shell:可利用"!"加<指令编号>的方式来执行history中记录的指令。
-k:指令所给的参数都会被视为此指令的环境变量。
-l:记录for循环的变量名称。 -m:使用监视模式。
-n:只读取指令,而不实际执行。
-p:启动优先顺序模式。
-P:启动-P参数后,执行指令时,会以实际的文件或目录来取代符号连接。
-t:执行完随后的指令,即退出shell。
-u:当执行时使用到未定义过的变量,则显示错误信息。
-v:显示shell所读取的输入值。
-x:执行指令后,会先显示该指令及所下的参数。
-a:标示已修改的变量,以供输出至环境变量。
-b:使被中止的后台程序立刻回报执行状态。
-C:转向所产生的文件无法覆盖已存在的文件。
-d:Shell预设会用杂凑表记忆使用过的指令,以加速指令的执行。使用-d参数可取消。
-e:若指令传回值不等于0,则立即退出shell。
-f:取消使用通配符。
-h:自动记录函数的所在位置。
-H Shell:可利用"!"加<指令编号>的方式来执行history中记录的指令。
-k:指令所给的参数都会被视为此指令的环境变量。
-l:记录for循环的变量名称。 -m:使用监视模式。
-n:只读取指令,而不实际执行。
-p:启动优先顺序模式。
-P:启动-P参数后,执行指令时,会以实际的文件或目录来取代符号连接。
-t:执行完随后的指令,即退出shell。
-u:当执行时使用到未定义过的变量,则显示错误信息。
-v:显示shell所读取的输入值。
-x:执行指令后,会先显示该指令及所下的参数。
刚刚学会了一个很实用的shell命令set -ex,在这里分享一下。
set -e
先说说set -e,这个参数的含义是,当命令发生错误的时候,停止脚本的执行。
通常来说,我们会习惯于使用&&来实现这样的功能,比如:
echo 1 && rm non-existent-file && echo 2
1
但是,写成一行呢,可读性有点差,分成多行的话,也得注意换行符和&&号,我就有过好几次忘了加这俩东西,还是挺麻烦的是吧。
更麻烦的是,&&连接的命令之间不能写注释,也就是说,下面这个示例是不能用的:
echo 1
&& rm non-existent-file
&& echo 2
1
2
3
运行之后会是这个德行:
rm: non-existent-file: No such file or directory
rm: #: No such file or directory
rm: which: No such file or directory
rm: will: No such file or directory
rm: fail: No such file or directory
./test1.sh: line 5: syntax error near unexpected token `&&'
./test1.sh: line 5: ` && echo 2'
1
2
3
4
5
6
7
现在,就可以写成下面这样了:
#!/bin/bash
set -e
echo 1
rm non-existent-file
echo 2
1
2
3
4
5
6
猜猜最后输出里面会不会把2打印出来?
set -x
说完了-e,继续说说-x。-x参数的作用,是把将要运行的命令用一个+标记之后显示出来。
还是拿上面这个脚本举个例子,这次加上-x:
#!/bin/bash
set -ex
echo 1
rm non-existent-file
echo 2
1
2
3
4
5
6
然后它的输出就变成了:
+ echo 1
+ rm non-existent-file
rm: non-existent-file: No such file or directory
1
2
3
注意第一行和第三行前面那个+,这就是-x参数的作用。
写在最后!!!
需要注意,这条命令需要放到整个shell脚本的开头,才会起作用。毕竟稍微想想就知道,这是俩开关,不论放在中间还是结尾,都不会起到预期的作用。
————————————————
版权声明:本文为优快云博主「看见月亮的人」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.youkuaiyun.com/cljdsc/article/details/111906237