生产环境中常用Linux命令

news2025/2/27 8:10:02

太简单的我就不讲解啦,浪费时间,直接将生产中常用的

文章目录

  • 1.总纲
  • 2.整机 top
  • 3.CPU vmstat
  • 3. 内存 free
  • 4. 硬盘: df
  • 5. 磁盘IO iostat
  • 6. 网络IO ifstat
  • 7: 内存过高的情景排查

1.总纲

  1. 整机:top
  2. cpu:vmstat
  3. 内存:free
  4. 硬盘:df
  5. 磁盘io: iostat
  6. 网络io:ifstat

2.整机 top

首先们要查询整机的状况 top -H
在这里插入图片描述
如果三个值得综合/3*100%>60% 就说明负担有点高啦,按下q按键退出

其中uptime命令为负载均衡的精简版窗口
在这里插入图片描述

3.CPU vmstat

命令 vmstat -n 2,3 2秒的时间,采样3个数据
在这里插入图片描述
在这里插入图片描述

扩展:
查看所有的CPU核信息:mpstat -P ALL 2 每两秒采样一次
每个进程使用CPU的用量分解信息 pidstat -u 1 -p 进程编号

3. 内存 free

free -m 以MB的形式显示,更加精确
在这里插入图片描述

(如果没有安装,请执行 yum install sysstat)
扩展:查看额外内存 pidstat -p 进程号 -r 采样的间隔数
MEN 展示 的这个进程占用内容的百分比
在这里插入图片描述

top
top -Hp pid
printf %x 11129
jstack -l 11095 |grep 11129 >> jstack.log


按进程的CPU使用率排序

运行top命令后,键入大写P。

有两种途径:

a) 打开大写键盘的情况下,直接按P键

b) 未打开大写键盘的情况下,Shift+P键

按进程的内存使用率排序

运行top命令后,键入大写M。

有两种途径:

a) 打开大写键盘的情况下,直接按M键

b) 未打开大写键盘的情况下,Shift+M键


4. 硬盘: df

df -h 查看磁盘剩余空间数
du * -h | sort -hr | head -100 , 由大到小,查询前100个送占用磁盘的文件路径
du /home -h | sort -hr | head -100 , 自定义路径
在这里插入图片描述
顺便分享下MySQL磁盘的定位分析

//不用做修改,查看当前mysql连接下,每个库的总大小
select TABLE_SCHEMA, concat(truncate(sum(data_length)/1024/1024/1024,2), 'GB') as data_size, concat(truncate(sum(index_length)/1024/1024,2),'MB') as index_size 
from information_schema.tables 
group by TABLE_SCHEMA 
order by data_length desc;

//修改 tp 数据库的名称,查看当前数据库下,每个表的总大小
select TABLE_NAME, concat(truncate(data_length/1024/1024/1024,2),'GB') as data_size, concat(truncate(index_length/1024/1024/1024,2), 'GB') as index_size 
from information_schema.tables where TABLE_SCHEMA = 'tp' 
group by TABLE_NAME 
order by data_length desc;

5. 磁盘IO iostat

参数含义

-c: 显示CPU使用情况
-d: 显示磁盘使用情况
-N: 显示磁盘阵列(LVM) 信息
-n: 显示NFS 使用情况
-k: 以 KB 为单位显示
-m: 以 M 为单位显示
-t: 报告每秒向终端读取和写入的字符数和CPU的信息
-V: 显示版本信息
-x: 显示详细信息
-p:[磁盘] 显示磁盘和分区的情况

具体的使用

iostat -xdk 2 3

每隔2秒,显示一次设备统计信息.总共输出3次, 显示的单位以kb为单位

结果参数说明

在这里插入图片描述

具体参数参数含义
rkB/s每秒读取数据量kb
wkB/s每秒写入数据量Kb
svctmI/O请求的平均时间,单位毫秒
awaitI/O请求的平均等待时间,单位毫秒,值越小,性能越好
util一秒钟有百分几的时间用于处理I/O操作,当达到100%时,标识磁盘宽带跑满,需要优化程序或者增加磁盘,是重要的指标

