4.4.3 动态ISM共享内存
动态紧密共享内存(DISM)最早是在Solaris 8 1/01版本(第三个更新版)中引进的,其目的是为了给应用程序提供动态可变大小的ISM共享内存。第一个支持DISM的主要应用程序是Oracle 9i。Oracle 9i使用DISM是为了它新引入的动态系统全局区域(SGA、System Global Area)功能。
对于普通的ISM,一旦ISM块被生成,则不可能去改变它的大小。为了改变数据库缓冲区的尺寸,数据库必须关闭再重启(或设计为使用一组可变数量的共享内存块——这是一种更为复杂的替代方法)。这种限制对系统可用性有负面影响,例如,如果内存由于动态重新配置事件而被系统删除,一个或多个数据库实例会不得不关闭。DISM就是为了克服这种限制而设计的。当数据库启动时,会生成一个较大的DISM内存块,其中的各段可以随着内存需求的变化而选择性的被加锁、解锁。为DISM内存加锁不是由内核自动完成的,而是由应用程序(例如,Oracle)进行加锁、解锁,这样为动态调整提供了灵活性。
除了DISM不像ISM那样自动加锁外,DISM与ISM大体相似的。是由应用程序,而不是内核通过调用mlock()进行锁操作。内核的虚存-物理内存地址转换结构由附加在DISM内存块的进程共享,这样可以节省内核存储空间和CPU时间。
4.4.3.1 DISM性能
这个Solaris版本中测试表明,DISM和ISM性能相当。这是一个重要的进展,因为这意味着DISM在可用性上的改进,而不会在性能上有任何的损失。
4.4.3.2 DISM实现
使用ISM机制,shmget(2)生成内存块。shmget()所指定的大小是整个内存块的大小,也就是最大尺寸。内存块的大小可以大于物理内存。如果内存块尺寸比物理内存块大,那么就应该有足够的磁盘交换空间来满足最大可能的DISM尺寸。
DISM内存块通过shmat(2)接口,被附加到某个进程。新标志位SHM_DYNAMIC,通知shmat(2)生成动态ISM。物理内存是根据访问所需要的页面大小来分配,或者是根据在DISM虚拟区域中加锁所需要的页面大小来分配。
| 回书目 |
|
· 第六章 你能帮我吗?.. · Linux笔试面试题选摘测.. · 08年5月软考网管上午真.. · 性能测试从零开始 目录 · 08年5月软考网工上午真.. · 上周拒绝服务攻击(DDo.. |
· 08年5月各大网上书店及.. · 2008年5月24日软考试题.. · 软件设计师专家临考模.. · 上周网络管理员专家自.. · 网络工程师自测获奖名.. · 08年4月各大网上书店及.. |
|
||||
| · NAC安全访问控制 · 网络布线测试仪器 · Windows Server 2008专.. · Windows远程桌面应用 · 网络故障排除宝典 · 运营商封堵ADSL共享 中.. · 解析35岁技术人的价值.. · 世纪枭雄比尔盖茨的王.. |
· 主流品牌防火墙配置 · ASP.NET开发教程 · 超级计算机TOP500专题 · Vista SP1对决XP SP3 · SQL Server 2008/2005.. · 程序员如何成长? · C#技术开发指南 · 虚拟化技术还有点“虚” |
|||
|
||||
| · SOA 面向服务架构 · SQL Server 2008/2005.. · Apache技术专题 · 三层交换技术专题 · SQL Server入门到精通 · Windows远程桌面应用 · C#技术开发指南 · Apache技术专题 |
· Windows集群服务应用 · C#技术开发指南 · 国际文档格式标准开战 · 路由器设置与口令恢复 · Linux 集群技术专题 · PHP开发应用手册 · SOA 面向服务架构 · 企业数据恢复指南 |
|||
|
||||
| · SQL Server入门到精通 · SQL Server 2008/2005.. · SOA 面向服务架构 · Apache技术专题 · C#技术开发指南 · 三层交换技术专题 · Apache技术专题 · C#技术开发指南 |
· Windows远程桌面应用 · 企业数据恢复指南 · Windows集群服务应用 · 路由器设置与口令恢复 · Linux 集群技术专题 · SOA 面向服务架构 · 了解统一威胁管理(UTM).. · 反垃圾邮件技术应用 |
|||