首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

关于内存越界的问题

后来在网上查了许多资料,基本上定位是内存地址越界引起,只是不知道具体的越界地点。      ...当时我做的第一个措施是把所有的sprintf、memcpy,strcpy等相关容易出现内存地址越界的函数都检查了一遍,都加了防御代码,不过遗憾的是问题不是出在这些地方。崩溃问题依旧。      ...分析代码尝试解决失败,只能依赖工具,尝试了valgrind等几乎所有linux下的内存检查工具,但是这些工具都有一个致命的缺陷,我们的服务器程序太臃肿了,跑起来非常卡,连正常启动加载运行时10秒就能完成的任务...,用这些工具都需要20分钟以上。...通过这件事情,我总结一下,在解决linux崩溃这些疑难杂症上,必须分析代码+使用工具,代码分析是我的强项,但是使用工具这方面我还有待加强,而且不能急躁,要多一点耐心,多一点坚持,问题一定能解决。

1.5K30
您找到你想要的搜索结果了吗?
是的
没有找到

Linux内存管理神器:smem工具

今天给大家分享一款 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 工具常见用法

1.2K20

Linux内核内存检测工具KASAN

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通过建立影子内存来管理内存访问的合法性,可以有效检测内存越界等问题,但无法发现因逻辑问题导致的合法内存的内容改写问题。

7.1K21

数组的下标越界内存溢出有关吗_数据量过大数组报下标越界

发现如果数组下标越界了,那么它会自动接着那块内存往后写。...内存溢出 在初始化数组(给数组元素赋值)时,初始化(赋值)元素的个数超过了数组定义时元素的个数。...而在Linux(CentOS6.5)里面运行时,就是我们开头说的那种下标越界的情况,不管你下标咋越界,我的编译器都不会对数组下标做边界检查。...这是在Linux(CentOS6.5)环境下,编译链接运行都可以,但程序停不下来,关闭终端时可以看到程序仍在进行。...比如下标越界那个例子中的 i 我定义为10,当在VS2013环境下,我输入的下标值为12,在输出arr[12] = 20 的同时,会把i的值也改为20(VS中定义的两个变量,分配内存时会在两个变量的内存空间之间隔出两个空间

1.7K60

Postgresql中检测内存越界或use after free的简便方法

1 使用场景 在Postgresql的内存管理模块中,最常用的aset.c提供的内存池实现,该实现提供了两个非常实用的开关来解决常见的内存越界问题: memdebug.c * About CLOBBER_FREED_MEMORY...简单总结如下: CLOBBER_FREED_MEMORY: 如果定义了这个符号,所有释放的内存都会被覆盖为0x7F。这对于捕捉引用已释放内存的地方非常有用。...因此,如果有人犯了常见的错误,超出了他们请求的范围,问题可能会被忽视…直到更换平台后,没有这种空间未使用空间,导致内存越界使用的问题才被发现。...但是如果你内存越界访问到第六个字节后,实际上是不会发生任何破坏的,因为这第六个字节也没有人会用,释放时也不可能发现。这就造成了隐患(这类问题都比较难差会有奇怪的逻辑报错)。...打开CLOBBER_FREED_MEMORY后,释放时会调用wipe_mem将内存覆盖成0X7F static inline void wipe_mem(void *ptr, size_t size)

12640

Kasan - Linux 内核的内存检测工具

Sanitizer 的缩写,它是一个动态检测内存错误的工具,主要功能是检查内存越界访问和使用已释放的内存等问题。...但这些工具只能检测用户空间的内存问题。通过在编译时加入指定的选项,就可以给用户程序加入 Address Sanitizer 功能。 清单 1. 用户空间内存错误代码实例 ?...了解 Linux 内存管理的读者知道,内存中的每个物理页在内存中都会有一个 struct page 这样的结构体来表示,即每 4KB 的页需要 40B 的结构体,大约 1% 的内存用来表示内存本身。...例如,下面的代码模拟了内存越界的情况:申请了 124 字节的空间,却写访问第 125 个字节的内容,则会造成越界访问的问题。 清单 6. Kasan 内存右侧越界测试代码 ?...当打开 DEBUG_PAGEALLOC 选项后,可以检测部分释放后使用内存的情况。 这些都是内核代码质量的保证工具,当提交代码的时候,综合使用以上工具可以预防自己的补丁引入一些低级的错误。

5.3K11

Linux下检测内存泄露的工具 valgrind

Valgrind是运行在Linux上一套基于仿真技术的程序调试和分析工具,它包含一个内核,一个软件合成的CPU,和一系列的小工具。 每个工具都可以完成一项任务—调试分析或测试等。...Valgrind可以检测内存泄漏和内存违例。还可以分析cache的使用,灵活又强大,值得入手。 一、Valgrind概述 它主要有下列几个工具。...3)读/写超出malloc分配的内存块 4)读/写不适当的栈中的内存块 5)内存泄漏,指向一块内存的指针永远丢失 6)不正确的malloc/free或new/delete匹配 7)memcpy相关函数中的...Lackey是小型工具,很少用到;Nulgrind只是为开发者展示如何创建一个工具。 二、使用Valgrind 先安装,我的服务器上已经安装好了,不知道是不是所有的linux都自带这个东西。 ?...fun(); printf("i = %d\n", i); return 0; } 存在两个问题: 1)没有free掉申请的资源 2)fun函数里面越界

5.8K100

Linux内存检测工具asan使用介绍

1、编译选项 1.1 Gcc编译选项 -fsanitize=address:开启内存越界检测 -fsanitize-recover=address:一般后台程序为保证稳定性,不能遇到错误就简单退出,而是继续运行...,采用该选项支持内存出错之后程序继续运行,需要叠加设置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...其次,平台软件通常都会内部实现一套内存操作接口,为使用asan工具,需要替换成glibc提供的接口。此时,可以通过LD_PRELOAD环境变量解决这类问题。

