这是我前几天整理的一篇 数据库优化的文章,贴出来与大家共享。

据统计,以数据库为中心的应用程序80%的性能问题是低效的SQL语句引起的,所以SQL的性能优化显得十分重要。另一方面,Oracle数据库应用系统运行阶段,DBA(数据库管理员)对系统参数配置不合理导致数据库运行性能低下,再者数据库物理结构的不合理也是导致性能低下的原因,本文主要从这些方面展开对oracle数据库应用性能的讨论。[2]


1. SQL优化

1.1 索引提升性能

Oracle采用 2种访问表中记录的方式:全表扫描和通过

ROWID访问表。全表扫描就是顺序的访问表中每条记录,该扫描方式耗费的时间和系统资源均较高;通过ROWID访问表,ROWID包含了表中记录的物理位置信息,Oracle采用索引(Index)实现了数据和存放数据的物理位置(ROWID)之间的联系,索引提供了快速访问ROWID的方法。

通过在许多情况下,针对数据表中的某个字段创建索引可以很快查询到所需的数据,一般来说应遵循以下基本原则:

(1)该字段是否为关键字,主键和外键须添加索引。

(2)为经常出现在关键字ORDER BY、GROUP BY、DISTINCT后面的字段,建立索引。

(3)对经常与表进行连接的表的连接字段建立索引。

索引虽有助于提高性能,但并不是索引越多越好,过多的索引会导致系统低效,用户在表中每加进一个索引,维护索引集合就要做相应的更新工作,加重相应的更新代价。[3]


1.2 SQL语句优化

SQL语句优化的实质就是在结果正确的前提下,用优化器可以识别的语句,充分利用索引来减少表扫描的I/O次数,尽量避免表搜索的发生。优化的目的就是将性能低下的SQL语句转换成目的相同的、性能优异的SQL语句,使数据查找的路径最简化,并尽量保持处理器时间和I/O时间的平衡。通常分为以下几个步骤:1)查找有问题的SQL语句。优化有问题的sql语句能显著提高数据库性能。寻找的方法有:搜集统计数据,oracle中可以通过DBMSSTATS包或ANALYZE命令,前者

可用于搜集有关链接数据行的统计数据,簇的数据情况只能使用ANALYEZ命令获得,其相关语法为ANALYEZE CLUSTERCluste_name ComputerSTATISTICS,对于其它情况可以使用DBMS_SATS包,语法为:execDBMS_SATS.gather_table_stats(‘owname’,’tablename’,’partnmae’);利用SQLTrace工具分析SQL语句。通过命令ALTER SESSION SET SQL_TRACE=TRUE会话激活SQL_TRACE,oracle就会在udump管理区创建跟踪文件,从而可以了解如解析、执行和返回数据的次数、CPU时间和执行时间、物理读和逻辑读操作次数、库缓冲区命中率等参数;通过oracleEnterpriseManager Console、Oracle Diagnostics Pack等图形性能工具能够很快地获取到数据库缓冲区命中率、CPU利用率、运行时内存等重要的数据库性能指标信息,并将它们以GUI表格形式和曲线图形式显示出来;2)建立合适的SQL语句。参照原则如下:建立“适当”的索引,使用索引的根本目的就是为了提高查询效率,但索引也不是越多越好,使用索引时应遵循相应的原则。此外,为了降低I/O竞争,索引不应与用户表空间建在同一磁盘上;避免使用耗费资源的操作如DSJTNITC、UNION、GROUP BY、ORDERBY等关键字,因为他们会启动SQL引擎执行耗费资源的排序功能。[4]


2. 数据库应用系统参数优化

2.1 调整服务器内存分配

服务器内存分配是在应用系统运行过程中优化设置的。DBA根据数据库的运行状况不仅可以调整数据库系统全局区(SGA区)的数据缓冲区、日志缓冲区和共享池的大小,而且还可以调整程序全局区(PGA区)的大小。

