重新整理 .net core 实践篇 ———— linux上排查问题 [外篇]
前言
简单介绍一下在排查问题。献给初学者。
该文的前置篇:
https://www.cnblogs.com/aoximin/p/16838657.html
正文
什么是linux系统
linux 是基于名为procfs的特殊文件系统。
linux 有一句著名的话,一切皆文件。
通常,数据会在启动时映射到名为 /proc 的装入点。 proc 文件系统充当内核中内部数据结构的接口。 可以使用该文件获取有关系统的信息,并在运行时更改某些内核参数 (sysctl) 。
进程被视为 /proc/ 目录下的文件。 此目录在此处定义为特殊目录:
“此特殊目录保存有关 Linux 系统的所有详细信息,包括其内核、进程和配置参数。
举个例子,比如你要查看内存,你可以使用free。
然后你还可以使用:
cat /proc/meminfo

比如查看cpu信息:

可以看到我的cpu 是i5 7500,好多年的电脑了,当年也是很好的。
如果要查看进程信息,这里随便找一个进程。

然后进40422这个目录看一下:

这里面就是这个进程运行数据:
比如cmdline:

有比如说查看这个进程的环境变量:

最基础的排查方式
查看内存和cpu。
windows 上有任务管理器,那么linux 也有,就是top。

如果发现这些信息不能满足你,可以按f,去选择自己想要的信息。

通过空格,选择自己需要看的信息。
然后使用man top 查看用法。
top -p xxx 查看某一个进程,然后有个比较好用的是 top -Hp xxx
这个是查看线程模式:

可以观察到线程的运行情况。
如果运行太多,可以使用U来查看某个用户的进程。
top -u root
如果查看正在使用cpu的进程可以使用-i,比如 top -i -u root 这样查看。
再介绍一个htop,这个是装13模式。

这逼格是不是加大了,命令和top一样,不过颜色标明出来了。
注意这一行:

