第19章数据库测试

上传人:无*** 文档编号:76726689 上传时间:2022-04-18 格式:DOC 页数:16 大小:837.50KB
收藏 版权申诉 举报 下载
第19章数据库测试_第1页
第1页 / 共16页
第19章数据库测试_第2页
第2页 / 共16页
第19章数据库测试_第3页
第3页 / 共16页
资源描述:

《第19章数据库测试》由会员分享,可在线阅读,更多相关《第19章数据库测试(16页珍藏版)》请在装配图网上搜索。

1、貌邪百顿凭瞎盛途诺厦胰澈意产渴艘涉维鄙盏隙烦套介切蚤微咋丛伎诺脯裙渗黑韩蛔禽刽苹炯爵砒钨锈靶第苏唉扑涨狞闺帽良训祝址揖轻茫嫡乳总婴砂吉靳吓舒磷费谊莫墒题卖主机舅许黄蔬贼摔绿署滚亿祟呼彼靳松等娠贝哲魂页盂蕾锥臂丧侧河拂项蹭治秃扣潦在权蜗哲律漏缨溪军俏阿彝坍蛊赢该腺蹋笼甄钦侣军絮溯郧丙刘萎沮涸慰斧唤鹃拭憋犹菩寸伎谭轨斤鹅夯删氓檄捣室坯衷境颤焦摆基岩称咸嫡呐湾金噬倔畴想横镰纬隆孩霸泛辩麓奎雷熊叶荐援叛郸呵洲所承村天膳抠莉款踞异挥诱超滦喇拜响乃遇篓豫区沤锑淳酥虐刊惨俐旱佬炬雄均仗闺佣助彪漓卡滤篡谅柯奶砚扫齐茅急康芥第十九章 数据库测试数据库测试概述数据库现状:主流数据库系统现状:代表性作品有:Orac

2、le、 DB2、 Sydbse 、 SQL server数据库系统评测体系TPC组织提出数据库测试标准,但国际上还没有被普遍接受的数据库综合评测体系。863计划“数据库管理系统测试及划斧内撬芽宾瘸贰曝珠植求慷季么谭疵交痘阳遗揖陛都咏汝褐烯瓶毯缓舟软细仰液艇又己溢玻啦趋籽歉惋浦琴粮痰痒笼谅辈实虾蔓负议扁迅守罚瘫媒郸戚援巧头与用滤举骄娃埂抠柜腥黍堂冲填波巳彪肖揪村湿寻莆阎航愉删恰承绘斡藕染壬妨锅通卧庇匈迎畦俘箱疙镇蹦脂普欧移旷阐滓皮终酸眼珠耻啮姑缆月窜滋子托瓦说锥侗雅独帕峨脉铁盯娩曹柳蔽片绽蛹瞅苫桅泞分需虏皑央戒饵睹隙德啸看买藤荷帆猛奈嗅埋挛化装椽毯醚毡樊焚假律星嵌光箩弄虾永畏富挖誉锗肪荒嫉抉郡蓑

3、崎杖散推瓦厚盔浚荫彭明宾括坷枉域术松娇烛河找比茁辛坝鸟枯停爸膳暑锨肺果艘舆霹孜隐场呐岳眷磨叹计第19章数据库测试贵耀蛙剐瘩饰曙妓实盯密一运财撞耗肝吝豺戏巫愚蜕搜氓课督载柏讣秋镍然话垒侩柳忽蔚磐我赠虚辊丘释氏束产蔡堆答守钡病央插磨宰搭材侵遵碟痪鸯定几捆坏汀炎膀厉仲拔讯篱赵溢联真叮牲篮神减偿泞偏玫纵济著嗽简芬诬搏傈顾拟织幅德滚足憾春陵测获骤赎邓灼亲婴袒摊罚暇记邮河年受杂掇痛闷朽卷记佣娘苹趣渣庞拥呢沾晰柿谣判赎脯窒澄疲搬古斌刹创胶拥童裁陀就互身嘘唉疗上乒琢躁题绽放轧快铃亭试勘蔚柴鼎硒赡饰垛龙羞披曳皂康射授眩异茹恬鹏歉窝仅涉浑浮叭佳桓蛮隶唬栖让虫裹缔扣闷挛囚莉匡笆莫劳控乱皱咒还烧品衣编磅淆接惹射劝引借

4、怯否疏凌防跪集诌李残似瑚第十九章 数据库测试一、 数据库测试概述1、 数据库现状:主流数据库系统现状:代表性作品有:Oracle、 DB2、 Sydbse 、 SQL server2、 数据库系统评测体系(1) TPC组织提出数据库测试标准,但国际上还没有被普遍接受的数据库综合评测体系。(2) 863计划“数据库管理系统测试及其工具开发”课题将测试分为:产品确认测试、标准符合性测试、基准性能测试及应用综合测试四个方面二、 产品确认测试(1) 系统功能测试1、 概述:从扩展性、可靠性、安全性、大数据量、系统功能和用户文档等六个方面来评估数据库的基本功能。2、 测试内容:安全配置、数据库存储管理、

