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

内存覆盖与交换

内存空间的扩充:覆盖技术,交换技术,虚拟存储技术 覆盖技术-解决程序大小超过物理内存总和问题(现在基本不用了),增加了编程负担 思想: 1)将程序分为多个段,常用的段常驻内存,不常用的段需要时调入内存...2)内存分为一个"固定区",若干个"覆盖区" 3)需要常驻的放在"固定区",调入后不在调出(除非运行结束) 4)不常用的段放在"覆盖区" 交换技术-将内存某些进程暂时换出外存,把外存某些具备运行条件的进程换入内存...(进程在内存与磁盘间动态调整),中级调度内存调度中的进程挂起 1)磁盘分为文件区和交换区,交换区使用连续分配方式,交换区的i/o速度比文件区更快 2)如果进程经常出现缺页,说明内存紧张,可以换出一些进程

92110

内存与IO的交换

file-backed pages在内存不足的时候可以直接写回对应的硬盘文件里,称为page-out,不需要用到交换区(swap);而anonymous pages在内存不足时就只能写到硬盘上的交换区(...但是常驻内存的话,就会吃内存,可以通过给硬盘搞一个swap分区或硬盘中创建一个swap文件让匿名页也能交换到磁盘上。可认为是为匿名页伪造的文件背景。...swap分区或swap文件实际上最终是到达了增大内存的效果。当然,如果频繁交换的话,被交换出去的数据的访问就会慢一些,因为要有IO操作了。 1....zRAM机制 不用swap分区,也可以用zRAM机制来缓解内存紧张: 从内存里拿出一段内存空间(compressed block),作为交换空间模拟硬盘的交换分区,用来交换匿名页,并且让kernel看到的物理内存大小不包括这段内存...Android里面普遍使用了zRAM技术,由于zRAM牺牲了CPU时间,所以交换次数还是越少越好。像Android和windows,内存越大越好,因为发生交换的几率就小。

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

LyScript 内存交换与差异对比

LyScript 针对内存读写函数的封装功能并不多,只提供了内存读取和内存写入函数的封装,本篇文章将继续对API进行封装,实现一些在软件逆向分析中非常实用的功能,例如内存交换内存区域对比,磁盘与内存镜像比较...插件地址:https://github.com/lyshark/LyScript内存区域交换: 实现被加载程序内特定一块内存区域的交换,该方法实现原理就是两个变量之间的交换,只是在交换时需要逐个字节进行...from LyScript32 import MyDebug# 交换两个内存区域def memory_xchage(dbg,memory_ptr_x,memory_ptr_y,bytes): ref...flag = memory_xchage(dbg, 6815744,6815776,4) print("内存交换状态: {}".format(flag)) dbg.close()PE...文件头节点交换后如下:图片内存区域对比: 可用于对比该进程内存中的特定一块区域的差异,返回是列表中的字典形式,分别传入对比内存x,y以及需要对比的内存长度,此处建议不要超过1024字节。

48520

内存与IO的交换【转】

file-backed pages在内存不足的时候可以直接写回对应的硬盘文件里,称为page-out,不需要用到交换区(swap);而anonymous pages在内存不足时就只能写到硬盘上的交换区(...但是常驻内存的话,就会吃内存,可以通过给硬盘搞一个swap分区或硬盘中创建一个swap文件让匿名页也能交换到磁盘上。可认为是为匿名页伪造的文件背景。...swap分区或swap文件实际上最终是到达了增大内存的效果。当然,如果频繁交换的话,被交换出去的数据的访问就会慢一些,因为要有IO操作了。 1....zRAM机制 不用swap分区,也可以用zRAM机制来缓解内存紧张: 从内存里拿出一段内存空间(compressed block),作为交换空间模拟硬盘的交换分区,用来交换匿名页,并且让kernel看到的物理内存大小不包括这段内存...Android里面普遍使用了zRAM技术,由于zRAM牺牲了CPU时间,所以交换次数还是越少越好。像Android和windows,内存越大越好,因为发生交换的几率就小。

65420

LyScript 内存交换与差异对比

LyScript 针对内存读写函数的封装功能并不多,只提供了内存读取和内存写入函数的封装,本篇文章将继续对API进行封装,实现一些在软件逆向分析中非常实用的功能,例如内存交换内存区域对比,磁盘与内存镜像比较...插件地址:https://github.com/lyshark/LyScript 内存区域交换: 实现被加载程序内特定一块内存区域的交换,该方法实现原理就是两个变量之间的交换,只是在交换时需要逐个字节进行...from LyScript32 import MyDebug # 交换两个内存区域 def memory_xchage(dbg,memory_ptr_x,memory_ptr_y,bytes):...(memory_ptr_x + index) read_byte_y = dbg.read_memory_byte(memory_ptr_y + index) # 交换内存...) PE文件头节点交换后如下: 内存区域对比: 可用于对比该进程内存中的特定一块区域的差异,返回是列表中的字典形式,分别传入对比内存x,y以及需要对比的内存长度,此处建议不要超过1024字节。

51420

Linux的内存回收和交换

,将部分内存上的数据交换到swap空间上,以便让系统不会因内存不够用而导致oom或者更致命的情况出现。...那么内存回收和swap的关系,我们可以提出以下几个问题: 什么时候会进行内存回收呢? 哪些内存会可能被回收呢? 回收的过程中什么时候会进行交换呢? 具体怎么交换?...如果符合交换条件的内存较长,是不是可以不用全部交换出去?比如可以交换内存有100M,但是目前只需要50M内存,实际只要交换50M就可以了,不用把能交换的都交换出去。...这在很多应用场景下可以提高效率,比如文件服务器,或者依赖内存中cache比较多的应用场景。...这时候我们就希望不要swap,即使出现oom-killer也造成不了太大影响,但是不能允许服务器因为IO卡死像多米诺骨牌一样全部死机,而且无法登陆。

4.6K52

Linux swappiness参数设置与内存交换

简介 swappiness,Linux内核参数,控制换出运行时内存的相对权重。swappiness参数值可设置范围在0到100之间。...低参数值会让内核尽量少用交换,更高参数值会使内核更多的去使用交换空间。默认值为60(参考网络资料:当剩余物理内存低于40%(40=100-60)时,开始使用交换空间)。...swappiness参数值说明 vm.swappiness = 0 仅在内存不足的情况下--当剩余空闲内存低于vm.min_free_kbytes limit时,使用交换空间。...vm.swappiness = 1 内核版本3.5及以上、Red Hat内核版本2.6.32-303及以上,进行最少量的交换,而不禁用交换。...vm.swappiness = 10 当系统存在足够内存时,推荐设置为该值以提高性能。

10.1K20

22-内存空间扩充(覆盖与交换

覆盖技术 早期计算机内存很小,因此经常出现内存大小不够使用的情况,因此人们引入了覆盖技术,用来解决“程序大小超过物理内存总和”的问题 覆盖技术的思想在于,将程序分为多个段(多个执行模块),常用的模块常驻在内存中...交换技术 交换(对换)技术的设计思想:内存空间紧张时,系统将内存中某些进程暂时换出外存,把外存中某些已具备运行条件的进程换入内存(进程在内存与磁盘间动态调度) 之前所讲过的中级调度(内存调度),就是要决定哪个处于挂起状态的进程重新调入内存...回忆部分: 暂时换出外存等待的进程状态称为挂起状态(挂起态,suspend)挂起态又可以进一步细分为就绪挂起、阻塞挂起两种状态 进程的状态,控制与通信 交换技术需要考虑的问题 应该在外存(磁盘...什么时候应该交换? 交换通常在许多进程运行且内存吃紧时进行,而系统负荷降低就暂停。例如:在发现许多进程运行时经常发生缺页,就说明内存紧张,此时可以换出一些进程;如果缺页率明显下降,就可以暂停换出。...可优先换出阻塞进程;可换出优先级低的进程;为了防止优先级低的进程在被调入内存后很快又被换出,有的系统还会考虑进程在内存的驻留时间… 需要注意的一点就是整个过程中,进程的PCB始终还是存放在内存队列中的,

72620

操作系统 内存管理 覆盖与交换技术

不太经常使用的部分,它们存放在磁盘上,当调用它们时才被调入内存覆盖区。 交换技术 交换技术:在分时系统中,用户的进程比内存能容纳的数量要多,这就需要在磁盘上保存那些内存放不下的进程。...在需要运行这些进程时,再将它们装入内存。 进程从内存移到磁盘并再移动回内存称为交换交换技术是进程在内存与外存之间的动态调度,是由操作系统控制的。 后备存储区(又称盘交换区)。...目的:尽可能达到”足够快的交换进程,以使当CPU调度程序想重新调度CPU时,总有进程在内存中处于就绪(准备执行)状态“的理想状态,从而提高内存利用率。...交换技术的原理: (1)换出进程的选择:系统需要将内存中的进程换出时,应该选择那个进程? 根据时间片轮转法或基于优先数的调度算法来选择要换出的进程。...(2)交换时间的确定 在内存空间不够或有不够的危险时,还出内存中的部分进程到外存,以释放所需要的内存。 (3)交换空间的分配 在一些系统中,当进程在内存中时,不再外塔分配磁盘空间。

2.2K10

服务器内存监测

而对于程序员而言,如何避免内存泄漏也是一门学问,倘若不加以控制,那么无论多大的内存都会有消耗殆尽的那天。...本文当然不是研究如何分析内存泄漏的产生原因与解决方案,而是在此之前的一步,通过简单的内存监测方式来预测内存泄漏的 潜在可能性 或者 偶发性 等。...我这边需要监测 系统内存 与 jvm堆内存 ,最终的结果会展示各个时间点的内存情况,所以需要一个时间类,表示每个切片的时间点。...timeMarkInterval是存储定时器id的,在销毁之前释放定时器;physicMemory和heapMemory获取图表div节点,用于echarts节点获取;systemInfo则会存储定时从服务器拉取到的数据...由图可见我这个系统堆内存通常消耗不到一百兆,后续可以将堆内存设定的再小一些,以提供给其它服务使用。总体内存是稳定状态,达到一定值会自动回收垃圾,占用率不会逐步提高,是个可控的系统。

11520

一文看懂 | 内存交换机制

相对于内存来说, 磁盘的容量是非常大的, 所以Linux内核实现了一个叫 内存交换 的功能 -- 把某些进程的一些暂时用不到的内存页保存到磁盘中, 然后把物理内存页分配给更紧急的用户使用, 当进程用到时再从磁盘读回到内存中即可...有了 内存交换 功能, 系统可使用的内存就可以远远大于物理内存的容量....LRU算法 内存交换 过程首先是找到一个合适的用户进程内存管理结构,然后把进程占用的内存交换到磁盘中,并断开虚拟内存与物理内存的映射,最后释放进程占用的内存页。...如果被交换出去的内存页刚好又被访问了,这时又需要从磁盘中把内存页的数据交换内存中。所以,在这种情况下不单不能解决内存紧缺的问题,而且增加了系统的负荷。...著名的缓存服务器 memcached 就是使用这种 LRU算法. Linux内核也使用了类似的算法, 但相对要复杂一些. Linux内核维护着三个队列: 活跃队列, 非活跃脏队列和非活跃干净队列.

96930

服务器内存监测

而对于程序员而言,如何避免内存泄漏也是一门学问,倘若不加以控制,那么无论多大的内存都会有消耗殆尽的那天。...本文当然不是研究如何分析内存泄漏的产生原因与解决方案,而是在此之前的一步,通过简单的内存监测方式来预测内存泄漏的 潜在可能性 或者 偶发性 等。...我这边需要监测 系统内存 与 jvm堆内存 ,最终的结果会展示各个时间点的内存情况,所以需要一个时间类,表示每个切片的时间点。...timeMarkInterval是存储定时器id的,在销毁之前释放定时器;physicMemory和heapMemory获取图表div节点,用于echarts节点获取;systemInfo则会存储定时从服务器拉取到的数据...由图可见我这个系统堆内存通常消耗不到一百兆,后续可以将堆内存设定的再小一些,以提供给其它服务使用。总体内存是稳定状态,达到一定值会自动回收垃圾,占用率不会逐步提高,是个可控的系统。

15040

linux服务器内存

早上到单位 发现服务器 mysql 服务器停了 然后起来了 查询日志 显示 内存满了 把mysql服务给杀了 linux 服务器如果 内存满了 会自动清理进程 防止服务器挂掉 选择的话 谁占的的内存大...就先杀谁 我的服务器里面 mysql服务占的内存是最大的 所以就把mysql就给杀了 image.png 然后 重启mysql 查询内存 image.png 在这说一下 怎么看linux的内存 举个例子...第三部分是指交换分区, 我想不讲大家都明白. 我想大家看了上面,还是很晕.第一部分(Mem)与第二部分(-/+ buffers/cache)的结果中有关used和free为什么这么奇怪....记住内存是拿来用的,不是拿来看的.不象windows, 无论你的真实物理内存有多少,他都要拿硬盘交换文件来读.这也就是windows为什么常常提示虚拟空间不足的原因.你们想想,多无聊,在内存还有大部分的时候...,拿出一部分硬盘空间来充当内存.硬盘怎么会快过内存.所以我们看linux,只要不用swap的交换空间,就不用担心自己的内存太少.如果常常 swap用很多,可能你就要考虑加物理内存了.这也是linux看内存是否够用的标准哦

31.8K10

Linux服务器创建和删除Swap交换分区

需求最近有项目需要用到 Mysql8.0 ,但是腾讯云轻量服务器的4G内存,实际可用只有3600多M,在编译安装 Mysql8.0 的时候会 Kill 掉安装进程,导致安装失败。...所以就需要给 Linux 服务器添加 Swap 交换分区(就相当于 Windows 的虚拟内存),来保证能够成功编译安装 Mysql8.0,需要注意的是,使用 Swap 交换分区会比较吃磁盘的性能,如果磁盘性能不够好...,可能会对服务器的性能产生负面影响这里使用的系统是 Centos7.9 其他系统请自行测试关于 swap 空间的大小很多老的教程都说 swap 空间要设置到自己物理内存的1.5~2倍但是看到Redhat...官方的文档中的建议,感觉更合理物理内存建议的交换空间大小 4G 内存的2倍,不超过4G4G~8G 等于物理内存大小 8G~64G 设置为8G 创建 swap 空间,会占用磁盘空间,请注意自己的磁盘的剩余空间查看当前系统...# 默认一般是30,建议设置为10,即内存剩余小于10%的时候使用swap内存echo "vm.swappiness = 10" >> /etc/sysctl.conf使配置生效sysctl -p重启服务器

29720

怎样给Linux服务器添加Swap交换空间

演示系统:Debian Server 9.9,所有操作在root用户模式下 计算机中Swap空间也就是交换空间,Swap空间是电脑硬盘中的一部分,当计算机的实际内存不够用的时候,操作系统会去使用Swap...第一步,检查时候有Swap空间 我们可以看到Swap空间为空 第二步,创建swap分区 创建2G的swap,可以根据你的服务器配置来调整大小,一般情况下,Swap空间不需要很大 dd if=/dev/...zero of=/mnt/swap bs=1M count=2048 设置交换分区文件 mkswap /mnt/swap 启动swap swapon /mnt/swap 设置开机时自启用 swap...分区,需要修改文件 /etc/fstab 中的 swap 行,添加以下代码 /mnt/swap swap swap defaults 0 0 如图所示 重启服务器之后,可以看到多出了swap空间

4.1K10

计算机网络之数据交换(电路交换,报文交换,分组交换)电路交换报文交换分组交换分组交换与电路交换

电路交换 报文交换 分组交换 如何实现数据通过网络核心从源主机到达目的主机? 就要经过网络核心进行数据交换,数据不断从一个网络交换到另一个网络,直到到达目的主机。...数据交换主要有三种: 电路交换 报文交换 分组交换 电路交换 最典型电路交换网络:电话网络 电路交换的三个阶段: 建立连接(呼叫/电路建立) 通信 释放连接(拆除电路) 电路交换是独占资源的,建立连接之后...image.png 分组交换 分组:报文分拆出来的一系列相对较小的数据包 分组交换需要报文的拆分与重组 分组交换相对于报文交换会产生额外开销,因为i要进行数据的拆分和重组 ?...image.png 报文交换与分组交换均采用存储-转发交换方式 区别是: 报文交换以完整报文进行“存储-转发” 分组交换以较小的分组进行“存储-转发 两种方式各有各的特点,下面我们就具体的分析 首先从发送速率上来说...分组交换的报文交付时间的计算公式: ? image.png 分组交换与电路交换 分组交换允许更多用户同时使用网络!——网络资源充分共享 分组交换绝对优于电路交换

1.8K10
领券