系统全局区(SGA)是一个分配给ORACLE包含ORACLE数据库实例控制信息的内存段。SGA的大小对系统性能的影响极大,其缺省参数设置只适用于配置很低的计算机,对现有较大资源的系统,这些参数若不作调整,会对系统资源造成巨大浪费。例如:现有服务器系统内存为256MB时,SGA的大小以160MB左右为宜。初始化参数文件中的一些参数对SGA的大小有决定性的影响。参数DB-BLOCK-BUFFERS(SGA中存储区高速缓存的缓冲区数目),参数SHARED-POO-L-SIZE(分配给共享SQL区的字节数),是SGA大小的主要影响者。DB-BLOCK-BUFFERS参数是SGA大小和数据库性能的最重要的决定因素。该值较高,可以提高系统的命中率,减少IPO。每个缓冲区的大小等于参数DB-BLOCK-SIZE的大小。ORACLE数据库块以字节表示大小。ORACLESGA区共享池部分由库高速缓存、字典高速缓存及其他一些用户和服务器会话信息组成,共享池是最大的消耗成分。调整SGA区各个结构的大小,可以极大地提高系统的性能[2]:

(1)调整LibraryCache

库高速缓存(Library Cache)中包含私用和共享SQL区和PLPSQL区。调整SGA的重要问题是确保库高速缓存足够大,以使ORACLE能在共享池中保持分析和执行语句,提高语句分析和执行效率,降低资源消耗。通过比较LibraryCache的命中率来决定它的大小。

(2)调整数据字典高速缓存(DictionaryCache)

数据字典高速缓存包括了有关数据库的结构、用户、实体信息等。数据字典的命中率对系统有很大的影响。

(3)调整数据库缓冲区高速缓存

ORACLE在运行期间向数据库高速缓存读写数据,高速缓存命中表示信息已在内存中,高速缓存失败意味着ORACLE必需进行磁盘IPO。保持高速缓存失败率最小的关键是确保高速缓存的大小。初始化参数DB-BLOCK-BUFFERS控制数据库缓冲区高速缓存的大小。[9]


2.2 调整磁盘IPO

磁盘IPO是系统性能的瓶颈,解决好磁盘IPO,可明显提高性能。通过查询VÃFILESTAT可以知道每个物理文件的使用频率(phyrds表示每个数据文件读的次数,phywrts表示每个数据文件写的次数)[10]

SQL>SELECTname,phyrds,phywrts FROM VÃdatafile df,VÃfilestat fs WHEREdf.file#=fs.file#;

对于使用频率较高的物理文件,可以采用以下策略:

(1)将组成同一个表空间的数据文件平均分配在尽可能多的磁盘上,做到磁盘之间IPO负载均衡;

(2)为表和索引建立不同的表空间;

(3)将数据文件与重做日志文件分离在不同的磁盘上;

(4)减少不经ORACLESERVER的磁盘IPO。


2.3 调整资源竞争

当多个进程对相同资源发出申请时,产生竞争。

(1)修改process参数

该参数定义可以同时连接到ORACLE数据库的最大进程数,缺省值为50。注意,ORACLE的后台进程也包括在此数目中,建议将该值改为200。

(2)减少调度进程的竞争

减少调度进程的竞争,通过查询VÃdispatcher表来判定调度进程的竞争SQL>SELECT   network,sum(busy)Psum(busy)+sum(idle)

FROM VÃdispatcher GROUP BYnetwork;

如果某种协议忙的比率超过50%,应增加MTS-DISPATCHERS的值。

(3)减少多线程服务进程竞争

首先查询VÃSYSSTAT表判定是否发生多线程服务进程竞争:

SQL>SELECT DECODE(total q,0,.No request.,

waitPtotal q+.hunderths of seconds.)

FROM VÃsysstat WHERE type=.common.;

如果共享服务进程数量已达到初始化参数文件中MTS-MAX-SERVERS指定的最大值,但应用运行时,平均请求等待时间仍持续增长,那么,应加大MTS-MAX-SERVERS的值。

(4)减少重做日志缓冲区竞争

通过查询VÃSYSSTAT表判定redo log文件缓冲区是否足够。

SQL>SELECTname,value

FROM VÃsysstat

WHERE name=.redo log space request.;

此处value的值应接近于0,否则,应增大初始化参数文件的LOG-BUFFEQS的值[11]

(5)减少回退段竞争

回退段对性能也有影响,根据事务大小情况来分配合适的回退段。

首先判定回退段的数量能否满足系统运行的需要:

查询VÃWAITSTAT表与VÃSYSSTAT表