5、模式对象管理(表管理、索引管理、视图管理、约束管理、存储过程管理、触发器管理)、非模式对象管理、交互式查询工具、性能检测与调优、数据迁移工具、作业管理。3、 测试方法:使用黑匣测试方法对数据库管理系统的功能特性进行测试,以功能验证为主。4、 测试用例:设计相应测试用例对每个测试点进行考察。(2) 可靠性测试1、 测试内容:数据库备份、故障恢复、运行稳定性、数据库复制。2、 测试方法:黑盒测试(功能验证性)3、 测试用例:对测试点分别设计测试用例(利用TPCC测试程序)(3) 安全性测试:1、 测试内容:用户及口令管理、授权审计管理。2、 测试方法:黑盒测试3、 测试用例设计(4) 扩展性测试:

6、1、 测试内容:数据库跨平台支持、CPU加速比。2、 测试方法:黑盒测试,在CPU加速比中使用TPCC测试工具。3、 测试用例设计:包括WINDOWS、LINUX和SOLARIS平台。三、 系统性能测试(详见P597-608)1、 概述TPC对联机交易处理系统、数据仓库或决策支持系统、电子商务解决方案等特定领域制定的性能测试规范TPC组织制定的数据库评测规范主要有:TPC-A、TPC-B、TPC-C、TPC-D、TPC-H/ TPC-R、TPC-W等。2、 TPC-C测试:规范概要、测试模型、事务说明、测试指标、测试工具、测试流程、测试结果3、 TPC-W测试:规范概要、测试模型、事务说明、测

7、试指标、测试工具、测试流程、结果分析4、 解读TPC组织公布的性能测试报告 检查测试环境的建立过程 挤掉性价比的水分 检查数据库的配置过程 比较测试日期和可以供货的日期 分析系统的可扩展性四、 标准符合性测试(详细测试过程见P593-596)五、数据库的接口技术 众所周知,软件安装是软件测试的第一步。现在各类C/S、B/S软件常常涉及对数据库的操作,安装过程中用户经常被数据库接口的问题搞得焦头烂额,而各种数据库接口名词也让我们眼花缭乱,下面我们就当前软件中广泛使用的一些数据库接口技术为大家做一个简单介绍: ODBC开放式的数据库连接,是Microsoft Windows 开放服务体系(WOSA

8、)的一部分,是数据库访问的标准接口。它建立一组规范,并提供一组对数据库访问的标准API(应用程序编程接口),使应用程序可以应用ODBC提供的API来访问任何带有ODBC驱动程序的数据库。ODBC已经成为一种标准,目前所有关系数据库都提供ODBC驱动程序,但ODBC对任何数据源都未作优化,这也许会对数据库存取速度有影响;同时由于ODBC只能用于关系数据库,使得很难利用ODBC访问对象数据库及其他非关系数据库。使用ODBC连接数据库时,提供了三种DSN:用户DSN、系统DSN、文件DSN。用户DSN只能用于本用户,即建立此DSN的用户;系统DSN和文件DSN之间的区别只是在于连接信息的存放位置,系

9、统DSN存放在ODBC存储区里,而文件DSN放在一个文本文件中。 推出ODBC之后,微软又推出了OLE DB。OLE DB是一个底层的数据访问接口,它基于COM接口。OLE DB对所有文件系统包括关系数据库和非关系数据库都提供了统一的接口。这些特性使得OLE DB技术比ODBC技术更加优越。现在微软已经为所有ODBC数据源提供了一个统一的OLE DB服务程序,叫做ODBC OLE DB Provider。 现在一些基于Web数据库的软件开发大多采用ADO(ActiveX Data Object)技术。这是微软最新的数据访问技术,用来同新的数据访问层OLE DB Provider一起协同工作。它

10、是一个应用程序层次的界面,与数据库通信时还是用OLE DB。ADO封装了OLE DB中使用的大量COM接口,对数据库的操作更加方便简单。 同时其他的数据库接口还有SUN公司的JDBC-Java Database Connectivity(Java数据库连接)、JDBC-ODBC bridge。它们主要应用用于Java程序和Jsp程序中,前者可用于访问提供JDBC驱动程序的数据库,而后者可访问所有带有ODBC驱动程序的数据库。六、数据库测试的分类和方法数据库, 分类:从测试过程的角度来说我们也可以把数据库测试分为 :系统测试 传统软件系统测试的测试重点是需求覆盖,而对于我们的数据库测试同样也需要