快捷方式做一些常规操作。
核心转储
什么是核心转储,核心转储就是进程内存的快照。
下面是 Linux 系统的行为与核心转储文件生成相关的一些关键方面:
默认情况下,当进程意外终止时,将生成核心转储文件。
核心转储文件名为“core”,在当前工作目录或目录中 /var/lib/systemd/coredump 创建。
尽管默认行为是操作系统生成核心转储文件,但可以覆盖 /proc/sys/kernel/core_pattern 此设置,将核心转储文件输出直接传送到另一个应用程序。
那么生成了核心转储服务,有没有管理的,那肯定是有的,比如apport
捕获核心转储和调试器:
有多种工具可用于捕获核心转储文件,例如 gcore、gdb 和用于分析核心转储文件的多个工具,例如 objdump、 kdump、 gdb 和 lldb。
但是,在使用这些工具尝试执行 .NET 调试时,你会遇到一些重大困难:
与在 Windows 上为 WinDbg 调试器设置符号的过程相比,配置可能很困难。
核心转储文件很大,因为这些工具不知道在 .NET Core 进程中使用了哪个内存区域,并且无法将内存信息剪裁为仅需要什么。
转储文件不可移植。 必须分析生成这些文件的 Linux 计算机上的转储文件。 如果要分析不同 Linux 计算机上的转储文件,则需要执行额外的步骤来为调试会话配置主机。
微软官方推荐:
Lldb 是用于分析 .NET Core 转储的建议工具。 .NET SDK 包括用于正确配置 lldb 的有用工具。 但是,必须安装至少版本 3.9 才能对 .NET Core 执行此类调试分析。
若要安装 lldb 3.9 或更高版本,请使用包管理器 (,例如: sudo apt install lldb) 。
但是微软有自己的,比如:
createdump
dotnet-dump
dotnet-gcdump
dotnet-symbol
Procdump
这几个是需要掌握的,因为内容比较多,所以下一节吧。
结
下一节介绍:
Lldb
createdump
dotnet-dump
dotnet-gcdump
dotnet-symbol
Procdump
重新整理 .net core 实践篇 ———— linux上排查问题 [外篇]的更多相关文章
- 重新整理 .net core 实践篇 ———— linux上排查问题实用工具 [外篇]
前言 介绍下面几个工具: Lldb createdump dotnet-dump dotnet-gcdump dotnet-symbol Procdump 该文的前置篇为: https://www.c ...
- 重新整理 .net core 实践篇 ———— linux上性能排查 [外篇]
前言 该文的前置篇为: https://www.cnblogs.com/aoximin/p/16839830.html 本文介绍性能排查. 正文 上一节是出现错误了,如何去排查具体问题. 这一节介绍一 ...
- 重新整理 .net core 实践篇 ———— linux 上线篇 [外篇]
前言 简单整理一个linux 简单上线. 这个是该系列的外篇,该系列继续更新.献给刚学的人. 正文 安装实例 dotnet new webapp -n AspNetCoreDemo -o firstw ...
- 重新整理 .net core 实践篇————配置应用[一]
前言 本来想整理到<<重新整理.net core 计1400篇>>里面去,但是后来一想,整理 .net core 实践篇 是偏于实践,故而分开. 因为是重新整理,那么就从配置开 ...
- 重新整理 .net core 实践篇————依赖注入应用[二]
前言 这里介绍一下.net core的依赖注入框架,其中其代码原理在我的另一个整理<<重新整理 1400篇>>中已经写了,故而专门整理应用这一块. 以下只是个人整理,如有问题, ...
- Node.js~在linux上的部署~外网不能访问node.js网站的解决方法
这是上一篇node.js部署到linux上的后续文章,当我们安装完node.js之后,建立了sailsjs的网站,然后在外面电脑上无法访问这个网站,这个问题我们如何去解决? 解决思路: 查看linux ...
- 重新整理 .net core 实践篇————依赖注入应用之援军[四]
前言 介绍第三方依赖注入框架Autofac,看看为我们解决什么问题. 下面介绍4个点: 命名注册 属性注册 aop 注入 子容器命名 正文 为什么我们需要使用第三方框架?第三方框架为我们做了什么?第三 ...
- 重新整理 .net core 实践篇—————服务与配置之间[十一二]
前言 前面基本介绍了,官方对于asp .net core 设计配置和设计服务的框架的一些思路.看下服务和配置之间是如何联系的吧. 正文 服务: public interface ISelfServic ...
- 重新整理 .net core 实践篇—————中间件[十九]
前言 简单介绍一下.net core的中间件. 正文 官方文档已经给出了中间件的概念图: 和其密切相关的是下面这两个东西: IApplicationBuilder 和 RequestDelegate( ...
随机推荐
- poi生成表格自动合并单元格
直接复制这个工具类即可使用: /** * 合并单元格 * @author tongyao * @param sheet sheet页 * @param titleColumn 标题占用行 * @par ...
- LOJ#2014「SCOI2016」萌萌哒(倍增,并查集优化连边)
题面 点此看题 题意很明白,就不转述了吧. 题解 题目相当于告诉了我们若干等量关系,每个限制 l 1 , r 1 , l 2 , r 2 \tt l_1,r_1,l_2,r_2 l1,r1,l2 ...
- CF-1623C
Problem - 1623C - Codeforces 题意: 给出一个序列,从第三个数字开始,你可以让他减少3*d,然后让它的前两个数字,分别加2*d,和d,找出序列中的最小值的最大值. 题解: ...
- 第八十二篇:Vue购物车(三) 实现全选功能
好家伙, 继续完善购物车相应功能 1.如何实现全选和反全选 1.1.全选框的状态显示(父传子) 来一波合理分析: 在页面中,有三个商品中 三个商品中的第二个未选择, 我么使用一个计算属性(fullSt ...
- KingbaseES的SQL语句-CTE递归
背景 从上下级关系表中,任意一个节点数据出发,可以获得该节点的上级或下级.CTE的递归语法,或者 connect by 与 start with的 查询语法,能够实现这个需求. 当我们需要制作上下级关 ...
- 可靠的自托管「GitHub 热点速览 v.22.37」
自托管(Self-Hosted) 是很多开源项目主打的亮点:数据在手,安全我有.本周 GitHub 热点榜单上有多款自托管的项目,当中自然不能少了之前 HG 小伙伴 @makes world simp ...
- 【Spring】Spring bean中id和name的差异
id和name都是spring 容器中中bean 的唯一标识符. id: 一个bean的唯一标识 , 命名格式必须符合XML ID属性的命名规范 name: 可以用特殊字符,并且一个bean可以用多个 ...
- 使用 Elastic 技术栈构建 K8S 全栈监控 -2: 用 Metricbeat 对 Kubernetes 集群进行监控
文章转载自:https://www.qikqiak.com/post/k8s-monitor-use-elastic-stack-2/ 操作步骤 git clone https://github.co ...
- 关联Prometheus与Alertmanager
在Prometheus的架构中被划分成两个独立的部分.Prometheus负责产生告警,而Alertmanager负责告警产生后的后续处理.因此Alertmanager部署完成后,需要在Prometh ...
- 各编程语言 + aardio 相互调用示例
代码简单.复制可用.aardio 快速调用 C,C++,C#,Java,R,V,Python,JavaScript,Node.js,Rust,PHP,Ruby,PowerShell,Fortran,D ...