排查总结

  1. 如果 %util 接近 100%,说明产生的I/O请求太多,I/O系统已经满负荷该磁盘可能存在瓶颈。
  2. 如果 svctm 比较接近 await,说明 I/O 几乎没有等待时间;
  3. 如果 await 远大于 svctm,说明I/O 队列太长,io响应太慢,则需要进行必要优化。
  4. 如果avgqu-sz比较大,也表示有当量io在等待

单独进程的磁盘IO pidstat -d 2 -p 进程号

6. 网络IO ifstat

默认本地是没有网络IO,下载ifstat

  1. wget http://gael.roualland.free.fr/ifstat/ifstat-1.1.tat.gz
  2. tar ifstat-1.1.tat.gz
  3. cd ifstat-1.1
  4. ./configure
  5. make
  6. make install

在这里插入图片描述

7: 内存过高的情景排查

1: 利用top命令,得到占用内存最高的进程PID

top

在这里插入图片描述
2.查看此进程中占用CPU较高的线程排行

ps -mp PID(这里替换) -o THREAD,tid,time|sort -rn|head -n 20

在这里插入图片描述

3.将此线程id转换成16进制,为我们接下来的操作做准备。

printf "%x\n" tid

4:用jstack查看一下

jstack pid |grep tid -A 30

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1087441.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

阿里云服务器10M带宽收费价格表

阿里云服务器10M公网带宽收费价格表,地域不同带宽价格不同,阿里云百科以华东2(杭州)地域为例,阿里云10M带宽一年85折优惠价格5355元,10M带一个月525元,阿里云百科aliyunbaike.com分享阿里云服务…

第二证券:全涨停,上市以来首次!

10月12日,国内产品商场大面积飘红,其间有色、化工板块上涨明显,碳酸锂期货自本年7月份上市以来初次呈现合约悉数触及涨停,到收盘时,主力合约LC2401上涨10750元/吨,涨幅6.97%,报164950元/吨。 碳…

pytorch学习第三篇:梯度

下面介绍了在pytorch中如何进行梯度运算,并介绍了在运行梯度计算时遇到的问题,通过解决一个个问题,来深入理解梯度计算。 梯度计算 import torch x = torch.rand(3,4,requires_grad=True) b = torch.rand(4,3,requires_grad=True) print(x,b)y = x@bt = y.sum()求导数 t.…

CrossOver2024下载安装详细图文教程

本文将集中为各位小伙伴们介绍一下类虚拟机软件CrossOver Mac是如何进行下载、安装教程。 1、双击下载好的文件(若为压缩文件,请先解压),随后弹出“是否要把程序移动到应用程序文件夹中?”,一般我们选择移…

快排超详细,Leetcode排序数组题目带你升华掌握

大家好,这里是Dark FalmeMater。 这篇文章我将超级仔细地讲解快速排序,快排之所以叫快排,到底有多快,为什么这么快,还有快速排序的优化和改进,通过这篇文章你一定会对快排有进一步的掌握。 文章目录 Hoare版…

消息队列缓存,以蓝牙消息服务为例

前言 消息队列缓存,支持阻塞、非阻塞模式;支持协议、非协议模式 可自定义消息结构体数据内容 使用者只需设置一些宏定义、调用相应接口即可 这里我用蓝牙消息服务举例 有纰漏请指出,转载请说明。 学习交流请发邮件 1280253714qq.com 原…

4D视频数据集

RealGraph: A Multiview Dataset for 4D Real-world Context Graph Generation RealGraph是一个全新的4D视频数据集,旨在支持“Context Graph Generation (CGG)”任务。CGG任务的目标是从动态场景的校准多视图视频中恢复出物体的语义信息,包括坐标、轨迹…

Idea报错 java: 程序包org.springframework.boot不存在 解决方法

发现我的是因为更改了maven的主路径和本地仓库路径,但是新建了一个工程后,设置就恢复默认了。需要重新设置正确路径。 应用后会重新下载依赖项 之后虽然还会报错,但是已经不影响项目运行,配置成功

高速数字化仪和AWG在车辆总线(CAN/LIN/PSI5)测试中的应用(一)