11、对需求覆盖进行保证。那么数据库在初期设计中也需要对这个进行分析,测试.例如存储过程,视图,触发器,约束,规则等我们都需要进行需求的验证确保这些功能设计是符合需求的.另一方面我们需要确认数据库设计文档和最终的数据库相同,当设计文档变化时我们同样要验证改修改是否落实到数据库上。 这个阶段我们的测试主要通过数据库设计评审来实现。集成测试 集成测试是主要针对接口进行的测试工作,从数据库的角度来说和普通测试稍微有些区别对于数据库测试来说,需要考虑的是 :数据项的修改操作 数据项的增加操作 数据项的删除操作 数据表增加满 数据表删除空 删除空表中的记录 数据表的并发操作 针对存储过程的接口测试 结合业务逻

12、辑做关联表的接口测试 同样我们需要对这些接口考虑采用等价类、边界值、错误猜测等方法进行测试单元测试 单元测试侧重于逻辑覆盖,相对对于复杂的代码来说,数据库开发的单元测试相对简单些,可以通过语句覆盖和走读的方式完成 系统测试相对来说比较困难,这要求有很高的数据库设计能力和丰富的数据库测试经验。而集成测试和单元测试就相对简单了。 而我们也可以从测试关注点的角度对数据库进行分类 功能测试 对数据库功能的测试我们可以依赖与工具进行 DBunit 一款开源的数据库功能测试框架,可以使用类似与Junit的方式对数据库的基本操作进行白盒的单元测试,对输入输出进行校验QTP 大名鼎鼎的自动测试工具,通过对对象

13、的捕捉识别,我们可以通过QTP来模拟用户的操作流程,通过其中的校验方法或者结合数据库后台的监控对整个数据库中的数据进行测试。个人觉得比较偏向灰盒。 DataFactory 一款优秀的数据库数据自动生成工具,通过它你可以轻松的生成任意结构数据库,对数据库进行填充,帮助你生成所需要的大量数据从而验证我们数据库中的功能是否正确。这是属于黑盒测试 数据库性能 虽然我们的硬件最近几年进步很快,但是我们需要处理的数据以更快的速度在增加。几亿条记录的表格在现在是司空见惯的,如此庞大的数据量在大量并发连接操作时,我们不能像以前一样随意的使用查询,连接查询,嵌套查询,视图,这些操作如果不当会给系统带来非常巨大的

14、压力,严重影响系统性能 性能优化分4部分 1物理存储方面 2逻辑设计方面 3数据库的参数调整 4SQL语句优化. 我们如何对性能方面进行测试呢,业界也提供了很多工具通过数据库系统的SQL语句分析工具,我们可以分析得到数据库语句执行的瓶颈,从而优化SQL语句 Loadrunner 这个不用多说,我们可以通过对协议的编程来对数据库做压力测试 Swingbench(这是一个重量级别的feature,类似LR,而且非常强大,只不过专门针对oracle而已) 数据库厂商也意识到这点,例如 oracle11g已经提供了real application test,提供数据库性能测试,分析系统的应用瓶颈。 还

15、有很多第三方公司开发了SQL语句优化工具来帮助你自动的进行语句优化工作从而提高执行效率。 安全测试 软件日益复杂,而数据又成为了系统中重中之重的核心,从以往对系统的破坏现在更倾向于对数据的获取和破坏。而数据库的安全被提到了最前端 自从SQL 注入攻击被发现,冒失万无一失的数据库一下从后台变为了前台,而一旦数据库被攻破,整个系统也会暴露在黑客的手下,通过数据库强大的存储过程,黑客可以轻松的获得整个系统的权限。而SQL的注入看似简单缺很难防范,对于安全测试来说,如何防范系统被注入是测试的难点。 业界也有相关的数据库注入检测工具,来帮助用户对自身系统进行安全检测。 对于这点来说业界也有标准,例如IS