SQL<SELECTclass,count FROM VÃwaitstat

WHERE class IN(.systemundo header.,systemundo

block.,.undo header.,.undo block.);

SQL>SELECTsum(value) FROM VÃsysstat WHERE nameIN(.db block

gets.,.consistentgets.);如果任何一个classPsum(value)

>10%,那么考虑增加回退段。

(6)减少Free List竞争

当多个进程同时向一个表中插入数据时,产生Free List竞争。

3. 优化数据库物理结构

3.1 优化设置控制文件的个数,位置及其备份

建议CONTROL_ FILE初始化参数中指定多个文件应大于2,并将控制文件镜像到不同位置,并要把这些控制文件备份到安全的磁盘中。


3.2 优化设计表空间,数据文件的大小及位置

3.2.1 设计表空间

尽量把同一时间对磁盘的读写操作分散开,如对一个表中数据进行更新时,数据库将同时去读该表中的数据和该表上的索引信息,如果把表的数据信息和索引信息都放在同一个数据文件中,则数据库的速度将会变慢。最好是把数据信息和索引信息分别放在不同磁盘的两个数据文件中,此时数据库对磁盘的读写操作将分散在两个磁盘上,速度将得到显著提高。因此在设计数据库的表空间和数据文件时,首先给表和表的索引分别创建两个表空间(存放用户数据的数据表空间和存放表索引的索引表空间)。另外,还根据该系统的数据量的大小及系统中的数据的性质不同,再考虑创建几个数据表空间或者给数据表空间添加几个数据文件。

3.2.2 设计数据文件的大小

把记录大小相当的表放在同一个表空间中,这时一个表空间的存储参数设置,可以保证表中的记录都放在一个范围中,避免了一条记录跨范围存放,可以明显数据库的性能。

3.2.3 设计数据文件的位置

为了避免磁盘的I/O操作冲突,应把数据文件创建在不同位置。


3.3 优化设计重演日志文件

3.3.1 重演日志文件的大小

由于数据库在利用重演日志文件时是循环使用它们的,而且当LGWR进程在两个日志文件切换时,将自动产生一个检测点,所以重演日志文件的大小会直接影响到检测点出现的频率。而由于在数据库检测点时,对用户而言,数据库的速度会受影响,所以检测点的出现频率大,或者检测点正好出现在数据库处理数据高峰期,将会极大影响数据库的性能。因此,重演日志文件的大小设计,应考虑检测点出现的频率以及检测点应避开数据库处理数据的高峰期。

3.3.2 重演日志文件组的个数

在ARCHIVELOG模式下时,适当增加重演日志文件组的个数,可以降低数据库存档日志文件的频率。

3.3.3 重演日志文件的存档

应把重演日志文件的存档之处设置在磁盘读写更快的物理设备上。这样可以减少日志文件的存档时间。[5]


4. 数据库集群

集群是一组相互独立的、通过高速网络互联的计算机,它们构成了一个组,并以单一系统的模式加以管理.数据库集群系统是由多个共享一个数据库的有独立操作系统的服务器组成[6]

Oracle 10g RAC是一种基于网格服务的数据库集群系统架构,它具有每一层计算堆栈上的虚拟化、根据策略和动态需求来分配工作和资源、集中资源以提高利用率、能自我调整和修补、可统一管理和供应的特点[7].

每一层计算堆栈上的虚拟化.Oracle 10g RAC通过虚拟化将网格中的每一个物理和逻辑实体都抽象为一项服务.虚拟化使得网格中的存储器、处理器、数据库服务器等组件紧密地集成在一起,并且使得每一个组件在不损害整体的系统性能的前提下,根据不断变化的环境快速地作出反应,快速适应并屏蔽组件故障.此外,RAC是动态地创建一个连接,将来自某个特定应用程序的请求分配给数据库集群中的一个服务器节点处理.

根据策略和动态需求来分配工作和资源.RAC通过网格服务中介自动且动态地将网格的某个元素的资源需求和另一个元素的资源可用性连接在一起,动态地分配需要处理的服务器请求、需要访问和使用的数据以及需要执行的计算,使资源得到有效地利用.随着环境的变化,它还能调整这种关联.根据制定的策略,RAC进一步优化了集群中资源请求者与资源提供者之间的关联,使得预期的高峰需求等问题得到了有效处理.

