四 ASP NET缓存API
在写应用程序之前 你要做的第一件事是让应袜逗用程序最大化的利用ASP NET的缓存功能
如果你的组件是要在Asp net应用程序中运行 你只要把System Web dll引用到你的项目中就可以了 然后用HttpRuntime Cache属性就可访问Cache了(也可以通过Page Cache或HttpContext Cache访问)
有以下几条缓存数据的规则 第一 数据可能会被频繁的被使用 这种数据可以缓存 第二 数据的访问频率非常高 或者一个数据的访问频率不高 但是它的生存周期很长 这样的数据最好也缓存起来 第三是一个常常被忽略的问题 有时候我们缓存了太多数据 通常在一台X 的机弊迅子上 如果你要缓存的数据超过 M的话 就会出现内存溢出的错误 所以说缓存是有限的 换名话说 你应该估计缓存集的大小 把缓存集的大小限制在 以内 否则它可能会出问题 在Asp net中 如果缓存过大的话也会报内存溢出错误 特别是如果缓存大的DataSet对象的时候
这里有几个你必须了解的重要的缓存机制 首先是缓存实现了 最近使用 原则( a least recently used algorithm) 当缓存少的时候 它会自动的强制清除那些无用的缓存 其次 条件依赖 强制清除原则(expiration dependencies) 条件可以是时间 关键字和文件 以时间作为条件是最常用的 在asp net 中增加一更强的条件 就是数据库条件 当数据库中的数据发生变化时 就会强制清除缓存 要更深入的了解数据库条件依赖请看Dino Esposito 在MSDN杂志 年七月刊的Cutting Edge专栏文章 Asp net的缓存架构如下图所示 五 预请求缓存
在前面 我提到过即使我们只对某些地方作了一个小小的性能改进也可以获得大的性能提升 我非常喜欢用预请求缓存来提升程序的性能
虽然Cache API设计成用来保存某段时间的数据 而预请求缓存只是保存某个时期的某个请求的内容 如果某个请求的访问频率高 而且这个请求只需要提取 应用 修改或者更新数据一次 那么就可以预缓存该请求 我们举个例子来说明
在CS的论坛应用程序中 每一个页面的服务器控件都要求得到用于决定它的皮肤(skin)的自定义的数据 以决定用哪个样式表及其它的一些个性化的东西 这里面的某些数据可能要长时间的保存 有些时间则不然 如控件的skin数据 它只需要应用一次 而后就可以一直使用
要实现预请求缓存 用Asp net 的HttpContext类 HttpContext类的实例在每一个请求中创建 在请求期间的任何地方都可以通过HttpContext Current属性访问 HttpContext类有一个Items集合属性 在请求期间所有的对象和数据都被添加到这个集合中缓存起来 和你用Cache缓存访问频率高租好此数据一样 你可以用HttpContext Items缓存那些每个请求都要用到的基础数据 它背后的逻辑很简单 我们向HttpContext Items中添加一个数据 然后再从它里面读出数据
六 后台处理
通过上面的方法你的应用程序应该运行得很快了 是不是?但是在某些时候 程序中的一次请求中可能要执行一个非常耗时的任务 如发送邮件或者是检查提交的数据的正确性等
当我们把asp net Forums 集成在CS中的时侯 发现提交一个新的帖子的时候会非常的慢 每次新增一个帖子的时侯 应用程序首先要检查这个帖子是不是重复提的 然后用 badword 过滤器来过滤 检查图片附加码 作帖子的索引 把它添加到合适的队列中 验证它的附件 最后 发邮件到它的订阅者邮件箱中 显然 这个工作量很大
结果是它把大量的时间都花在做索引和发送邮件中了 做帖子的索引是一项很耗时的 *** 作 而发邮件给订阅都需要连接到SMTP服务 然后给每一个订阅者都发一封邮件 随着订阅用户的增加 发送邮件的时间会更长
索引和发邮件并不需要在每次请求时触发 理想状态下 我们想要批量的处理这些 *** 作 每次只发 封邮件或者每隔 分钟把所有的要发的新邮件发一次 我们决定使用与数据库原型缓存一样的代码 但是失败了 所以又不得不回到VS NET
我们在System Threading命名空间下找到了Timer类 这个类非常有用 但却很少有人知道 Web开发人员则更少有人知道了 一旦他建了该类的实例 每隔一个指定的时间 Timer类就会从线程池中的一个线程中调用指定的回调函数 这意味着你的asp net应用程序可以在没有请求的时候也可以运行 这就是后以处理的解决方案 你就可以让做索引和发邮件工作在后台运行 而不是在每次请求的时候必须执行
后台运行的技术有两个问题 第一是 当你的应用程序域卸载后 Timer类实例就会停止运行了 也就是不会调用回调方法了 另外 因为CLR的每个进程中都有许多的线程在运行 你将很难让Timer获得一个线程来执行它 或者能执行它 但会延时 Asp net层要尽量少的使用这种技术 以减少进程中线程的数量 或者只让请求用一小部分的线程 当然如果你有大量的异步工作的话 那就只能用它了
lishixinzhi/Article/program/net/201311/15286
Oracle 分区功能可芹孝以提高许多应用程序的可管理性 性能与可用性 通过分区功能 可以将表 索引和索引组织表进一步细分为段 从而能够更精确地管理和访问这些数据库对象 Oracle 提供了种类繁多的分区方案以满足每种业务要求 而且 因为在 SQL 语句中分区是完全透明的 所以该功能几乎可应用于任何应用程序
分区功能的优势
分区功能通过改善可管理性 性能和可用性 从而为各式应用程序带来了极大的好处 通常 分区可以使某些查询以及维护 *** 作的性能大大提高 此外 分区还可以极大简化常见的管理任务 通过分区 数据歼首带库设计人员和管理员能够解决前沿应用程序带来的一些难题 分区是构建千兆字节数据系统或超高可用性系统的关键工具
分区功能的基本知识
分区功能能够将表 索引或索引组织表进一步细分为段 这些数据库对象的段叫做分区 每个分区有自己的名称 还可以选择自己的存储特性 从数据库管理员的角度来看 一个分区后的对象具有多个段 这些段既可进行集体管理 也可单独管理 这就使数据库管理员在管理分区后的对象时有相当氏芦大的灵活性 但是 从应用程序的角度来看 分区后的表与非分区表完全相同 使用 SQL DML 命令访问分区后的表时 无需任何修改
表的分区是通过 分区键 来实现的 分区键指的是一些列 这些列决定了某一行所在的分区 Oracle 数据库 g 提供了六项技术用于对表进行分区
范围分区
每个分区都由一个分区键值范围指定(对于一个以日期列作为分区键的表 年 月 分区包含分区键值为从 年 月 日 到 年 月 日 的行)
列表分区
每个分区都由一个分区键值列表指定(对于一个地区列作为分区键的表 北美 分区可能包含值 加拿大 美国 和 墨西哥 )
散列分区
将散列算法用于分区键来确定指定行所在的分区
组合范围散列分区
范围和散列分区技术的组合 通过该组合 首先对表进行范围分区 然后针对每个单独的范围分区再使用散列分区技术进一步细分 索引组织表只能进行范围分区
组合范围列表分区
范围和列表分区技术的组合 通过该组合 首先对表进行范围分区 然后针对每个单独的范围分区再使用列表分区技术进一步细分 索引组织表可以按范围 列表或散列进行分区
Oracle 数据库 g 还提供了三种类型的分区索引
本地索引
本地索引是其分区方式与其所在基础表的分区方式一模一样的索引 本地索引的每个分区仅对应于其所在基础表的一个分区
全局分区索引
全局分区索引是使用不同于其所在表的分区键进行分区的索引 其所在表可以是分区表或非分区表 全局分区的索引可以使用范围或散列分区进行分区 例如 某个表可以按月份进行范围分区 因此具有十二个分区 而该表上的索引则可以使用不同的分区键进行范围分区 从而具有不同的分区数量
全局非分区索引
全局非分区索引基本上和非分区表的索引一样 索引结构是不分区的
Oracle 提供了一系列丰富的技术 可用于对表 索引和索引组织表进行分区 因此可以针对任何业务环境中的任何应用程序进行最佳的分区 Oracle 还提供一套完整的 SQL 命令 用于管理分区表 其中包括添加新分区 删除分区 分拆分区以及合并分区的命令
用分区功能提高可管理性
通过 Oracle 分区功能 可将表和索引分成更多 更小的可管理单元 从而使数据库管理员能以 化整为零 个个击破 的方式管理数据
使用分区功能 维护 *** 作可集中于表的特定部分 例如 数据库管理员可以只对表的一部分做备份 而不必对整个表做备份 对整个数据库对象的维护 *** 作 可以在每个分区的基础上进行 从而将维护工作分解成更容易管理的小块
利用分区功能提高可管理性的一个典型用法是支持数据仓库中的 滚动视窗 加载进程 假设数据库管理员每周向表中加载新数据 可以对该表进行范围分区 使每个分区包含一周的数据 这样加载进程只是简单地添加新的分区 添加一个分区的 *** 作比修改整个表效率高很多 因为 DBA 不需要修改任何其他分区
用分区功能提高性能
由于限制了所检查或 *** 作的数据数量 同时支持并行任务执行 Oracle 分区功能实现了性能上增益 这些特性包括
分区修整
分区修整是用分区功能提高性能的最简单最有价值的手段 分区修整常常能够将查询性能提高几个数量级 例如 假设某个应用程序包含一个存储订单历史记录的 Orders 表 并且此表已按周分区 查询一周的订单只需访问该订单表的一个分区 如果该订单表包含两年的历史记录 这个查询只需要访问一个分区而不是一百零四个 该查询的执行速度因为分区修整而有可能快一百倍 分区修整能与所有其他 Oracle 性能特性协作 Oracle 能将分区修整功能与任何索引技术 联接技术或并行访问方法结合使用
分区智能联接
分区功能可以通过称为分区智能联接的技术提高多表联接的性能 当两个表要联接在一起 而且每个表都用联接键来分区时 就可以使用分区智能联接 分区智能联接将大型联接分解成较小的发生在各个分区间的联接 从而用较少的时间完成全部联接 这就给串行和并行的执行都能带来显著的性能改善
用分区功能提高可用性
分区的数据库对象具有分区独立性 该分区独立性特点可能是高可用性战略的一个重要部分 例如 如果分区表的一个分区不能用 但该表的所有其他分区仍然保持在线并可用 那么这个应用可以继续针对该分区表执行查询和事务处理 只要不是访问不可用的分区 数据库 *** 作仍然能够成功运行
数据库管理员可以指定各分区存放在不同的表空间里 从而让管理员隔离其它表分区针对单个分区进行备份与恢复 *** 作 还有 分区功能可以减少计划停机时间 由于分区功能改善了性能 使数据库管理员能用相对较少的时间完成大型数据库对象的维护工作
未来发展方向
自从引入分区技术以来 Oracle 公司在每次推出重要版本时都会增加新的分区方法 Oracle 引入了范围分区功能 Oracle i 引入了散列和组合范围散列分区功能 Oracle i 引入了列表分区功能 在最新版本 Oracle 数据库 g 中 则增强了用于索引组织表和全局分区索引的分区策略 并且扩展了其用于所有分区维护 *** 作的并发索引维护功能 Oracle 公司致力于不断完善分区技术 确保满足所有的业务需求
结论
lishixinzhi/Article/program/Oracle/201311/16823
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)