Linux 常用命令
1 Spring项目 jar 启动
只输出错误信息到日志文件
nohup java -jar yourProject.jar >/dev/null 2>log &
什么信息也不要
nohup java -jar yourProject.jar >/dev/null 2>&1 &
1. >/dev/null
这条命令的作用是将标准输出1重定向到/dev/null
中。 /dev/null
代表linux的空设备文件,所有往这个文件里面写入的内容都会丢失,俗称“黑洞”。那么执行了>/dev/null
之后,标准输出就会不再存在,没有任何地方能够找到输出的内容。
2. 2>&1
这条命令用到了重定向绑定,采用&可以将两个输出绑定在一起。这条命令的作用是错误输出将和标准输出同用一个文件描述符,说人话就是错误输出将会和标准输出输出到同一个地方。
linux在执行shell命令之前,就会确定好所有的输入输出位置,并且从左到右依次执行重定向的命令,所以>/dev/null 2>&1
的作用就是让标准输出重定向到/dev/null
中(丢弃标准输出),然后错误输出由于重用了标准输出的描述符,所以错误输出也被定向到了/dev/null
中,错误输出同样也被丢弃了。执行了这条命令之后,该条shell命令将不会输出任何信息到控制台,也不会有任何信息输出到文件中
2 Linux应用日志定时清理
- 编辑shell脚本
#!/bin/sh
find /u01/app/logs/ -mtime +10 -name "*.log.*" -exec rm -rf {} \;
说明:
find:Linux查找命令,用户查找指定条件的文件
/u01/app/logs/:需要进行清理的目标目录
-mtime:标准语句写法
+10 :数字代表天数
-name "*.log.*":目标文件的类型,带有log的所有文件
-exec:固定写法
rm -rf:强制删除包括目录在内的文件
{} \;:固定写法,一对大括号+空格+\+;
-
赋予可执行权限
chmod +x auto-del-log.sh
-
设置定时任务
# 进入定时任务编辑界面
crontab -e
# 将auto-del-log.sh执行脚本加入到系统计划任务,到点自动执行 每天凌晨30清理日志
30 0 * * * /root/auto-del-log.sh
# 使任务生效
/sbin/service crond restart
crontab中的同步任务时而成功,时而不成功,什么原因呢?定位问题的关键点,就要通过日志来分析……
- linux
看 /var/log/cron这个文件就可以,可以用tail -f /var/log/cron观察
- unix
在 /var/spool/cron/tmp文件中,有croutXXX001864的tmp文件,tail 这些文件就可以看到正在执行的任务了。
- mail任务
在 /var/spool/mail/root 文件中,有crontab执行日志的记录,用tail -f /var/spool/mail/root 即可查看最近的crontab执行情况。
3 Linux 监控
iotop
iotop 查看某些进程使用了多少你宝贵的 I/O 资源。iostat 命令也能查看 I/O 状态的,但他监控的是系统级别的 I/O 情况,而 iotop 监控的是进程级别的,可以监控到哪一个进程使用的 I/O 信息。
htop
htop 是传统 top 的增强版,具有更好的视觉效果,更容易理解当前系统的状况。可以清楚看到 CPU 每个核儿的使用状况,不像 top 那样隐晦。同样,内存的使用情况也很清晰。不仅有传统的百分比数据,还使用了条形图来显示CPU和内存的度量指标,可读性比 top 好了很多。而且操作也更加便利,例如终止进程可以不用输入进程ID,还可以一次终止多个进程。htop 还有很多便利的操作,推荐用他来替代 top。
日常有用
tail
#查看倒数300行并进入实时监听文件写入模式
tail -300f error.log
grep
grep forest f.txt #文件查找
grep forest f.txt cpf.txt #多文件查找
grep 'log' /home/admin -r -n #目录下查找所有符合关键字的文件
cat f.txt | grep -i shopbase
grep 'shopbase' /home/admin -r -n --include *.{vm,java} #指定文件后缀
grep 'shopbase' /home/admin -r -n --exclude *.{vm,java} #反匹配
seq 10 | grep 5 -A 3 #上匹配
seq 10 | grep 5 -B 3 #下匹配
seq 10 | grep 5 -C 3 #上下匹配,平时用这个就妥了
cat f.txt | grep -c 'SHOPBASE'
awk
awk命令格式和选项
语法形式
awk [options] 'script' var=value file(s)
awk [options] -f scriptfile var=value file(s)
常用命令选项
- -F fs fs指定输入分隔符,fs可以是字符串或正则表达式,如-F:
- -v var=value 赋值一个用户定义变量,将外部变量传递给awk
- -f scripfile 从脚本文件中读取awk命令
- -m[fr] val 对val值设置内在限制,-mf选项限制分配给val的最大块数目;-mr选项限制记录的最大数目。这两个功能是Bell实验室版awk的扩展功能,在标准awk中不适用。
awk以空格为默认分隔符
awk '{print $4,$6}' f.txt #一行一行的读取指定的文件, 打印第4个、6个字段
# NR 表示记录数,在执行过程中对应于当前的行号。
awk '{print NR,$0}' f.txt cpf.txt
# FNR 同NR,但相对于当前文件。
awk '{print FNR,$0}' f.txt cpf.txt
# FILENAME 当前输入文件的名
awk '{print FNR,FILENAME,$0}' f.txt cpf.txt
# NF 表示字段数,在执行过程中对应于当前的字段数。
awk '{print FILENAME,"NR="NR,"FNR="FNR,"$"NF"="$NF}' f.txt cpf.txt
echo 1:2:3:4 | awk -F: '{print $1,$2,$3,$4}'
awk匹配
awk '/ldb/ {print}' f.txt #匹配ldb
awk '!/ldb/ {print}' f.txt #不匹配ldb
awk '/ldb/ && /LISTEN/ {print}' f.txt #匹配ldb和LISTEN
awk '$5 ~ /ldb/ {print}' f.txt #第五列匹配ldb
awk内建变量
- NR:NR表示从awk开始执行后,按照记录分隔符读取的数据次数,默认的记录分隔符为换行符,因此默认的就是读取的数据行数,NR可以理解为Number of Record的缩写。
- FNR:在awk处理多个输入文件的时候,在处理完第一个文件后,NR并不会从1开始,而是继续累加,因此就出现了FNR,每当处理一个新文件的时候,FNR就从1开始计数,FNR可以理解为File Number of Record。
- NF: NF表示目前的记录被分割的字段的数目,NF可以理解为Number of Field。
find
sudo -u admin find /home/admin /tmp /usr -name *.log #(多个目录去找)
find . -iname *.txt #(大小写都匹配)
find . -type d #(当前目录下的所有子目录)
find /usr -type l #(当前目录下所有的符号链接)
find /usr -type l -name "z*" -ls #(符号链接的详细信息 eg:inode,目录)
find /home/admin -size +250000k #(超过250000k的文件,当然+改成-就是小于了)
find /home/admin f -perm 777 -exec ls -l {} ; #(按照权限查询文件)
find /home/admin -atime -1 #1天内访问过的文件
find /home/admin -ctime -1 #1天内状态改变过的文件
find /home/admin -mtime -1 #1天内修改过的文件
find /home/admin -amin -1 #1分钟内访问过的文件
find /home/admin -cmin -1 #1分钟内状态改变过的文件
find /home/admin -mmin -1 #1分钟内修改过的文件
排查利器
btrace
首当其冲的要说的是btrace。真是生产环境&预发的排查问题大杀器。项目地址:https://github.com/btraceio/btrace
arthas
Arthas
是Alibaba开源的Java诊断工具。https://alibaba.github.io/arthas/arthas-tutorials?language=cn&id=arthas-advanced
更多推荐
所有评论(0)