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应用日志定时清理

  1. 编辑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:强制删除包括目录在内的文件
{} \;:固定写法,一对大括号+空格+\+;
  1. 赋予可执行权限
    chmod +x auto-del-log.sh
    
  2. 设置定时任务

# 进入定时任务编辑界面
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内建变量

  1. NR:NR表示从awk开始执行后,按照记录分隔符读取的数据次数,默认的记录分隔符为换行符,因此默认的就是读取的数据行数,NR可以理解为Number of Record的缩写。
  2. FNR:在awk处理多个输入文件的时候,在处理完第一个文件后,NR并不会从1开始,而是继续累加,因此就出现了FNR,每当处理一个新文件的时候,FNR就从1开始计数,FNR可以理解为File Number of Record。
  3. 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

发表评论

邮箱地址不会被公开。 必填项已用*标注