引言 模块化仪器比传统仪器的尺寸大大减小,适合安装在电路卡上,同时也可以将多个卡插入具有通用计算机接口、电源和互连的框架中。模块化仪器框架包括使用标准PCIe接口的计算机、PXI测试框架或基于LXI的盒子,工程师通常会使用多个卡并将其配…

基于Docker-compose搭建LNMP

1、配置nginx 创建nginx目录上传所需压缩包将wordress解压到指定路径下 配置Dockerfile文本文件 vim DockerfileFROM centos:7 MAINTAINER this is nginx image <zgc> RUN yum -y install pcre-devel zlib-devel gcc gcc-c make RUN useradd -M -s /sbin/nologin nginx…

【RcoketMQ】RcoketMQ 5.0新特性(二)- Pop消费模式

Pop模式消费和消息粒度负载均衡 在RocketMQ 5.0之前&#xff0c;消费有两种方式可以从Broker获取消息&#xff0c;分别为Pull模式和Push模式。 Pull模式&#xff1a;消费需要不断的从阻塞队列中获取数据&#xff0c;如果没有数据就等待&#xff0c;这个阻塞队列中的数据由消息…

springBoot 自动配置机制

springBoot 自动配置机制 自动配置的tomcat、springmvc等默认包扫描规则自定义扫描路径配置默认值按需加载自动配置总结 自动配置的tomcat、springmvc等 导入场景&#xff0c;容器中就会自动配置好这个场景的核心组件 以前&#xff1a;dispatcherservlet、viewresolver、chara…

MyCat分片规则

MyCat是一个开源的数据库中间件&#xff0c;它可以实现对MySQL数据库进行分片和负载均衡。在分片规则方面&#xff0c;MyCat支持以下几种常见的分片方式&#xff1a; 范围分片 根据指定的字段及其配置的范围与数据节点的对应情况&#xff0c; 来决定该数据属于哪一个分片。 …

LeetCode【438】找到字符串中所有字母异位词

题目&#xff1a; 注意&#xff1a;下面代码勉强通过&#xff0c;每次都对窗口内字符排序。然后比较字符串。 代码&#xff1a; public List<Integer> findAnagrams(String s, String p) {int start 0, end p.length() - 1;List<Integer> result new ArrayL…

Leetcode——统计数组中的元素练习

错误的集合 此题没做出来 class Solution { public:vector<int> findErrorNums(vector<int>& nums) {vector<int> errorNums(2);int n nums.size();sort(nums.begin(), nums.end());// 记录上一个元素int prev 0;for (int i 0; i < n; i) {int cu…

什么是指标体系,怎么搭建一套完整的指标体系?(附PDF素材)

什么是指标体系&#xff0c;怎么搭建一套完整的指标体系&#xff1f;数字化转型过程中&#xff0c;这个问题一直困扰着数据分析师。主要体现在&#xff1a; 各部门根据业务需求&#xff0c;都有一部分量化指标&#xff0c;但不够全面&#xff0c;对企业整体数据分析应用能力提…

4.0 Beta2版本编译RK3588错误问题解决

最近有小伙伴在问4.0 Beta2版本编译RK3588&#xff08;也就是dayu210&#xff09;时&#xff0c;会有各种莫名奇妙的报错 &#xff08;1&#xff09;subsystem name config incorrect in ....... 这个原因是OH代码加入了编译检查&#xff0c;临时措施是把需要编译检查的文件放…

提升自媒体影音创作效率,这 10 款 AI 工具打工人必备!

随着AI工具的不断涌现&#xff0c;自媒体影音创作的效率也得到了提升&#xff0c;本次为大家介绍10款AI影音工具&#xff0c;为你的自媒体创作助力&#xff01; 还是先上一张脑图&#xff1a; 自媒体必备AI工具 1. Runway AI视频编辑工具&#xff0c;支持文字转视频 目前最…

Elasticsearch:使用 Langchain 和 OpenAI 进行问答

这款交互式 jupyter notebook 使用 Langchain 将虚构的工作场所文档拆分为段落 (chunks)&#xff0c;并使用 OpenAI 将这些段落转换为嵌入并将其存储到 Elasticsearch 中。然后&#xff0c;当我们提出问题时&#xff0c;我们从向量存储中检索相关段落&#xff0c;并使用 langch…