6.7K20

Linux内存描述之高端内存--Linux内存管理(五)

但是,当Linux物理内存超过1G时,线性访问机制就不够用了,因为只能有1G的内存可以被映射,剩余的物理内存无法被内核管理,所以,为了解决这一问题,Linux把内核地址分为线性区和非线性区两部分,线性区规定最大为...DMA Zone通常很小,只有几十M,低端内存区与高端内存区的划分来源于Linux内核空间大小的限制。...因此,Linux 规定“内核直接映射空间” 最多映射 896M 物理内存。...1G) 2.3 Linux内核高端内存的理解 前 面我们解释了高端内存的由来。...(一一对应影射,物理地址线性地址-PAGE_OFFSET),这段区域的大小和机器实际拥有的物理内存大小有关,这儿VMALLOC_OFFSET在X86上为8M,主要用来防止越界错误;在内存比较小的系统上

12.2K22

Linux - Linux内存管理

移除交换空间 ---- 概念 内存管理是Linux系统重要的组成部分。...为了解决内存紧缺的问题,Linux引入了虚拟内存的概念。为了解决快速存取,引入了缓存机制、交换机制等。...当需要用到原始内容时,这些信息会被重新从交换空间读入物理内存Linux内存管理采取的是分页存取机制。...要深入了解Linux内存运行机制,需要知道下面提到的几个方面。 首先,Linux系统会不时地进行页面交换操作,以保持尽可能多的空闲物理内存。...其次,Linux进行页面交换是有条件的,不是所有页面在不用时都交换到虚拟内存中,Linux内核根据“最近最经常使用”算法,仅仅将一些不经常使用的页面文件交换到虚拟内存中。

52.1K41

Linux系统内存监控、性能诊断工具vmstat命令详解

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)。     ...(3) Linux 内存监控swap交换页面     si: 从磁盘交换到内存的交换页数量,单位:KB/秒。     so: 从内存交换到磁盘的交换页数量,单位:KB/秒。

2.6K50

小白博客 CryKeX:Linux内存加密密钥提取工具

Unix-理论上说,该工具可在任何基于Unix的操作系统平台上正常工作。 2. BASH-支持所有脚本的运行。 3....需要适当的用户权限以及内存授权 工作机制 基本上说,该工具会寻找某些类似密钥的数据,并通过分析其内存架构(C数据类型)来判断目标数据(密钥)的有效性。...【参考文献一】【 参考文献二】 CryKeX可以导出目标进程的实时内存数据,然后从中寻找出可能存在的密钥信息,整个过程中内存映射并不会发生改变。...工具脚本不仅能够向正在运行的进程中注入命令,而且还可以封装新的进程(通过单独启动进程后再进行注入来实现)。这样一来,该工具几乎就可以从目标系统中的任意进程/代码中提取密钥了。...Linux磁盘加密(LUKS)使用了反取证技术来缓解这类安全问题,但是我们仍然有可能从一段完整的内存中提取出密钥。

1.7K80

Win10 Edge浏览器从越界写到任意内存读写

在mapHelper遍历的过程中,即使length没有发生越界,最终也必然会导致越界写的行为发生,因此此漏洞仅仅影响64位的edge浏览器。但是单单的越界写是不足够的,还需要满足两个条件最佳: 1....可以控制越界写越多少界,例如我想越8字节时就8字节,16字节时就16字节。 解决方法:根据此漏洞的特性,通过控制y和n[5]数组的长度可以控制越界写的长度,当然还需要考虑内存对齐的细节。 2....至此,任意越界写已经实现,下一步就是通过越界写修改相邻IntArray的长度。 0×2 制造一个big_array 首先需要了解IntArray在内存中的数据结构: ?...Dataview的内存结构,分别是bytelength和buffer_address ? 任意内存读: ?...同理任意内存写: ? 0×5 获取任意对象地址 最后一步,就是获取任意对象的地址,我的代码如下: ?

1.4K70

内存相关工具

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 库内存占用 依次是此文件总的分配内存、括号内是共享部分大小、然后是库路径、最后是使用此库文件的进程号。

95420

Linux内存描述之内存节点node--Linux内存管理(二)

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链表

7.6K20

Linux内存描述之内存页面page--Linux内存管理(四)

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?

8K11

Linux内存描述之概述--Linux内存管理(一)

2 (N)UMA模型中linux内存的机构 Linux适用于各种不同的体系结构, 而不同体系结构在内存管理方面的差别很大. 因此linux内核需要用一种体系结构无关的方式来表示内存....Linux内核通过插入一些兼容层, 使得不同体系结构的差异很好的被隐藏起来, 内核对一致和非一致内存访问使用相同的数据结构 2.1 (N)UMA模型中linux内存的机构 非一致存储器访问(NUMA)模式下...而内存管理的其他地方则认为他们就是在处理一个(伪)NUMA系统. 2.2 Linux物理内存的组织形式 Linux把物理内存划分为三个层次来管理 层次 描述 存储节点(Node) CPU被划分为多个节点..., 我们会在后面典型架构(x86)上内存区域划分详细讲解x86_32上的内存区域划分 因此Linux内核对不同区域的内存需要采用不同的管理方式和映射方式, 为了解决这些制约条件,Linux使用了三种区:...2.6 高端内存 由于能够被Linux内核直接访问的ZONE_NORMAL区域的内存空间也是有限的,所以LINUX提出了高端内存(High memory)的概念,并且允许对高端内存的访问

6.8K30
领券