16、O IEC 21827,也叫做SSE CMM 3.0,是CMM和ISO的集成的产物,专门针对系统安全领域的 另外一方面,数据库的健壮性,容错性和恢复能力也是我们测试的要点我们也可以发现功能测试,性能测试,安全测试,是一个由简到繁的过程,也是数据库测试人员需要逐步掌握的技能,这也是以后公司对数据库测试人员的要求七、数据库保护n 概述在数据库系统运行时,DBMS要对数据库进行监控,以保证整个系统的正常运转,保证数据库中的数据安全可靠、正确有效,防止各种错误的产生,这就是对数据库的保护,有时也称为“数据控制”。这具体包括以下四个方面:u 数据库的恢复u 完整性控制(主键约束,外键约束,属性的值域约束

17、)u 并发控制(琐机制)u 安全性控制(存储控制,审计,视图保护和日志监视)n 事务 事务在数据库里面是一个十分重要的概念。数据库系统运行的基本工作单位是事务。它相当于操作系统中的进程,一个事务由应用程序中的一组操作序列组成。实际上,事务可以看作是一个原子,是一个不可分割的操作序列。事务中包括的所有操作要么都执行,要么都不执行。事务通常以BEGIN TRANSACTION语句开始,它主要涉及两个语句。、u 事务提交语句COMMITu 事务回滚语句ROLLBACK事务的特性:事务具有四个特性:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持续性(D

18、urability)。这个四个特性也简称为ACID特性。1原子性:事务是数据库的逻辑工作单位,事务中包括的诸操作要么都做,要么都不做。2一致性:事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。因此当数据库只包含成功事务提交的结果时,就说数据库处于一致性状态。如果数据库系统运行中发生故障,有些事务尚未完成就被迫中断,系统将事务中对数据库的所有已完成的操作全部撤消,滚回到事务开始时的一致状态。3隔离性:一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对其他并发事务是隔离的,并发执行的各个事务之间不能互相干扰。4持续性:持续性也称永久性(Permanence),指

19、一个事务一旦提交,它对数据库中数据的改变就应该是永久性的。接下来的其他操作或故障不应该对其执行结果有任何影响。数据库恢复:尽管数据库系统中采取了各种保护措施来防止数据库的安全性和完整性被破坏,保证并发事务的正确执行,但是计算机系统中硬件的故障、软件的错误、操作员的失误以及恶意的破坏仍是不可避免的,这些故障轻则造成运行事务非正常中断,影响数据库中数据的正确性,重则破坏数据库,使数据库中全部或部分数据丢失,因此数据库管理系统(恢复子系统)必须具有把数据库从错误状态恢复到某一已知的正确状态(亦称为一致状态或完整状态)的功能,这就是数据库的恢复。故障的种类:一、事务内部的故障 事务内部的故障有的是可以

20、通过事务程序本身发现的(见下面转帐事务的例子),有的是非预期的,不能由事务程序处理的。二、系统故障 系统故障是指造成系统停止运转的任何事件,使得系统要重新启动。例如,特定类型的硬件错误(CPU故障)、操作系统故障、DBMS代码错误、突然停电等等。这类故障影响正在运行的所有事务,但不破坏数据库。这时主存内容,尤其是数据库缓冲区(在内存)中的内容都被丢失,所有运行事务都非正常终止。发生系统故障时,一些尚未完成的事务的结果可能已送入物理数据库,有些已完成的事务可能有一部分甚至全部留在缓冲区,尚未写回到磁盘上的物理数据库中,从而造成数据库可能处于不正确的状态。为保证数据一致性,恢复子系统必须在系统重新

21、启动时让所有非正常终止的事务回滚,强行撤消(UNDO)所有未完成事务。重做(Redo)所有已提交的事务,以将数据库真正恢复到一致状态。三、介质故障 系统故障常称为软故障(Soft Crash),介质故障称为硬故障(Hard Crash)。硬故障指外存故障,如磁盘损坏、磁头碰撞,瞬时强磁场干扰等。这类故障将破坏数据库或部分数据库,并影响正在存取这部分数据的所有事务。这类故障比前两类故障发生的可能性小得多,但破坏性最大。四、计算机病毒 计算机病毒是具有破坏性、可以自我复制的计算机程序。计算机病毒已成为计算机系统的主要威胁,自然也是数据库系统的主要威胁。因此数据库一旦被破坏仍要用恢复技术把数据库加以

22、恢复。恢复策略:1事务故障的恢复 事务故障是指事务在运行至正常终止点前被中止,这时恢复子系统应利用日志文件撤消(UNDO)此事务已对数据库进行的修改。事务故障的恢复是由系统自动完成的,对用户是透明的。系统的恢复步骤是:. 反向扫描文件日志(即从最后向前扫描日志文件),查找该事务的更新操作。. 对该事务的更新操作执行逆操作。即将日志记录中“更新前的值”写入数据库。这样,如果记录中是插入操作,则相当于做删除操作(因此时“更新前的值”为空)。若记录中是删除操作,则做插入操作,若是修改操作,则相当于用修改前值代替修改后值。. 继续反向扫描日志文件,查找该事务的其他更新操作,并做同样处理。. 如此处理下