集中资源以提高利用率.RAC通过网格服务动态地将服务消费者与服务提供者连接在一起,并通过共享的磁盘存储阵列及构建数据库集群系统将资源合并和集中,实现了更高的资源利用率.

自我调整和修补.RAC具有自我调整和修补的自适应功能,使得系统接管了许多过去必须由管理员才能处理的工作,并且系统处理得比以前更好.这样,不仅提高了系统效率,而且使得管理员有更多的时间和精力去做更重要的工作.

统一管理和供应.RAC通过将集群系统看作单个逻辑实体,使用自我管理功能和数据库控制来统一、监控和管理网格中的每一个元素.通过图形化的Web管理界面,管理员可以主动监视数据库,并很快得到任何系统瓶颈问题或者任何不可用组件所引起的警报和建议.[8]


5. 结语

数据库应用系统的优化是一个系统工程,涉及的方面很多。程序员和数据库管理员需要认真分析Oracle在运行过程当中出现的各种问题,以保证Oracle数据库应用系统运行的高效率。

遗憾的是,对像Oracle这样的数据库进行调整和性能调节并不是一件容易的事。Oracle带有几种监控和调试工具,功能强大,但精通掌握十分困难。这就需要开发一个数据库应用系统优化软件,对程序员和有经验的数据库管理员都适用。程序员可以把它用在基于Oracle的应用系统的开发过程和测试过程中,而数据库管理员会觉得有益于调整已开发出来的应用系统,因为数据库随时间不断变化,数据库管理员们能使用该软件即时查看数据库内部的运行情况,从而使数据库应用系统的性能得到提高。相信不久,人们将开发出一个适合程序员和数据库管理员使用的数据库应用系统优化软件。

参考文献:

[1] 张江.Oracle数据库的性能优化策略浅析.现代计算机(专业版),2012年36期

[2] 何泽恒1,苏哲明2,李莉莎1.ORACLE应用系统的性能参数分析与优化. 哈尔滨商业大学学报(自然科学版), Vol.18 No.3 Jun.2002

[3] 荆立夏: 韩忠军. SQL优化在Oracle 10g调优中的应用.煤炭技术, Vol.29 No.6 Jun.2010

[4] 魏亚楠,宋义秋. oracle数据库应用系统的性能优化.制造业自动化,2010 (8): 0204-03.

[5] 闫伟,张喜民,张军华. Oracle数据库及应用程序优化.内蒙古石油化工 ,,2005 (1) :32 - 36.

[6] 王婉菲,王欣,张志浩.数据库集群系统的研究与实施[J].微型电脑应用,2003,19(10):31 -33.

[7] 闪四清.Oracle Database10g基础教程[M].北京:清华大学出版社,2005.

[8] 黄志宏,曾 鸣,徐春笙.基于网格服务的数据库集群系统的研究与应用. 重庆工学院学报(自然科学版),Vol.21 No.7 Jun.2007

[9] 李丹.Oracle的性能优化 . 河北工程技术职业学院学报 , Vol.5 NO.lMar 2003

[10] 郭卫华,刘卫东,宋佳兴. 已有ORACLE系统的性能调整优化. 计算机工程与应用,2001年04期

[11] 赵慧勤,李秀兰. Oracle 数据库应用系统的优化策略. 计算机工程与应用 , 2003年27期

引点参考文献,显得蛮专业,是不是代表自己越来越有学术气息了。

