引人入胜,实战讲解,Linux运维面试八股文

通过加粗部分可以看到,系统有着很高的cs值(上下文切换)和us值(用户CPU使用时间),表明系统的上下文切换频繁,用户CPU占用率很高。

注意:vmstat工具可以查看内存、交互分区、I/O操作、上下文

切换、时钟中断及CPU的使用情况。

四,iostat命令

==========

iostat命令可以提供详尽的I/O信息。它的基本使用方式如下:

引人入胜,实战讲解“Java性能调优六大工具”之linux命令行工具

以上命令显示了CPU的使用概况和磁盘I/O的信息。对输出信息每秒采样1次,合计采样两次。如果只需要显示磁盘情况,不需要显示CPU使用情况,则可以使用以下命令:

引人入胜,实战讲解“Java性能调优六大工具”之linux命令行工具

-d 表示输出磁盘的使用情况。在输出结果中,各个列的含义如下:

  • ·tps:该设备每秒的传输次数。

  • ·kB_read/s:每秒从设备读取的数据量。

  • ·kB_wrtn/s:每秒向设备写入的数据量。

  • ·kB_read:读取的总数据量。

  • ·kB_wrtn:写入的总数据量。

如果需要得到更多的统计信息,可以使用-x选项。例如:

引人入胜,实战讲解“Java性能调优六大工具”之linux命令行工具

注意:磁盘I/O很容易成为系统性能的瓶颈。通过iostat命令可以

快速定位系统是否产生了大量的I/O操作。

pidstat工具

=========

pidstat是一个功能强大的性能监测工具,它也是Sysstat的组件之一。读者可以

http://www.icewalkers.com/Linux/Software/59040/Sysstat.html上下载这个工具。下载后,通过./configure、make和makeinstall三个命令即可安装pidstat工具。pidstat的强大之处在于,它不仅可以监视进程的性能情况,也可以监视线程的性能情况。本小节将详细介绍pidstat的功能。

1.CPU使用率监控

下面是一个简单的占用CPU的程序,它开启了4个用户线程,其中1个线程大量占用CPU资源,其他3个线程则处于空闲状态。

引人入胜,实战讲解“Java性能调优六大工具”之linux命令行工具

运行以上程序,要监控该程序的CPU使用率,可以先使用jps命令找到Java程序的PID,然后使用pidstat命令输出程序的CPU使用情况。执行命令如下:

引人入胜,实战讲解“Java性能调优六大工具”之linux命令行工具

引人入胜,实战讲解“Java性能调优六大工具”之linux命令行工具

其中,pidstat的参数-p用于指定进程ID,-u表示对CPU使用率的监控,最后的参数1和3分别表示每秒采样1次与合计采样3次。从输出结果中可以看到,该应用程序的CPU占用率几乎达到100%。pidstat的功能不仅限于观察进程信息,它还可以进一步监控线程的信息,执行命令如下:

引人入胜,实战讲解“Java性能调优六大工具”之linux命令行工具

该命令的部分输出结果如下:

引人入胜,实战讲解“Java性能调优六大工具”之linux命令行工具

-t参数将系统性能的监控细化到线程级别。从输出结果中可以看到,该Java应用程序之所以占用如此高的CPU,是因为线程1204的缘故。

注意:使用pidstat工具不仅可以定位到进程,甚至可以进一步定位到线程。

使用以下命令可以导出指定Java应用程序的所有线程。

引人入胜,实战讲解“Java性能调优六大工具”之linux命令行工具

在输出的t.txt文件中可以找到这样一段输出内容:

引人入胜,实战讲解“Java性能调优六大工具”之linux命令行工具

从加粗的文字可以看到,这个线程正是HoldCPUTask类,它的nid(nativeID)为0x4b4,转为十进制后正好是1204。

通过这个方法,开发人员可以使用pidstat很容易地捕获在Java应用程序中大量占用CPU的线程。

2.I/O使用监控

磁盘I/O也是常见的性能瓶颈之一。使用pidstat也可以监控进程内线程的I/O情况。下面的代码开启了4个线程,其中,线程HoldIOTask产生了大量的I/O操作。

引人入胜,实战讲解“Java性能调优六大工具”之linux命令行工具

引人入胜,实战讲解“Java性能调优六大工具”之linux命令行工具

在程序运行过程中,使用以下命令监控程序I/O的使用情况:

引人入胜,实战讲解“Java性能调优六大工具”之linux命令行工具

其中,22796是通过jps命令查询到的进程ID,-d参数表明监控对象为磁盘I/O,1和3分别表示每秒采样1次,合计采样3次。

从输出结果中可以看到,进程中的22813(0x591D)线程产生了大量的I/O操作。通过前文中提到的jstatck命令可以导出当前线程的堆栈,查找nid为22813(0x591D)的线程,即可定位到HoldIOTask线程。

注意:使用pidstat命令可以查看进程和线程的I/O信息。

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Linux运维工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Linux运维全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Linux运维知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加VX:vip1024b (备注Linux运维获取)
img

最全的Linux教程,Linux从入门到精通

======================

  1. linux从入门到精通(第2版)

  2. Linux系统移植

  3. Linux驱动开发入门与实战

  4. LINUX 系统移植 第2版

  5. Linux开源网络全栈详解 从DPDK到OpenFlow

华为18级工程师呕心沥血撰写3000页Linux学习笔记教程

第一份《Linux从入门到精通》466页

====================

内容简介

====

本书是获得了很多读者好评的Linux经典畅销书**《Linux从入门到精通》的第2版**。本书第1版出版后曾经多次印刷,并被51CTO读书频道评为“最受读者喜爱的原创IT技术图书奖”。本书第﹖版以最新的Ubuntu 12.04为版本,循序渐进地向读者介绍了Linux 的基础应用、系统管理、网络应用、娱乐和办公、程序开发、服务器配置、系统安全等。本书附带1张光盘,内容为本书配套多媒体教学视频。另外,本书还为读者提供了大量的Linux学习资料和Ubuntu安装镜像文件,供读者免费下载。

华为18级工程师呕心沥血撰写3000页Linux学习笔记教程

本书适合广大Linux初中级用户、开源软件爱好者和大专院校的学生阅读,同时也非常适合准备从事Linux平台开发的各类人员。

需要《Linux入门到精通》、《linux系统移植》、《Linux驱动开发入门实战》、《Linux开源网络全栈》电子书籍及教程的工程师朋友们劳烦您转发+评论

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
img

从事Linux平台开发的各类人员。**

需要《Linux入门到精通》、《linux系统移植》、《Linux驱动开发入门实战》、《Linux开源网络全栈》电子书籍及教程的工程师朋友们劳烦您转发+评论

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-JDSfRBx5-1712627401316)]

  • 5
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值