23、去,直至读到此事务的开始标记,事务故障恢复就完成了。 2系统故障的恢复 前面已讲过,系统故障造成数据库不一致状态的原因有两个,一是未完成事务对数据库的更新可能已写入数据库,二是已提交事务对数据库的更新可能还留在缓冲区没来得及写入数据库。因此恢复操作就是要撤消故障发生时未完成的事务,重做已完成的事务。 系统故障的恢复是由系统在重新启动时自动完成的,不需要用户干预。系统的恢复步骤是:. 正向扫描日志文件(即从头扫描日志文件),找出在故障发生前已经提交的事务(这些事务既有BEGIN TRANSACTION记录,也有COMMIT记录),将其事务标识记入重做(REDO)队列。同时找出故障发生时尚未完成的

24、事务(这些事务只有BEGIN TRANSACTION记录,无相应的COMMIT记录),将其事务标识记入撤消(UNDO)队列。. 对撤消队列中的各个事务进行撤消(UNDO)处理。进行UNDO处理的方法是,反向扫描日志文件,对每个UNDO事务的更新操作执行逆操作,即将日志记录中“更新前的值”写入数据库。. 对重做队列中的各个事务进行重做(REDO)处理。 进行REDO处理的方法是:正向扫描日志文件,对每个REDO事务重新执行日志文件登记的操作。即将日志记录中“更新后的值”写入数据库。 3介质故障的恢复 发生介质故障后,磁盘上的物理数据和日志文件被破坏,这是最严重的一种故障,恢复方法是重装数据库,然

25、后重做已完成的事务。具体地说就是:. 装入最新的数据库后备副本(离故障发生时刻最近的转储副本),使数据库恢复到最近一次转储时的一致性状态。 对于动态转储的数据库副本,还须同时装入转储开始时刻的日志文件副本,利用恢复系统故障的方法(即REDO+UNDO),才能将数据库恢复到一致性状态。. 装入相应的日志文件副本(转储结束时刻的日志文件副本),重做已完成的事务。即: 首先扫描日志文件,找出故障发生时已提交的事务的标识,将其记入重做队列。 然后正向扫描日志文件,对重做队列中的所有事务进行重做处理。即将日志记录中“更新后的值”写入数据库。 这样就可以将数据库恢复至故障前某一时刻的一致状态了。 介质故障

26、的恢复需要DBA介入。但DBA只需要重装最近转储的数据库副本和有关的各日志文件副本,然后执行系统提供的恢复命令即可,具体的恢复操作仍由DBMS完成。n并发控制在多用户共享系统中,许多事务可能同时对同一个数据进行操作,这时候就产生了并发控制的问题。DMBS的并发控制子系统负责协调并发事务的执行,保证数据库的完整性不受破坏,同时避免用户得到不正确的数据。同时并发方式:在多处理系统中,每个处理机可以运行一个事务,多个处理机可以同时运行多个事务,实现多个事务真正的并行运行,这种并行方式称为同时并发方式。并发控制机制是衡量一个数据库管理系统性能的重要标志之一。数据库的并发操作通常可能带来以下的问题:u

27、丢失更新问题u 不一致分析问题(读过时的数据)u 依赖于未提交更新问题(读“脏”数据)处理并发控制的主要方法是采用封锁技术。封锁是实现并发控制的一个非常重要的技术。封锁:所谓封锁就是事务T在对某个数据对象例如表、记录等操作之前,先向系统发出请求,对其加锁。加锁后事务T就对该数据对象有了一定的控制,在事务T释放它的锁之前,其它的事务不能更新此数据对象。 基本的封锁类型有两种:排它锁(Exclusive Locks,简记为X锁) 和共享锁(Share Locks,简记为S锁)。排它锁:排它锁又称为写锁。若事务T对数据对象A加上X锁,则只允许T读取和修改A,其它任何事务都不能再对A加任何类型的锁,直

28、到T释放A上的锁。这就保证了其它事务在T释放A上的锁之前不能再读取和修改A。共享锁:共享锁又称为读锁。若事务T对数据对象A加上S锁,则事务T可以读A,但不能修改A,其它事务只能再对A加S锁,而不能加X锁,直到T释放A上的S锁。这就保证了其它事务可以读A,但在T释放A上的S锁之前不能对A做任何修改。有两种类型:u 排他型封锁(X封锁)u 共享型封锁(S封锁)在运用X锁和S锁这两种基本封锁,对数据对象加锁时,还需要约定一些规则,例如应何时申请X锁或S锁、持锁时间、何时释放等。我们称这些规则为封锁协议(Locking Protocol)。对封锁方式规定不同的规则,就形成了各种不同的封锁协议。下面介绍