《java系统性能调优》--3.数据库相关推荐

  1. 《java系统性能调优》--1.发现瓶颈

    性能啊!性能! 之所以想写写性能调优,也是有感于我们的项目,我们採用一些手段使得系统性能上升了一个台阶,总是须要把这点经验沉淀一下.随着工作的深入,关于系统性能的事肯定还有非常多,也算是通过这个系列文 ...

  2. 深扒,用 6 部分讲完 Java 性能调优:多线程 + 设计模式 + 数据库

    Java 性能调优 Java 性能调优,是一个老生常谈的话题.可能有些人觉得没用,一些细小的地方没有好修改的,改与不改对于代码的运行效率有什么影响呢? Java 性能调优不单单是学一门编程语言那么简单 ...

  3. Java性能调优实践

    作者:张 俊城, 郭 理勇, 和 刘 建 https://www.ibm.com/developerworks/cn/java/j-lo-performance-tuning-practice/ind ...

  4. 怎么对 Java 程序调优?不看别后悔!

    Java 应用性能优化是一个老生常谈的话题,典型的性能问题如页面响应慢.接口超时,服务器负载高.并发数低,数据库频繁死锁等. 尤其是在"糙快猛"的互联网开发模式大行其道的今天,随着 ...

  5. Java 性能调优 概念详解 小白教程

    对于很多研发人员来说,Java 性能调优都是很头疼的问题,为什么这么说?如今,一个简单的系统就囊括了应用程序.数据库.容器.操作系统.网络等技术,线上一旦出现性能问题,就可能要你协调多方面组件去进行优 ...

  6. GitHub疯狂转发!阿里巴巴彩版java性能调优实战,终于到手了!文末福利

    怎样才能做好性能调优? 开始之前,我先来讲一下我对性能调优的看法.在我看来Java的性能调优并不是像学习编程语言一样可以通过学习掌握,它是没有办法用直线的思维学会并掌握使用的,并且它对于程序员来说,对 ...

  7. 系统性能调优必知必会(脑图更新。。)

    系统性能调优必知必会 CPU缓存 CPU多级缓存,单核心会有自己的一级二级缓存,所有核心会共享三级缓存 一级缓存包括数据缓存 .指令缓存. 数据的读取是以缓存行进行读取的,缓存行一般为64字节. 缓存 ...

  8. 原理剖析(第 013 篇)应用系统性能调优

    原理剖析(第 013 篇)应用系统性能调优 - 一.大致介绍 1. 本人接手的一个打车系统,因为出现了一次响应十分缓慢的情况,因此才有了应用调优的篇章: 2.由于过程中可能没有阐述的太清楚,如想详细了 ...

  9. 《Java性能调优实战》笔记(一)Java编程性能调优、多线程性能优化

    文章目录 一.Java性能调优概述 1.1 性能调优标准 1.2 制定性能调优策略 二.Java编程性能调优 2.1 字符串 2.2 正则表达式 2.3 ArrayList和LinkedList的选择 ...

最新文章

  1. 【国内首家】第一个基于语音生成实时知识图谱的系统来啦!!!
  2. 08_传智播客iOS视频教程_点语法
  3. eclipse+adt下开发android微信红包自动抢(AccessibilityService类)
  4. 禅道开源项目管理软件正式发布2.3版本
  5. 《数据结构》知识点Day_03
  6. Step by Step to download a material from ERP via request download
  7. Percona5.6.15线程池压力测试
  8. ceph部署-纠删码
  9. 快速获取知网,万方,维普等永久性免费下载权限
  10. python把汉字变成拼音英文_Python把汉字转换成拼音
  11. 摘果子问题(聚沙成塔问题)
  12. 国际象棋绘制java_java使用swing绘制国际象棋棋盘
  13. 求两个字符串的最大连续公共字串
  14. 【无线芯片解读】2.4G专题:Si24R1
  15. 微信小程序子组件向父组件传值的两个方法
  16. 如何生成github上的动态gif图
  17. python动态捕捉屏幕_如何使用Python实现自动化截取Windows系统屏幕
  18. 正弦函数的傅里叶级数展开计算
  19. pmsm什么意思_BLDC和PMSM电机区别
  20. 使用Jlayer和AudioTrack实现在线流媒体边下边播功能

热门文章

  1. 【Novel Category Discovery】AutoNovel: Automatically Discovering and Learning Novel Visual Categories
  2. 蓝宝石材质屏 3月23日大可乐3限量首发
  3. Win7系统QQ语音功能无法使用如何解决?
  4. excel数据整理:网络表格数据规范处理方法
  5. 【深度学习】谷歌云GPU服务器创建与使用指南(二)
  6. 技术分享连接汇总[201804]
  7. uniapp-获取input输入内容
  8. python爬取率_利用Python爬取OPGG上英雄联盟英雄胜率及选取率信息
  9. 「镁客·请讲」星会抉择吴昊:用VR新思路,打开线下娱乐体验新格局
  10. ElementUI table合并单元格