Linux服务器测试包括压力测试、负载测试和性能测试,其中性能测试包括涉及到吞吐量、响应时间、CPU占用率、并发用户数等不同指标。我们在测试服务器的过程中,经常会遇到性能上不去。...查看CPU,网络,IO消耗都挺低的,就是定位不到问题的原因,这时候往往需要进一步深入定位问题,下图详细列举了针对不同性能目前常用的测试工具。 QQ图片20190213174115.jpg
内存检测工具Valgrind Valgrind是运行在Linux上的一套基于仿真技术的程序调试和分析工具,作者是获得过Google-O’Reilly开源大奖的Julian Seward,它包含一个内核...——一个软件合成的CPU,和一系列的小工具,每个工具都可以完成一项任务——调试,分析,测试等。...内存检测,使用它的Memcheck工具。...等分配的动态内存范围 读/写不适当的栈中内存块 内存泄漏,指向一块内存的指针丢失 不正确的malloc/free或new/delete匹配 memcpy()相关函数中的dst和src指针重叠问题 ---...lost —— 确定的内存泄露,已经不能够访问这块内存 Indirectly lost —— 指向该内存的指针位于内存泄露处 Possibly lost —— 可能的内存泄露,仍然存在某个指针能够访问某块内存
今天给大家分享一款 Linux 系统里的内存管理神器:smem 。 smem 是Linux系统上的一款可以生成多种内存耗用报告的命令行工具。...与现有工具不一样的是 smem 可以报告 PSS【Proportional Set Size(按比例占用大小)】,这是一种更有意义的指标。可以衡量虚拟内存系统的库和应用程序所占用的内存数量。...由于大部分的物理内存通常在多个应用程序之间共享,名为驻留集大小(RSS)的这个标准的内存耗用衡量指标会大大高估内存耗用情况。...安装 smem 工具 如果你使用的是 Fedora 19 以上系统, smem 默认在存储库中,因此你可以使用 yum 来安装它: $ sudo yum install smem 对于 Ubuntu...sudo apt-get install smem 如果无法正常安装的话,可以下载它的源码直接安装,地址为:https://www.selenic.com/smem/download/ 2. smem 工具常见用法
KASAN 是 Kernel Address Sanitizer 的缩写,它是一个动态检测内存错误的工具,主要功能是检查内存越界访问和使用已释放的内存等问题。...KASAN 集成在 Linux 内核中,随 Linux 内核代码一起发布,并由内核社区维护和发展。本文简要介绍 KASAN 的原理及使用方法。 一、KASAN的原理和使用方法 1....由于1/8的内存用于shadow memory,可用内存会减少1/8,例如8GB的内存,打开KASAN后,MemTotal约为6.72GB。...KASAN原理概述 KASAN利用额外的内存标记可用内存的状态,这部分额外的内存被称作shadow memory(影子区),KASAN将1/8的内存用作shadow memory。...二、总结 KASAN通过建立影子内存来管理内存访问的合法性,可以有效检测内存越界等问题,但无法发现因逻辑问题导致的合法内存的内容改写问题。
通常情况下,我们都是使用tcp或者icmp来测试机器的TCP信息,但是有一部分环境下,我们需要使用UDP来进行通讯,常规测试方法是搭建一个正常的酸酸乳服务,然后进行udp测试,但是此方法比较繁琐,可以使用更简单的测试工具.../udpping.py 127.0.0.1 4000 如果在其他机器进行测试: ./udpping.py ip 4000 如果正常,可以得到如下结果: [root@VM-6462 ~]# .
Sanitizer 的缩写,它是一个动态检测内存错误的工具,主要功能是检查内存越界访问和使用已释放的内存等问题。...测试 学习 Linux 的同学一定对 Linus 的名言“Talk is cheap, show me the code.”耳熟能详。...幸运的是 Linux 内核的源码中已经包含了针对 Kasan 的测试代码,其位置在 linux/lib/test_kasan.c。...Kasan 内存右侧越界测试代码 ? 当运行以上测试代码的时候,在内核日志中会详细打印以下内容: 清单 7....结束语 本文介绍了 Kasan 的配置及使用方法,并通过运行 Kasan 的测试用例说明了 Kasan 的原理。对于内核开发者来说,该工具不仅可以用来检测自己代码。
Valgrind是运行在Linux上一套基于仿真技术的程序调试和分析工具,它包含一个内核,一个软件合成的CPU,和一系列的小工具。 每个工具都可以完成一项任务—调试分析或测试等。...Valgrind可以检测内存泄漏和内存违例。还可以分析cache的使用,灵活又强大,值得入手。 一、Valgrind概述 它主要有下列几个工具。...3)读/写超出malloc分配的内存块 4)读/写不适当的栈中的内存块 5)内存泄漏,指向一块内存的指针永远丢失 6)不正确的malloc/free或new/delete匹配 7)memcpy相关函数中的...Lackey是小型工具,很少用到;Nulgrind只是为开发者展示如何创建一个工具。 二、使用Valgrind 先安装,我的服务器上已经安装好了,不知道是不是所有的linux都自带这个东西。 ?...下面介绍一些其他用法(我也是照着参考学的,具体如何用到实际项目中还需要自己领悟): 测试下面时,main函数中的i我改为了没有赋值: 1.一旦出现错误,valgrind会自动启动调试器(一般是gdb):
,给我们的经验教训,就是上线前,基准测试的重要性,这篇文章着重介绍一下「Linux 性能基准测试工具及测试方法」 还是老规矩,先请性能领域的大师布伦丹·格雷格(Brendan Gregg)登场 linux_benchmarking_tools...整理测试指标如下图 测试环境说明:CentOS7, 4c8g CPU Super_Pi 是一种用于计算圆周率π的程序,通常用于测试计算机性能和稳定性。...=4 --events=10000 --time=0 run # 结果分析,看 total time 即可,时间越短,性能越好 内存 内存带宽(stream) Stream测试是内存测试中业界公认的内存带宽性能测试基准工具.../stream_c.exe # 结果分析,看 Copy、Scale、Add、Triad,数值越大,性能越好 磁盘 IO ⚠️ 测试时请准备裸的数据盘,测试完成后请重新格式化磁盘 测试方法和结果分析和文件...ip> -l 100 -- -m 1500 -R 1 & # 监控数据 sar -n DEV 5 # 结果分析,看 rxkB/s,txkB/s 值即可,值越大,性能越好 Nginx # 安装 ab 工具
FIO是测试IOPS的非常好的工具,用来对硬件进行压力测试和验证。磁盘IO是检查磁盘性能的重要指标,可以按照负载情况分成照顺序读写,随机读写两大类。...目前主流的第三方IO测试工具有fio、iometer 和 Orion,这三种工具各有千秋,在linux 下也可以使用dd 进行简单的磁盘(文件系统)测试(文末补充)。...fio在Linux系统下使用比较方便,iometer在window系统下使用比较方便,Orion是oracle的IO测试软件,可在没有安装oracle数据库的情况下模拟oracle数据库场景的读写。...此外 lockmem=1g 只使用1g内存进行测试。 zero_buffers 用0初始化系统buffer。 nrfiles=8 每个进程生成文件的数量。 磁盘读写常用测试点: 1....更多关于磁盘顺序io 部分,可以参考 dd 工具的使用;https://www.cnblogs.com/xuyaowen/p/dd.html FIO 图形界面工具:fio性能测试工具新添图形前端gfio
如何在 Linux 上安装 tcpping 测量到远程主机的网络延迟的一种常用方法是使用ping应用程序。该ping工具依赖 ICMP ECHO 请求和回复数据包来测量远程主机的往返延迟。...在这种情况下,你将需要依赖使用 TCP/UDP 数据包的第 3 层测量工具,因为这些第 3 层数据包更有可能绕过常见的防火墙规则。 一种这样的第 3 层测量工具是tcpping....在 Linux 上安装tcpping tcpping作为 shell 脚本实现,该脚本响应外部工具来执行和报告 RTT 测量。因此,为了安装tcpping,你首先需要先安装这些先决条件。...安装这些必备工具后,最后继续tcpping从官方源下载。...0.5秒(1秒=1000毫秒),单位 秒 tcping -w 0.5 1.1.1.1 80 -d :在每行返回信息中加入时间信息 tcping -d 1.1.1.1 80 -s : 当 TCPing 测试成功后
其中一个是 Kali,一个为安全和渗透测试而开发的 Linux 发行版。本文演示了如何使用 Kali Linux 来审视你的系统以发现弱点。...Kali 安装了很多工具,它们都是开源的,默认情况下安装了它们会让事情变得更容易。...它拥有 30GB 内存和 6 个虚拟 CPU(vCPU)。 vulnerable.usersys.redhat.com: 这是一个 Red Hat 企业版 Linux 8 系统,它会成为目标。...它拥有 16GB 内存和 6 个 vCPU。它是一个相对较新的系统,但有些软件包可能已经过时。...使用供应商提供的工具: 供应商有不同的工具来帮助你维护他们的系统,因此一定要充分利用它们。
简介 Apache Benchmark(简称ab) 是Apache安装包中自带的压力测试工具 ,简单易用 在此提供 ab 在 centOS7 下的安装和使用方法 注:个人发现,之前安装的centos6.5...(供测试的URL路径) Document Length: 3721 bytes (供测试的URL返回的文档大小) Concurrency Level: 1000 (并发数) Time...://192.168.1.106/index1.html 简单解释:并发访问量过大 服务器拒绝访问,理论上通过系统配置,可以有更好的承受能力 ⑤.注意事项 测试机与被测试机要分开 不要对线上的服务器做压力测试...观察测试工具ab所在机器,以及被测试的前端机的CPU、内存、网络等都不超过最高限度的75% ab请加-k参考启用http1.1的keepalive功能 核心原理 ab是如何分配并发和请求数的呢?...在test函数中,先给连接数和请求数分配内存,组http报文头、组http请求报文默认使用GET方法(最大2048个字节) 进入for循环 for (i = 0; i < concurrency; i+
,采用该选项支持内存出错之后程序继续运行,需要叠加设置ASAN_OPTIONS=halt_on_error=0才会生效;若未设置此选项,则内存出错即报错退出, ASAN_CFLAGS += -fsanitize...halt_on_error=0:检测内存错误后继续运行 detect_leaks=1:使能内存泄露检测 malloc_context_size=15:内存错误发生时,显示的调用栈层数为15 log_path...=/home/xos/asan.log:内存检查问题日志存放文件路径 suppressions=$SUPP_FILE:屏蔽打印某些内存错误 export ASAN_OPTIONS=halt_on_error...,常用运行选项有: exitcode=0:设置内存泄露退出码为0,默认情况内存泄露退出码0x16 use_unaligned=4:4字节对齐 export LSAN_OPTIONS=exitcode=0...其次,平台软件通常都会内部实现一套内存操作接口,为使用asan工具,需要替换成glibc提供的接口。此时,可以通过LD_PRELOAD环境变量解决这类问题。
但是,当Linux物理内存超过1G时,线性访问机制就不够用了,因为只能有1G的内存可以被映射,剩余的物理内存无法被内核管理,所以,为了解决这一问题,Linux把内核地址分为线性区和非线性区两部分,线性区规定最大为...DMA Zone通常很小,只有几十M,低端内存区与高端内存区的划分来源于Linux内核空间大小的限制。...因此,Linux 规定“内核直接映射空间” 最多映射 896M 物理内存。...1G) 2.3 Linux内核高端内存的理解 前 面我们解释了高端内存的由来。...4 页框管理 4.1 页框管理 Linux采用4KB页框大小作为标准的内存分配单元。
Unix-理论上说,该工具可在任何基于Unix的操作系统平台上正常工作。 2. BASH-支持所有脚本的运行。 3....需要适当的用户权限以及内存授权 工作机制 基本上说,该工具会寻找某些类似密钥的数据,并通过分析其内存架构(C数据类型)来判断目标数据(密钥)的有效性。...【参考文献一】【 参考文献二】 CryKeX可以导出目标进程的实时内存数据,然后从中寻找出可能存在的密钥信息,整个过程中内存映射并不会发生改变。...工具脚本不仅能够向正在运行的进程中注入命令,而且还可以封装新的进程(通过单独启动进程后再进行注入来实现)。这样一来,该工具几乎就可以从目标系统中的任意进程/代码中提取密钥了。...Linux磁盘加密(LUKS)使用了反取证技术来缓解这类安全问题,但是我们仍然有可能从一段完整的内存中提取出密钥。
移除交换空间 ---- 概念 内存管理是Linux系统重要的组成部分。...为了解决内存紧缺的问题,Linux引入了虚拟内存的概念。为了解决快速存取,引入了缓存机制、交换机制等。...当需要用到原始内容时,这些信息会被重新从交换空间读入物理内存。 Linux的内存管理采取的是分页存取机制。...要深入了解Linux内存运行机制,需要知道下面提到的几个方面。 首先,Linux系统会不时地进行页面交换操作,以保持尽可能多的空闲物理内存。...其次,Linux进行页面交换是有条件的,不是所有页面在不用时都交换到虚拟内存中,Linux内核根据“最近最经常使用”算法,仅仅将一些不经常使用的页面文件交换到虚拟内存中。
vmstat 命令是最常见的 Linux/Unix 监控工具,可以展现给定时间间隔的服务器的状态值,包括服务器的 CPU 使用率,内存使用,虚拟内存交换情况,IO 读写情况。...这个命令是我查看 Linux/Unix 最喜爱的命令,一个是 Linux/Unix 都支持,二是相比 top,我可以看到整个机器的 CPU,内存,IO 的使用情况,而不是单单看到各个进程的 CPU 使用率和内存使用率...一般 vmstat 工具的使用是通过两个数字参数来完成的,第一个参数是采样的时间间隔数,单位是秒,第二个参数是采样的次数,如: root@ubuntu:~# vmstat 2 1 procs -----...(2)Linux 内存监控内存memoy: swpd:现时可用的交换内存(单位KB)。 free:空闲的内存(单位KB)。 ...例如我们调用系统函数,就要进行上下文切换,线程的切换,也要进程上下文切换,这个值要越小越好,太大了,要考虑调低线程或者进程的数目,例如在 apache 和 nginx 这种 web 服务器中,我们一般做性能测试时会进行几千并发甚至几万并发的测试
1. vmstat 参照《Linux CPU占用率监控工具小结-vmstat》 2. memstat memstat可以通过sudo apt install memstat安装,安装包括两个文件memstat...memstat通过遍历/proc下所有进程,然后解析内存使用情况。 通过对比可以发现,memstat不会统计内核线程的内存使用情况,同时memstat也不会统计所有设备使用的内存。...2.1 memstat使用 memstat使用很简单: memstat - 显示整个系统内存使用情况。 memstat -p pid - 显示进程pid的内存使用情况。...依次是占用内存大小、pid号、文件路径。...这里的大小不包括库文件,也不包括可执行文件的text段,只是进程私有内存大小。 2.2.3 库内存占用 依次是此文件总的分配内存、括号内是共享部分大小、然后是库路径、最后是使用此库文件的进程号。
CPU访问本地内存的速度比访问远程内存的速度要快 Linux适用于各种不同的体系结构, 而不同体系结构在内存管理方面的差别很大....因此linux内核需要用一种体系结构无关的方式来表示内存....因此linux内核把物理内存按照CPU节点划分为不同的node, 每个node作为某个cpu结点的本地内存, 而作为其他CPU节点的远程内存, 而UMA结构下, 则任务系统中只存在一个内存node, 这样对于...系统中的NUMA结点都是从0开始编号的 3.1 linux-2.4中的实现 pgdat_next指针域和pgdat_list内存结点链表 而对于NUMA结构的系统中, 在linux-2.4.x之前的内核中所有的节点...-3.x~4.x的实现 node_data内存节点数组 在新的linux3.x~linux4.x的内核中,内核移除了pg_data_t的pgdat_next之指针域, 同时也删除了pgdat_list链表
1 Linux如何描述物理内存 Linux把物理内存划分为三个层次来管理 层次 描述 存储节点(Node) CPU被划分为多个节点(node), 内存则被分簇, 每个CPU对应一个本地物理内存, 即一个...内存中的每个节点都是由pg_data_t描述,而pg_data_t由struct pglist_data定义而来, 该数据结构定义在include/linux/mmzone.h, line 615, 每个结点关联到系统中的一个处理器...简单来说, 页是一个数据块, 可以存放在任何页框(内存中)或者磁盘(被交换至交换分区)中 我们今天就来详细讲解一下linux下物理页帧的描述 2 页帧 内核把物理页作为内存管理的基本单位....因此在后来linux-2.4.x的更新中, 删除了这个字段, 取而代之的是page->flags的最高ZONE_SHIFT位和NODE_SHIFT位, 存储了其所在zone和node在内存区域表zone_table...3.2 内存页标识pageflags 其中最后一个flag用于标识page的状态, 这些状态由枚举常量enum pageflags定义, 定义在include/linux/page-flags.h?
领取专属 10元无门槛券
手把手带您无忧上云