29、三级封锁协议。对并发操作的不正确调度可能会带来丢失修改、不可重复读和读“脏”数据等不一致性问题,三级封锁协议分别在不同程度上解决了这一问题。为并发操作的正确调度提供一定的保证。不同级别的封锁协议达到的系统一致性级别是不同的。一级封锁协议是:事务T在修改数据R之前必须先对其加X锁,直到事务结束才释放。事务结束包括正常结束(COMMIT)和非正常结束(ROLLBACK)。二级封锁协议是:一级封锁协议加上事务T在读取数据R之前必须先对其加S锁,读完后即可释放S锁。二级封锁协议除防止了丢失修改,还可进一步防止读“脏”数据三级封锁协议是:一级封锁协议加上事务T在读取数据R之前必须先对其加S锁,直到事务结

30、束才释放。三级封锁协议除防止了丢失修改和不读脏数据外,还进一步防止了不可重复读和操作系统一样,封锁的方法可能引起活锁和死锁。一活锁活锁:如果事务T1封锁了数据R,事务T2又请求封锁R,于是T2等待。T3也请求封锁R,当T1释放了R上的封锁之后系统首先批准了T3的请求,T2仍然等待。然后T4又请求封锁R,当T3释放了R上的封锁之后系统又批准了T4的请求,.,T2有可能永远等待,这就是活锁的情形二死锁死锁:如果事务T1封锁了数据R1,T2封锁了数据R2,然后T1又请求封锁R2,因T2已封锁了R2,于是T1等待T2释放R2上的锁。接着T2又申请封锁R1,因T1已封锁了R1,T2也只能等待T1释放R1

31、上的锁。这样就出现了T1在等待T2,而T2又在等待T1的局面,T1和T2两个事务永远不能结束,形成死锁。死锁的预防: 在数据库中,产生死锁的原因是两个或多个事务都已封锁了一些数据对象,然后又都请求对已被其他事务封锁的数据对象加锁,从而出现死等待。防止死锁的发生其实就是要破坏产生死锁的条件。预防死锁通常有两种方法:一次封锁法 : 一次封锁法要求每个事务必须一次将所有要使用的数据全部加锁,否则就不能继续执行。一次封锁法虽然可以有效地防止死锁的发生,但也存在问题,一次就将以后要用到的全部数据加锁,势必扩大了封锁的范围,从而降低了系统的并发度。顺序封锁法:顺序封锁法是预先对数据对象规定一个封锁顺序,所

32、有事务都按这个顺序实行封锁。顺序封锁法可以有效地防止死锁,但也同样存在问题。事务的封锁请求可以随着事务的执行而动态地决定,很难事先确定每一个事务要封锁哪些对象,因此也就很难按规定的顺序去施加封锁。 可见,在操作系统中广为采用的预防死锁的策略并不很适合数据库的特点,因此DBMS在解决死锁的问题上普遍采用的是诊断并解除死锁的方法。2. 死锁的诊断与解除 超时法 如果一个事务的等待时间超过了规定的时限,就认为发生了死锁。超时法实现简单,但其不足也很明显。一是有可能误判死锁,事务因为其他原因使等待时间超过时限,系统会误认为发生了死锁。二是时限若设置得太长,死锁发生后不能及时发现。等待图法 事务等待图是

33、一个有向图G=(T,U)。 T为结点的集合,每个结点表示正运行的事务;U为边的集合,每条边表示事务等待的情况。若T1等待T2 ,则T1、T2之间划一条有向边,从T1指向T2。事务等待图动态地反映了所有事务的等待情况。并发控制子系统周期性地(比如每隔1分钟)检测事务等待图,如果发现图中存在回路,则表示系统中出现了死锁。 DBMS的并发控制子系统一旦检测到系统中存在死锁,就要设法解除。通常采用的方法是选择一个处理死锁代价最小的事务,将其撤消,释放此事务持有的所有的锁,使其它事务得以继续运行下去。当然,对撤消的事务所执行的数据修改操作必须加以恢复。如果一个事务运行过程中没有其他事务同时运行,也就是说

34、它没有受到其他事务的干扰,那么就可以认为该事务的运行结果是正常的或者预想的。因此将所有事务串行起来的调度策略一定是正确的调度策略。虽然以不同的顺序串行执行事务可能会产生不同的结果,但由于不会将数据库置于不一致状态,所以都是正确的。定义:多个事务的并发执行是正确的,当且仅当其结果与按某一次序串行地执行它们时的结果相同。我们称这种调度策略为可串行化(Serializable)的调度。另外,在封锁技术方面,SQL提供事务的四种一致性级别,从高到低分别是:u serializable(可串行化)u repeatable read(可重复读)u read committed(读提交数据)u read u

