在Linux系统中,内存是非常重要的资源,它能够让应用程序快速地进行处理和读取文件。为了让应用程序更高效地使用内存,Linux提供了一些工具和方法来将数据写入内存。本文将介绍如何在Linux中使用这些方法将数据写入内存。
一、文件映射到内存
文件映射到内存是一种非常常见的数据写入内存的方法。它使用mmap系统调用将文件映射到内存,并使用读写操作来访问内存中的数据。在文件映射到内存后,应用程序可以快速读取和写入文件,而无需执行额外的数据复制操作。
步骤如下:
1. 打开要映射的文件。
2. 获取文件长度,并使用mmap系统调用将文件映射到内存。
3. 使用指针来访问内存中的数据。
4. 将数据写入内存。
5. 使用munmap系统调用释放内存映射。
下面是一个简单的示例程序,它将一个文件映射到内存中,并将一些数据写入该文件。
#include
#include
#include
#include
#include
int mn() {
const char *filename = “file.txt”;
int fd = open(filename, O_RDWR);
if (fd == -1) {
perror(“open”);
exit(1);
}
off_t length = lseek(fd, 0, SEEK_END);
void *map = mmap(NULL, length, PROT_READ|PROT_WRITE, MAP_SHARED, fd, 0);
if (map == MAP_FLED) {
perror(“mmap”);
exit(1);
}
char *data = (char*) map;
// write some data to memory
data[0] = ‘H’;
data[1] = ‘e’;
data[2] = ‘l’;
data[3] = ‘l’;
data[4] = ‘o’;
data[5] = ‘,’;
data[6] = ‘ ‘;
data[7] = ‘W’;
data[8] = ‘o’;
data[9] = ‘r’;
data[10] = ‘l’;
data[11] = ‘d’;
data[12] = ‘!’;
data[13] = ‘\n’;
munmap(map, length);
close(fd);
return 0;
}
这个程序将一个名为file.txt的文件映射到内存中,并使用指针来访问内存中的数据。它在内存中写入了一些数据,并使用munmap系统调用来释放内存映射。在执行完该程序后,file.txt文件将包含写入的数据。
二、使用共享内存
共享内存是另一种常见的将数据写入内存的方法。它使用shmget系统调用创建共享内存段,并使用shmat系统调用将共享内存段映射到进程的地址空间中。多个进程可以同时访问共享内存中的数据,使得它成为进程之间共享数据的一种有效方式。
步骤如下:
1. 使用shmget系统调用创建共享内存段。
2. 使用shmat系统调用将共享内存段映射到进程的地址空间中。
3. 使用指针来访问共享内存中的数据。
4. 将数据写入内存。
5. 使用shmdt系统调用将共享内存从进程的地址空间中分离。
下面是一个简单的示例程序,它创建一个共享内存段,并将一些数据写入该共享内存段。
#include
#include
#include
#include
int mn() {
const int SHM_SIZE = 1024;
const key_t SHM_KEY = 1234;
int shmid = shmget(SHM_KEY, SHM_SIZE, IPC_CREAT|0600);
if (shmid == -1) {
perror(“shmget”);
exit(1);
}
char *shm = shmat(shmid, NULL, 0);
if (shm == (void*) -1) {
perror(“shmat”);
exit(1);
}
// write some data to shared memory
shm[0] = ‘H’;
shm[1] = ‘e’;
shm[2] = ‘l’;
shm[3] = ‘l’;
shm[4] = ‘o’;
shm[5] = ‘,’;
shm[6] = ‘ ‘;
shm[7] = ‘W’;
shm[8] = ‘o’;
shm[9] = ‘r’;
shm[10] = ‘l’;
shm[11] = ‘d’;
shm[12] = ‘!’;
shm[13] = ‘\n’;
shmdt(shm);
shmctl(shmid, IPC_RMID, NULL);
return 0;
}
这个程序创建了一个共享内存段,并使用指针来访问共享内存中的数据。它在内存中写入了一些数据,并使用shmdt系统调用将共享内存从进程的地址空间中分离。在执行完该程序后,共享内存段将被销毁,写入的数据将被丢弃。
成都网站建设公司-创新互联,建站经验丰富以策略为先导10多年以来专注数字化网站建设,提供企业网站建设,高端网站设计,响应式网站制作,设计师量身打造品牌风格,热线:028-86922220物理内存和虚拟内存
我们知道,直接从物理内存读写数据要比从硬盘读写数据要快的多,因此,我们希望所有数据的读取和写入都在内存完成,而内存是有限的,这样就引出了物理内存与虚拟内存的概念。
物理内存就是系统硬件提供的内存大小,是真正的内存,相对于物理内存,在linux下还有一个虚拟内存的概念,虚拟内存就是为了满足物理内存的不足而提出的策略,它是利用磁盘空间虚拟出的一块逻辑内存,用作虚拟内存的磁盘空间被称为交换空间(Swap Space)。
作为物理内存的扩展,linux会在物理内存不足时,使用交换分区的虚拟内存,更详细的说,就是内核会将暂时不用的内存块信息写到交换空间,这样以来,物理内存得到了释放,这块内存就可以用于其它目的,当需要用到原始的内容时,这些信息会被重新从交换空间读入物理内存。
linux的内存管理采取的是分页存取机制,为了保证物理内存能得到充分的利用,内核会在适当的时候将物理内存中不经常使用的数据块自动交换到虚拟内存中,而将经常使用的信息保留到物理内存。
要深入了解linux内存运行机制,需要知道下面提到的几个方面:
首先,Linux系统会不时的进行则告页面交换操作,以保持尽可能多的空闲物理内存,即使并没有什么事情需要内存,Linux也会交换出暂时不用的内存页面。这可以避免等待交换所需的时间。
其次,linux进行页孙正明面交换是有
条件的,不是所有页面在不用时都交换到虚拟内存,linux内核根据”最近最经常使用“算法,仅仅将一些不经常使用的页面文件交换到虚拟内存,有时我们会
看到这么一个现象:linux物理内存还有很多,但是交换空间也使用清敏了很多。其实,这并不奇怪,例如,一个占用很大内存的进程运行时,需要耗费很多内存资
源,此时就会有一些不常用页面文件被交换到虚拟内存中,但后来这个占用很多内存资源的进程结束并释放了很多内存时,刚才被交换出去的页面文件并不会自动的
交换进物理内存,除非有这个必要,那么此刻系统物理内存就会空闲很多,同时交换空间也在被使用,就出现了刚才所说的现象了。关于这点,不用担心什么,只要
知道是怎么一回事就可以了。
最后,交换空间的页面在使用时会首
先被交换到物理内存,如果此时没有足够的物理内存来容纳这些页面,它们又会被马上交换出去,如此以来,虚拟内存中可能没有足够空间来存储这些交换页面,最
终会导致linux出现假死机、服务异常等问题,linux虽然可以在一段时间内自行恢复,但是恢复后的系统已经基本不可用了。
因此,合理规划和设计linux内存的使用,是非常重要的.
内存的监控
作为一名linux系统管理员,监控内存的使用状态是非常重要的,通过监控有助于了解内存的使用状态,比如内存占用是否正常,内存是否紧缺等等,监控内存最常使用的命令有free、top等,下面是某个系统free的输出:
$ free
totalusedfree shared buffers cached
Mem:0
-/+ buffers/cache:
Swap:
我们解释下输出结果中每个选项的含义:
首先是之一行:
total:物理内存的总大小。
used:已经使用的物理内存多小。
free:空闲的物理内存值。
shared:多个进程共享的内存值。
buffers/cached:磁盘缓存的大小。
第二行Mem:代表物理内存使用情况。
第三行(-/+ buffers/cached):代表磁盘缓存使用状态。
第四行:Swap表示交换空间内存使用状态。
free命令输出的内存状态,可以通过两个角度来查看:一个是从内核的角度来看,一个是从应用层的角度来看的。
从内核的角度来查看内存的状态
就是内核目前可以直接分配到,不需要额外的操作,即为上面free命令输出中第二行Mem项的值,可以看出,此系统物理内存有16G,空闲的内存只有41940K,也就是40M多一点,我们来做一个这样的计算:
-=
其实就是总的物理内存减去已经使用的物理内存得到的就是空闲的物理内存大小,注意这里的可用内存值41940并不包含处于buffers和cached状态的内存大小。
如果你认为这个系统空闲内存太小,那你就错了,实际上,内核完全控制着内存的使用情况,linux会在需要内存的时候,或在系统运行逐步推进时,将buffers和cached状态的内存变为free状态的内存,以供系统使用。
从应用层的角度来看系统内存的使用状态
也就是linux上运行的应用程序可以使用的内存大小,即free命令第三行“(-/+ buffers/cached)”的输出,可以看到,此系统已经使用的内存才K,而空闲的内存达到K,继续做这样一个计算:
41940+(465404+)=
通
过这个等式可知,应用程序可用的物理内存值是Mem项的free值加上buffers和cached值之和,也就是说,这个free值是包括
buffers和cached项大小的,对于应用程序来说,buffers/cached占有的内存是可用的,因为buffers/cached是为了提
高文件读取的性能,当应用程序需要用到内存的时候,buffers/cached会很快地被回收,以供应用程序使用。
buffers与cached的异同
在
Linux
操作系统中,当应用程序需要读取文件中的数据时,操作系统先分配一些内存,将数据从磁盘读入到这些内存中,然后再将数据分发给应用程序;当需要往文件中写
数据时,操作系统先分配内存接收用户数据,然后再将数据从内存写到磁盘上。然而,如果有大量数据需要从磁盘读取到内存或者由内存写入磁盘时,系统的读写性
能就变得非常低下,因为无论是从磁盘读数据,还是写数据到磁盘,都是一个很消耗时间和资源的过程,在这种情况下,linux引入了buffers和
cached机制。
buffers与cached都是内存操作,用来保存系统曾经打开过的文件以及文件属性信息,这样当操作系统需要读取
某些文件时,会首先在buffers与cached内存区查找,如果找到,直接读出传送给应用程序,如果没有找到需要数据,才从磁盘读取,这就是操作系统
的缓存机制,通过缓存,大大提高了操作系统的性能。但buffers与cached缓冲的内容却是不同的。
buffers是用来缓冲块设
备做的,它只记录文件系统的元数据(metadata)以及 tracking in-flight
pages,而cached是用来给文件做缓冲。更通俗一点说:buffers主要用来存放目录里面有什么内容,文件的属性以及权限等等。而cached
直接用来记忆我们打开过的文件和程序。
为了验证我们的结论是否正确,可以通过vi打开一个非常大的文件,看看cached的变化,然后再次vi这个文件,感觉一下两次打开的速度有何异同,是不是第二次打开的速度明显快于之一次呢?
接着执行下面的命令:
find /* -name *.conf
看看buffers的值是否变化,然后重复执行find命令,看看两次显示速度有何不同。
Linux操作系统的内存运行原理,很大程度上是根据服务器的需求来设计的,例如系统的缓冲机制会把经常使用到的文件和数据缓存在cached
中,linux总是在力求缓存更多的数据和信息,这样再次需要这些数据时可以直接从内存中取,而不需要有一个漫长的磁盘操作,这种设计思路提高了系统的整
体性能。
交换空间swap的使用
虽然现在的内存已经变得非常廉价,但是swap仍然有很大的使用价值,合理的规划和使用swap分区,对系统稳定运行至关重要。Linux下可以使用文件系统中的一个常规文件或者一个独立分区作为交换空间使用。同时linux允许使用多个交换分区或者交换文件。
创建swap交换空间
创建交换空间所需的交换文件是一个普通的文件,但是,创建交换文件与创建普通文件不同,必须通过dd命令来完成,同时这个文件必须位于本地硬盘上,不能在网络文件系统(NFS)上创建swap交换文件。例如:
# dd if=/dev/zero of=/data/swapfile bs=1024 count=65536
65536+0 records in
65536+0 records out
这样就创建一个有连续空间的交换文件,大小为60M左右,关于dd命令做简单的讲述:
if=输入文件,或者设备名称。
of=输出文件或者设备名称。
ibs=bytes 表示一次读入bytes 个字节(即一个块大小为 bytes 个字节)。
obs=bytes 表示一次写bytes 个字节(即一个块大小为 bytes 个字节)。
bs=bytes,同时设置读写块的大小,以bytes为单位,此参数可代替 ibs 和 obs。
count=blocks 仅拷贝blocks个块。
skip=blocks 表示从输入文件开头跳过 blocks 个块后再开始复制。
seek=blocks表示从输出文件开头跳过 blocks 个块后再开始复制。(通常只有当输出文件是磁盘或磁带时才有效)
这里的输入设备/dev/zero代表一个输出永远为0的设备文件,使用它作输入可以得到全为空的文件。
激活和使用swap
首先通过mkswap命令指定作为交换空间的设备或者文件:
#mkswap /data/swapfile
Setting up swapspace version 1, size =kB
# free
totalusedfree shared buffers cached
Mem:
-/+ buffers/cache:
Swap:
从上面输出可知,我们指定了一个67104 kB的交换空间,而此时新建的交换空间还未被使用,下面简单介绍下mkswap命令,mkswap的一般使用格式为:
mkswap
参数:
-c:建立交换区前,先检查是否有损坏的区块。
-v0:建立旧式交换区,此为预设值。
-v1:建立新式交换区。
交换区大小:指定交换区的大小,单位为1024字节。
设置交换分区后,接着通过swapon命令激活swap:
#/usr/in/swapon /data/swapfile
# free
totalusedfree shared buffers cached
Mem:
-/+ buffers/cache:
Swap:
通
过free命令可以看出,swap大小已经由k变为k,相差的值是60M左右,刚好等于我们增加的一个交换文件大小,这说明
新增的交换分区已经可以使用了,但是如果linux重启,那么新增的swap空间将变得不可用,因此需要在/etc/fstab中添加自动加载设置:
/data/swapfile none swap sw 0 0
如此以来,linux在重启后就可以实现自动加载swap分区了。其实linux在启动过程中会执行“swapon -a”命令,此命令会加载列在/etc/fstab中的所有交换空间。
移除swap
通过swapoff即可移除一个交换空间
#/usr/in/swapoff /data/swapfile
其实也可以通过“swapoff -a”移除在/etc/fstab中定义的所有交换空间,这里的“swapoff -a”与上面提到的“swapon -a”对应。执行“swapoff -a”后,free命令输出如下:
# free
totalusedfree shared buffers cached
Mem:
-/+ buffers/cache:
Swap:
关于linux 往内存写数据的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
成都创新互联科技有限公司,经过多年的不懈努力,公司现已经成为一家专业从事IT产品开发和营销公司。广泛应用于计算机网络、设计、SEO优化、关键词排名等多种行业!
分享名称:Linux中如何将数据写入内存(linux往内存写数据)
标题来源:http://www.mswzjz.cn/qtweb/news0/347000.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能