Linux系统中的mlock使用方法简介 (mlock linux)

在Linux系统中,mlock是一个非常重要的命令。它是用来锁定内存区域的,这样可以避免这些内存区域被系统交换到磁盘上,从而提高系统的性能。本文将介绍Linux系统中mlock的使用方法。

1. mlock的基本用途

mlock命令可以锁定一个进程的一段内存区域,从而防止这段内存被系统清除到交换空间中。这个命令通常在需要使用大量内存的时候使用,因为如果内存区域被清除到交换空间中,就会极大地影响系统的性能。

2. mlock的使用限制

在使用mlock之前,需要注意其使用限制。一般来说,只有当进程的权限是root时,才能使用mlock命令。这是因为mlock命令需要对内存区域进行锁定操作,而这种操作只有具备足够权限的用户才能进行。

此外,为了避免滥用mlock命令对系统造成的影响,Linux内核通常会对mlock命令的使用做出限制。在默认情况下,一个进程只能使用少量内存进行mlock操作。如果需要大量使用mlock,需要通过修改系统参数来实现。

3. 使用mlock命令锁定内存区域

在Linux系统中,使用mlock命令锁定一段内存区域非常简单。下面是一个简单的例子:

“`

#include

#include

#include

#include

int mn() {

void *p;

size_t size = 1024*1024;

p = mmap(NULL, size, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0);

if (p == MAP_FLED) {

perror(“mmap fled”);

exit(-1);

}

mlock(p, size);

printf(“mlock success\n”);

sleep(60);

return 0;

}

“`

在上面的例子中,我们首先调用mmap函数来分配一段大小为1MB的内存区域。然后使用mlock命令将这些内存区域锁定住。我们使用sleep函数让程序休眠60秒,这样我们可以在这段时间内观察到这些内存区域是否被系统清理到了交换空间中。

4. 使用mlock命令的注意事项

在使用mlock命令时,我们需要注意以下几点:

(1)尽量不要过度使用mlock命令。如果一味的将所有内存都锁定住,反而会降低系统的性能。

(2)mlock命令只锁定内存区域,因此如果这些内存区域被释放,锁定也会被清除。因此使用mlock命令时需要仔细考虑内存的分配和释放。

(3)在使用mlock命令后,内存区域只有在程序退出时才会被系统清理。因此如果需要释放这些内存,需要手动调用munlock命令。

5.

相关问题拓展阅读:

谁在用android的buffer和cached

buffer和cached 你是说缓吵历存吗,?

具体指哪方面则碰乎,麻烦你把问题描述清楚一点,android方面的问题,我们可孙悉以帮你解决

通常,对应Linux的系统来说,可以通过cat /proc/meminfo查看内存的使用情况,Android是基于Linux的,所有也可以使用adb shell cat /proc/meminfo

查看内存的使用情况,如下所示:

MemTotal:4 kB

MemFree:32 kB

Buffers:28 kB

Cached:332 kB

SwapCached:kB

Active:500 kB

Inactive:8 kB

Active(anon):kB

Inactive(anon):kB

Active(file):kB

Inactive(file):kB

Unevictable:kB

Mlocked: 0 kB

HighTotal: kB

HighFree:8 kB

LowTotal:2 kB

LowFree:04 kB

SwapTotal: kB

SwapFree:0 kB

Dirty: 0 kB

Writeback: kB

AnonPages: kB

Mapped:004 kB

Shmem: 452 kB

Slab:45988 kB

SReclaimable:kB

SUnreclaim:kB

KernelStack:kB

PageTables:kB

NFS_Unstable:kB

Bounce: 0 kB

WritebackTmp:kB

CommitLimit:kB

Committed_AS:kB

VmallocTotal:kB

VmallocUsed:kB

VmallocChunk:kB

其中:

MemTotal:总的可用内存

MemFree: 未被分配空闲的内存

Buffers:buffer的大小

Cached:cache的大小

SwapCached:swap 缓存的大小,Android很少使用swap的,经常为0

其中free memory = MemFree + Buffer + Cached,那么used memory = MemTotal – free memory = MemTotal – MemFree - Buffer – Cached,为649M

按理说应该是这样的,但事实却未必如此,使用procrank命令,看以看到总的信液激息如下:

PSS RSS

TOTALKK

RAM:K total,K free, 30692K buffers,K cached, 452K shmem, 45976K slab

可用看到PSS的内存大小为469M,还有80M不知道跑哪去了。哦,完了还有PageTables占用的内存没有减去,而此时系统PageTables才8M,= 640M,

离469M的PSS还有71M,应该还有地方没有去除的。是的,shmem和slab没有去除,这两个加起来有46M,= 25M,那这25M去孙厅哪了呢?应该是Android

Reserved 或者是3D/HW buffer使用了吧!不太清楚。

其实,应则埋隐该通过zoneinfo里面去查看内存的使用情况(单位:4kb,一个page的大小),可能更准确:

Node 0, zone Normal

pages free

min

low

high

scanned 0

spanned

present

nr_free_pages

nr_inactive_anon 0

nr_active_anon 0

nr_inactive_file 4187

nr_active_file 3590

nr_unevictable 0

nr_mlock 0

nr_anon_pages 0

nr_mapped 39

nr_file_pages 7771

nr_dirty 0

nr_writeback 0

nr_slab_reclaimable 5636

nr_slab_unreclaimable 5840

nr_page_table_pages 2479

nr_kernel_stack 867

nr_unstable 0

nr_bounce 0

nr_vmscan_write 0

nr_vmscan_immediate_reclaim 0

nr_writeback_temp 0

nr_isolated_anon 0

nr_isolated_file 0

nr_shmem 0

nr_dirtied

nr_written

nr_anon_transparent_hugepages 0

nr_free_cma 2329

protection: (0, 8902, 8902)

pagesets

cpu: 0

count: 52

high: 186

batch: 31

vm stats threshold: 8

all_unreclaimable: 0

start_pfn:

inactive_ratio: 1

Node 0, zone HighMem

pages free

min

low

high

scanned 0

spanned

present

nr_free_pages 58767

nr_inactive_anon 101

nr_active_anon 90565

nr_inactive_file 57093

nr_active_file 41004

nr_unevictable 0

nr_mlock 0

nr_anon_pages 90557

nr_mapped

nr_file_pages 98210

nr_dirty 0

mlock linux的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于mlock linux,Linux系统中的mlock使用方法简介,谁在用android的buffer和cached的信息别忘了在本站进行查找喔。


数据运维技术 » Linux系统中的mlock使用方法简介 (mlock linux)