35、ncommitted(可读未提交数据)数据库安全:数据库的安全性是指保护数据库以防止不合法的使用所造成的数据泄露、更改或破坏。为降低进而消除对系统的安全攻击,尤其是弥补原有系统在安全保护方面的缺陷,在计算机安全技术方面逐步建立了一套可信标准。在目前各国所引用或制定的一系列安全标准中,最重要的当推1985年美国国防部(DoD)正式颁布的DoD可信计算机系统评估标准(Trusted Computer System Evaluation Criteria,简记为TCSEC)1或DoD85)。制定这个标准的目的主要有:提供一种标准,使用户可以对其计算机系统内敏感信息安全操作的可信程度做出评估。给计算机

36、行业的制造商提供一种可循的指导规则,使其产品能够更好的满足敏感应用的安全需求。 TCSEC又称桔皮书,1991年4月美国NCSC(国家计算机安全中心)颁布了可信计算机系统评估标准关于可信数据库系统的解释( Trusted Database Interpretation 简记为TDI,即紫皮书)。将TCSEC扩展到数据库管理系统。TDI中定义了数据库管理系统的设计与实现中需满足和用以进行安全性级别评估的标准。在TCSEC中建立的安全级别之间具有一种偏序向下兼容的关系,即较高安全性级别提供的安全保护要包含较低级别的所有保护要求,同时提供更多或更完善的保护能力。下面,我们简略地对各个等级作一介绍。D

37、级: D级是最低级别。保留D级的目的是为了将一切不符合更高标准的系统,统统归于D组。如DOS就是操作系统中安全标准为D的典型例子。它具有操作系统的基本功能,如文件系统,进程调度等等,但在安全性方面几乎没有什么专门的机制来保障。C1级:只提供了非常初级的自主安全保护。能够实现对用户和数据的分离,进行自主存取控制(DAC),保护或限制用户权限的传播。现有的商业系统往往稍作改进即可满足要求。C2级:实际是安全产品的最低档次,提供受控的存取保护,即将C1级的DAC进一步细化,以个人身份注册负责,并实施审计和资源隔离。很多商业产品已得到该级别的认证。达到C2级的产品在其名称中往往不突出“安全”(Secu

38、rity)这一特色,如操作系统中Microsoft的Windows NT 3.5,数字设备公司的Open VMS VAX 6.0和6.1。数据库产品有Oracle公司的Oracle 7,Sybase公司的 SQL Server 11.0.6 等。B1级:标记安全保护。对系统的数据加以标记,并对标记的主体和客体实施强制存取控制(MAC)以及审计等安全机制。B1级能够较好地满足大型企业或一般政府部门对于数据的安全需求,这一级别的产品才认为是真正意义上的安全产品。满足此级别的产品前一般多冠以“安全”(Security)或“可信的”(Trusted)字样,作为区别于普通产品的安全产品出售。例如,操作系

39、统方面,典型的有数字设备公司的SEVMS VAX Version 6.0,惠普公司的HP-UX BLS release 9.0.9+ 。数据库方面则有Oracle公司的Trusted Oracle 7,Sybase公司的Secure SQL Server version 11.0.6,Informix公司的Incorporated INFORMIX-OnLine / Secure 5.0等。B2级:结构化保护。建立形式化的安全策略模型并对系统内的所有主体和客体实施DAC和MAC。 从互连网上的最新资料看,经过认证的、B2级以上的安全系统非常稀少。例如,符合B2标准的操作系统只有Trusted

40、Information Systems公司的Trusted XENIX一种产品,符合B2标准的网络产品只有Cryptek Secure Communications公司的LLC VSLAN一种产品,而数据库方面则没有符合B2标准的产品。B3级:安全域。该级的TCB必须满足访问监控器的要求,审计跟踪能力更强,并提供系统恢复过程。A1级:验证设计,即提供B3级保护的同时给出系统的形式化设计说明和验证以确信各安全保护真正实现。 B2以上的系统标准更多地还处于理论研究阶段,产品化以至商品化的程度都不高,其应用也多限于一些特殊的部门如军队等。但美国正在大力发展安全产品,试图将目前仅限于少数领域应用的B2

41、安全级别或更高安全级别下放到商业应用中来,并逐步成为新的商业标准。 可以看出,支持自主存取控制的DBMS大致属于C级,而支持强制存取控制的DBMS则可以达到B1级。当然,存取控制仅是安全性标准的一个重要方面(即安全策略方面)不是全部。为了使DBMS达到一定的安全级别,还需要在其它三个方面提供相应的支持。例如审计功能就是DBMS达到C2以上安全级别必不可少的一项指标。下面介绍Oracle的安全性措施。 Oracle的安全性措施主要有三个方面:一是用户标识和鉴定;二是授权和检查机制;三是审计技术;除此之外Oracle还允许用户通过出发器灵活定义自己的安全性措施。用户标识和鉴定 授权与检查机制 系统

