`
cfyme
  • 浏览: 274954 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

(转载)java问题排查常用linux命令

 
阅读更多

 最近部门的测试环境总是半夜挂掉,有感于线上问题排查的种种困惑,所以打算彻底扫盲一下问题排查的一些关键命令,在真正火灾来临的时候,能够迅速的定位问题。

    重用的linux命令总体分为几个大类,以前自己觉得,这些命令,在用的时候现查就行,但是经历了几次事情之后,我觉得对于这些工具在问题真正来临的会后需要灵活运用,灵活运用需要平时对这些就很熟悉,自己很多没有熟悉,所系需要恶补一下,在问题真正来临的时候,自己能够冷静准确的处理问题。

 

(1)ping :

功能是检测主机,执行ping指令会使用ICMP传输协议,发出要求回应的信息,若远端主机的网络功能没有问题,就会回应该信息,因而得知该主机运作正常。 

 

(2)  netstat:
显示与IP、TCP、UDP和ICMP协议相关的统计数据,一般用于检验本机各端口的网络连接情况。
·netstat –s
本选项能够按照各个协议分别显示其统计数据。如果我们的应用程序(如Web浏览器)运行速度比较慢,或者不能显示Web页之类的数据,那么我们就可以用本选项来查看一下所显示的信息。我们需要仔细查看统计数据的各行,找到出错的关键字,进而确定问题所在。
·netstat –e
本选项用于显示关于以太网的统计数据。它列出的项目包括传送的数据报的总字节数、错误数、删除数、数据报的数量和广播的数量。

·netstat –a
本选项显示一个所有的有效连接信息列表,包括已建立的连接(ESTABLISHED),也包括监听连接请(LISTENING)的那些连接。
·netstat –n
显示所有已建立的有效连接。

 

(3)hostname
显示或设置系统的主机名;如果无任何选项和主机名,则用于显示系统的主机名。

在看这个命令的时候想起了windows中修改host文件来进行测试,这里顺便了解了一下host文件的作用。

Hosts文件是一个纯文本的文件,用普通的文本编辑软件如记事本等都能打开。 


Hosts文件的格式: 
这个文件包含IP地址到HOST name(主机名)的映射关系.每一条独自占有一行. 
IP地址应该放在第一位,后面应该紧跟着Host name. IP地址与Host name之间应该被最少一个空格隔开.对于每行的映射说明,用“#”分割后用文字说明。 
Hosts文件在Windows中的用途: 
访问某个网站通常是根据域名访问,比如:http://www.9usb.net.我们在浏览器中输入以上域名后,后台就首先通过DNS服务器把网络域名www.9usb.net解析成173.XXX.XXX.XXX的IP地址后,我们的计算机才能访问。要是对于每个域名请求我们都要等待域名服务器解析后返回IP信息,这样访问网络的效率就会降低。 
Hosts文件起作用的地方就是在由域名转换成IP的过程中。hosts文件在本地保存了一个域名和IP地址的映射,能提高解析效率。Windows系统在进行DNS请求以前,Windows系统会先检查Hosts文件中是否有这个地址映射关系,如果有则调用这个IP地址映射,如果没有再向已知的DNS服务器提出域名解析。 
Hosts的请求级别比DNS高。 


Host文件在具体使用中的作用 
1.绕开DNS请求,节省域名解析时间 
对于要经常访问的网站,我们可以通过在Hosts中配置域名和IP的映射关系,这样当我们输入域名计算机就能很快解析出IP,而不用请求网络上的DNS服务器。在本地进行域名解析比请求DNS服务器进行转换要省时间,这大大加快了访问速度。 
2.方便局域网用户 
通常局域网一般不会架设DNS服务器,访问某些服务要输入难记的IP地址,这就比较不方便。现在可以分别给这些服务器取个容易记住的名字,然后在Hosts中建立IP映射,这样以后访问的时候我们输入这个服务器的名字就OK了。 
3、屏蔽网站和解屏蔽网站 
4.顺利连接系统 

 

(4)uptime

linux系统中的uptime命令主要用于获取主机运行时间和查询linux系统负载等信息。
uptime命令可以显示系统已经运行了多长时间,信息显示依次为:现在时间、系统已经运行了多长时间、目前有多少登陆用户、系统在过去的1分钟、5分钟和15分钟内的平均负载。
uptime命令用法十分简单:直接输入uptime即可.

例如: 17:07:22 up 79 days, 17:57,  1 user,  load average: 0.08, 0.08, 0.02

 

(5)TOP

 

TOP显示的内容详解

 

在TOP命令运行的过程中,点击下面的键,可以进行进一步的显示。

 

(1)u:指定显示用户进程。

(2)1 :显示每个CPU的统计信息。

(3)P:按%CPU使用率排行。shift+p。

(4)M:按%MEM排行。shift+m。

(5)<Space>:立即刷新。

(6)-H : 显示线程。当这个设定开启时,将显示所有进程产生的线程。

(7)-p : 监控指定的进程。当监控多个进程时,进程ID以逗号分隔。这个选项只能在命令行下使用。

 

 

 

 

---------------------------------------------------------------------------------------

 

  • 查看java进程中各个线程占用CPU以及内存情况

top -H -p `pgrep java -u admin`

  • 加入看到8440这个线程有异常,进制转换

printf '0x%x\n' 8440

  • 看这个线程在做什么事情

sudo -u admin /opt/taobao/java/bin/jstack `pgrep java -u admin` | grep -C 20 0x20f8 –color

 

---------------------------------------------------------------------------------------

 

 

 

(6)sar

sar 的主要作用:

主要负责收集、汇报与存储系统运行信息的。有两个参数非常非常常用,就是“时间间隔”和“输出次数”。默认输出CPU的信息,但是内存、Load、IO的情况都可以查看

1、把sar输出的信息保存到文件中,只要  -o filename即可,不过在看次文件的时候,需要sar  -f  filename   否则通过cat看到的是乱码

2、CPU是多核的情况下,查看每一下的情况已经统计情况,

    sar -P ALL   显示每一核的情况已经总体情况

    sar -P 数字  显示特定CPU的情况

 

    

3、查看历史的sar的情况

     sar   -u(r/q/) -f    /var/log/sa/sa01    最后一个为具体的日志(sa+日期中的天数)

4、sar -q  查看load的情况

 

    

5、sar -r  查看内存

  

 

6、sar -n  查看网络情况

 

 

 

 

 

 

(7)vmstat

 

 

(8)ps

 

 

(9)grep/egrep/fgrep

 

 

(10)awk

 

(11)kill

 

 

(12)mapstat

 

 

(13)iostat

 

(14)df/du

 

(15)

 

 

系统配置相关:
 
查看内核/操作系统/CPU信息: uname -a
 
查看操作系统版本: head -1 /etc/issue
 
查看网卡信息:cat  /sbin/ifconfig
 
查看cpu配置: cat /proc/cpuinfo
 
查看mem配置:cat /proc/meminfo
 
查看环境变量 资源: env 
 
查看各分区使用情况:  df -h
 
查看指定目录的大小: du -sh
 
查看系统负载 磁盘和分区: cat /proc/loadavg 

查看挂接的分区状态:  mount | column -t 

查看hosts配置:cat
 /etc/hosts
 
查看所有网络接口的属性: ifconfig 
 
查看路由表: route -n
 
查看tcp协议配置(ipv4):  /proc/sys/net/ipv4
 
 
性能分析相关工具:
 
ps,pstree: 命令是系统分析最常用的基本命令,ps命令提供了一个正在运行的进程的列表,列出进程的数量取决于命令所附加的参数。
 
uptime: 查看系统运行时间、用户数、负载
 
top :实时显示cpu负载、进程资源占用
 
vmstat:整体性能监控,cpu,mem,页面io等。
 
free: free命令显示系统的所有内存的使用情况,包括空闲内存、被使用的内存和交换内存空间。Free命令显示也包括一些内核使用的缓存和缓冲区的信息。
-m  以M形式展示数据
-g 以G形式展示数据
 
 
pmap: pmap命令显示一个或者多个进程使用内存的数量,你可以用这个工具来确定服务器上哪个进程占用了过多的内存从而导致内存瓶颈。
 
iostat:iostat是sysstat包的一部分。Iostat显示自系统启动后的平均CPU时间(与uptime类似),它也可以显示磁盘子系统的使用情况,iostat可以用来监测CPU利用率和磁盘利用率。
 
sar: sar也是sysstat安装包的一部分。sar命令用于收集、报告和保存系统的信息。
 
mpstat: mpstat命令也是sysstat包的一部分。Mpstat命令用于监测一个多CPU系统中每个可用CPU的情况。Mpstat命令可以显示每个CPU或者所有CPU的运行情况
 
ulimit: 可以通过ulimit来控制系统资源的使用。
 
 
java应用性能分析:
 
jmap(配合jhat分析heapdump)、jstat、jconsole、jvisualvm、jprofiler、visualGC等等多种多样。
 
 
 
查看进程和端口号相关netstat:
 
Netstat 用于显示与IP、TCP、UDP和ICMP协议相关的统计数据,一般用于检验本机各端口的网络连接情况。
通过netstat可以查看网络连接、端口号等占用情况
 
查看TCP/UDP端口:netstat -tuoln

查看进程名运行的端口号:netstat -anp|grep 进程名
当需要监控某个服务的端口号时可以首先获取该服务的监听端口号,如tomact进程
netstat -anp|grep tomcat
 
 根据端口查看运行的进程:
netstat -anp|grep 端口号  或  lsof -i:端口号
通常用于查看某个端口号下建立的连接数,如8083端口号下的连接数统计:
netstat -anp|grep:8083|wc -l 

netstat -tln 查看服务监听端口
 
查看进程   ps aux
 
查看指定服务的进程号,如tomcat服务: ps aux|grep tomcat
结束进程   kill -15 pid 立即释放资源; kill -9 pid 不会立即释放资源 
 
查看特定文件中特定文本的个数
egrep -o "[A-Z|a-z]\w*""Exception" map.log | sort | uniq -c | sort –nr   
 
 
最后制定定时执行任务,合理利用空闲时间:
 
crontab -e: 设置计划任务;
 
分享到:
评论

相关推荐

    linux 常用命令,玩转linux,服务端研发常用排查问题命令

    linux 常用命令,玩转linux,服务端研发常用排查问题命令

    车载常用linux命令+火车/高铁/公交车行业+车载linux系统测试常用命令,用于测试职位或运维技术支持职位

    在IT行业中,Linux系统是许多车载设备和交通系统的首选操作系统,因为它的稳定性和...总之,熟练掌握这些Linux命令对于车载Linux系统测试和运维工作至关重要,它们能帮助我们高效地进行系统管理、故障排查和性能优化。

    常用Linux命令.pdf

    描述中提到文档是“最常用的Linux命令总结”,这说明文档内容是针对Linux系统中经常使用的命令进行的汇编,可能覆盖了系统的各个方面,从基础操作到复杂的问题排查。同时,文档强调了“全面性”,意味着内容可能会...

    Java虚拟机调优及问题排查手册.docx

    Java虚拟机调优及问题排查手册 本手册主要介绍Java虚拟机(JVM)的调优和问题排查解决方案。该手册涵盖了JVM排查、数据库连接排查、堆栈快照排查等多方面的内容。 JVM排查 JVM排查是指通过各种命令和工具来排查...

    Java常见问题排查

    ### Java常见问题排查 #### NoSuchMethodException **出现原因:** `NoSuchMethodException`异常通常发生在尝试通过反射机制调用类的方法时,该类没有对应签名的方法。这可能是因为类库版本不一致导致方法签名的...

    linux常用命令大全

    以上仅是Linux命令的冰山一角,随着实践的深入,你将逐渐熟悉更多高级命令,如文本处理工具`sed`和`awk`、日志分析工具`logrotate`等,这些都将在日常的系统维护和开发工作中发挥重要作用。Linux命令的学习是一个...

    Linux常用命令文档和命令大全

    本压缩包文件"Linux常用命令文档和命令大全"包含了两份宝贵的资源,分别是"Linux命令大全(修改版).chm"和"Linux学习笔记.doc",它们都是深入理解和熟练掌握Linux操作系统的宝贵资料。 "Linux命令大全(修改版).chm...

    Linux命令大全完整版.pdf

    本文将详细解读《Linux命令大全完整版.pdf》中所收录的各类命令,以帮助读者更好地理解和运用Linux命令。 1. Linux系统管理命令 系统管理命令是Linux系统中最重要的命令类别之一,涵盖了用户管理、进程控制、系统...

    JAVA线上问题排查和工具.pdf

    JAVA线上问题排查和工具 内容详细 结合实际工作 贴合实际

    Linux常用命令-API手册.zip

    本压缩包"Linux常用命令-API手册.zip"包含了两个重要的参考资料:"Linux基础命令教程豪华版.chm"和"Linux常用命令大全.chm",它们为用户提供详尽的Linux命令学习指南。 "Linux基础命令教程豪华版.chm"可能是对Linux...

    Java线上故障排查方案(2).pdf

    在故障排查时,常见的Linux命令也必须掌握。比如,使用top或htop命令查看实时的系统状态,使用vmstat、iostat等命令来检查内存和I/O性能,以及使用netstat检查网络连接状态等。 Arthas是一个Java诊断工具,其提供了...

    linux下常用排查命令_2021_2_241

    Linux 操作系统提供了许多实用的命令来排查和解决问题。以下是 Linux 下常用排查命令的整理。 用户信息 * `/etc/passwd` 文件用于存储用户信息 * `/etc/shadow` 文件用于存储用户密码信息 * `awk -F: '$3==0{print...

    Linux常用命令全集

    这份"Linux常用命令全集"的文档集合,旨在帮助用户理解和熟练运用各种Linux命令,从而更高效地管理系统、进行文件操作、网络通信以及系统维护。 1. **文件与目录操作** - `cd`: 改变当前工作目录,如`cd /home/...

    linux常用命令手册中文版

    "Linux常用命令手册中文版"为学习和查阅Linux命令提供了极大的便利。这个压缩包包含了两份资源——"Linux命令大全(Linuxidc.com修改版).chm"和"Linux命令大全(Linuxidc.com修改版).chw"。这两个文件很可能是同一个...

    常用Linux命令1

    以下是一些关于常用Linux命令的详细解释: 1. **ls** 命令:`ls` 是 `list` 的缩写,用于列出目录内容。当你运行 `ls` 时,它会显示当前目录下的非隐藏文件和目录。如果想要显示所有文件,包括隐藏文件(以`.`开头...

    java内存泄露、溢出检查方法和工具

    1. **生成堆转储文件**:在Linux环境中,可以使用JVM提供的`jmap`命令生成堆转储文件。例如,如果Java进程的PID为12345,可以执行`jmap -dump:format=b,file=heapdump.hprof 12345`,这会在当前目录下创建一个名为`...

    linux常用命令 linux常用命令

    以下是一些基本的Linux命令及其用途: 1. **man** 命令:这是Linux中最核心的命令之一,用于查看其他命令的详细使用手册。只需输入`man`后跟你要查询的命令,如`man ls`来查看`ls`命令的用法。 2. **ls**:列出...

    linux常用命令大全.md

    Linux命令的掌握程度直接影响到工作效率,因此对于每一位使用Linux的用户来说,熟练地使用和理解这些常用命令是非常必要的。Linux命令的灵活性和多样性为用户提供了强大的操作能力,但同时也需要用户对命令有深入的...

    python-常用linux命令.docx

    以下是一些Python开发者常用的Linux命令详解: 1. **cd命令**:`cd`命令用于改变当前工作目录,这对于在不同的项目路径之间切换至关重要。例如,如果你的工作目录在`/home/user/project`,你可以通过`cd /home/user...

Global site tag (gtag.js) - Google Analytics