系统相关
首页 > 系统相关> > Linux内存管理十 如何让Linux进程在固定堆运行

Linux内存管理十 如何让Linux进程在固定堆运行

作者:互联网

我们知道程序在每次运行的时候地址都是不一样的,linux之所以有这样的设计也许是为了安全性考虑,不利于黑客的攻击。

我们看一个简单的程序:

#include <stdio.h>
#include <stdlib.h>

int main(int argc, char* argv[])
{
    int first = 0;
    int *p = malloc(1024);
    printf("p=%p\n", p);

    return 0;
}

显然程序每次运行的地址都不一样!

那么有没有办法让相同程序每次运行的地址都一样呢?

看到这里你也许会问为什么让程序每次运行的地址都一样,这不违背OS设计的初衷了吗?是的,这的确违背 linux 内核设计的初衷。但是实际项目中难免不会遇到奇葩的需求,比如有些app由于历史的原因需要运行在指定地址上,那这时候就需要把地址空间随机化关掉。再比如遇到随机地址crash问题也可以用这种方法debug。

废话少说,我们看下地址空间随机化关掉的方法。


echo 0> /proc/sys/kernel/randomize_va_space
or
sudo sysctl -w kernel.randomize_va_space=0

关掉后我们看下该程序的测试结果:

哇!地址一样!

 

标签:int,程序,关掉,随机化,地址,内存,Linux,进程,运行
来源: https://blog.csdn.net/caofengtao1314/article/details/117333592