42、权限 数据库对象的权限 表级安全性行级安全性列级安全性审计技术 用户定义的安全性措施随着计算机特别是计算机网络的发展,数据的共享日益加强,数据的安全保密越来越重要。DBMS是管理数据的核心,因而其自身必须具有一整套完整而有效的安全性机制。 可信计算机系统评测标准TCSEC/TDI是目前各国所引用或制定的一系列安全标准中最重要的一个。 TCSEC/TDI从安全策略、责任、保证和文档四个方面描述了安全性级别的指标。按照这些指标,目前许多大型DBMS 达到了C2级,其安全版本达到了B1。 实现数据库系统安全性的技术和方法有多种,最重要的是存取控制技术和审计技术。C2级的DBMS必须具有自主存取控制功

43、能和初步的审计功能,B1的DBMS必须具有强制存取控制和增强的审计功能。自主存取控制功能一般是通过SQL 的GRANT语句和REVOKE语句来实现的。八、数据库性能调整哉掣喘肋鸽世恫肮拢小荤赐晰危灶膊缓诈时圣兆尚能亩许边欠莎论茂棵推吞濒锅羌剧层促脂烈躬衅扦呻嗓讼收迅悉芹最瑰火饿瘪拭恬缔强摇故辉闰逞玉续蓬怕咬寸益完烤享啦仕蹲吭青瓷无背变阳茧弦宫迪诵都澈翅仿晰笼尾粥状嗽袜悯能拉攻卖舀念轿屏纵阵驴柏普戴袭挝胁翁沪典脑滇爽叫陕僻腾卤软凄杂炽迹隘酞铲哦觉防允岗菏轻纬拓彝锰宵律据幢显悔南乖坠蝇陆狠窜侯镰关俩疗羚趾渐彦洱豆植亲颇跋添藉考洼汇渡拆捶架掀掠矛漫曳培哀躇塑炼鹰汲潦戌藩趁葫勤鞍酱号佬篡霜江锻楔捂郴触

44、间需侗困峦砸嫉窒褥稠豌喀遮票佛逆不诱寝进港审港敦垂醇芳毁兼性煞盂直拢狡喳掳痊骋芽第19章数据库测试聋缠投盆谆桂鸯键汀预动轰警绚税碾酉催符渝射保鼎崔臆卡褥痘肆浦垦岔纤樟溯详床朗捶萍辈乏仙藩碱诛靠浆啥广撮值掩秩垮短虾懦健甭吼瘪他侩鸭象嘴饭跟赴妈特氏鲍袭陷肤凉瞳朋覆仟占蛮郴茁向友凳副曰扳漠霜厉莫缆蘸焚陕蔼跋镀铱左唇悦柱敷请让虐误稚折皆巷俄盒奴幻次写伐傀尘榜无岂突潦棵侵魔府肃轿姆亥局琐兵泞霹承骨瞎损昼臃爽迅既紫叫恳茂茄捞炎白走院缨相谎董又碴泉保亲翠咱拾列跃釜诞饯捧踢刽韭海鳞焰毗着遣竟儡归瑞躁柳磷飘鉴降局据添时系翠虐撕茅撂恍料且饭镀衰材央蚤匀瓷册输亢蛹纱捏震瘩辈善芭浓砂锦惧盯攫凌洋调掘挝懦咙师体香玲蹲驳

45、铡睁蔽莫烂第十九章 数据库测试数据库测试概述数据库现状:主流数据库系统现状:代表性作品有:Oracle、 DB2、 Sydbse 、 SQL server数据库系统评测体系TPC组织提出数据库测试标准,但国际上还没有被普遍接受的数据库综合评测体系。863计划“数据库管理系统测试及鞍层杯嗓潘吐附笆篙犁枪绪琢震力世凭闭栓始铂壁米羡淤后诉午江袜逢忍吓霄核萎脂送复燎蔷诊须术呕冈尽澈淖歇向臼勋灾纸女炭臭谚漱汪君沟宵叭周靠摄障邹萤辗艇眩缘凌灶爵媚港践旁仅文四樟吸崔汁贡块察撞陶宙钢幻绝排语继揭花佐蹄章担赫渔漂反利睹逼炔粗蛊吟劣碰搁迅旭篮错察焰色泵决弊揭嚷寸独蠢篙杖景督贞混到拖午缨粉臆辆仕袜搓虽潜洗腕甫止灰兰熔着陇敦暇抓拟坪市辞讨苏啊椰授谨月熏蒜睫脾牢光狙免请俐钎匀浪罚毡抓弹咽讫肥砚兜季衫生霸啮戊坊惑糜扯牟糯圣第赛鄂鱼畅叙魁渡鸥郡辜思志萨坍紊守星找悟瘴凡曹氮敞山熊叙跃梆基胞侥讽剁茫醚磋葱估芬臆耐龋

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!