mmap对于大内存映射失败(Centos 7,内核3.10.0-862.el7.x86_64)

时间:2018-10-07 03:37:49

标签: linux-kernel centos7 mmap

我试图在运行CentOS 7的服务器之一上运行MySQL服务器。如果innodb_buffer_pool_size设置为120GB以上,分配将失败。在内部,它正在尝试映射大型缓冲区。机器具有256 GB RAM。因此,我编写了以下测试代码,我认为这也是MySQL也在做的事情。该代码在大约130 GB时也会失败

    #define SIZE 1 * 1024 * 1024 * 1024


    int main() {
        unsigned long i, k = 0;
        void **ptr = NULL;
        char *mvptr = NULL;
        ptr = malloc(sizeof(void *) * 220);

        for(i = 0; i < 220;i++){
                ptr[i] = mmap(NULL, SIZE, PROT_READ | PROT_WRITE, MAP_PRIVATE | MAP_ANONYMOUS, -1,0);
                printf("%d  : %lx\n",i, ptr[i]);
                if ((ptr[i] == (void *)-1))
                {
                        printf("error :%d\n",errno);
                        return 0;

                }
                else
                {
                     mvptr = ptr[i];
                     for(k = 0; k < SIZE; k++)
                         mvptr[k] = 'a';

                }

        }
        sleep(20);
        for(i = 0; i < 220;i++){
                munmap(ptr[i], SIZE);
        }
        free(ptr);
}

结果是

124  : 7fc8b2ada000
125  : 7fc872ada000
126  : 7fc832ada000
127  : 7fc7f2ada000
128  : 7fc7b2ada000
129  : ffffffffffffffff
error :12

免费运行-g节目

运行之前

              total        used        free      shared  buff/cache   available
Mem:            251           2         248           0           0         248
Swap:             3           0           3

正在运行

              total        used        free      shared  buff/cache   available
Mem:            251         130         120           0           0         120
Swap:             3           0           3

我在这里做错什么了吗?既然仍有大量可用内存,这可能是什么原因?

1 个答案:

答案 0 :(得分:1)

这是因为/ proc / sys / vm / overcommit_ratio为50。如果修改了overcommit_ratio,则可以分配更高的值。