浅谈如何优化SQL Server服务器

 

 

在中国,使用SQLServer数据库的用户和企业是最多的,那么如何去设计和优化SQLSerer服务器呢,DBA应该遵循那些准则和方法呢,下面就将个人经验与你们分享,但愿对你们有所帮助。算法

AD:数据库

1.数据和日志文件分开存放在不一样磁盘上服务器

数据文件和日志文件的操做会产生大量的I/O。在可能的条件下,日志文件应该存放在一个与数据和索引所在的数据文件不一样的硬盘上以分散I/O,同时还有利于数据库的灾难恢复。并发

2.tempdb数据库单独存放在不一样磁盘上post

tempdb数据库是其余全部数据库都有可能使用的临时数据库。当使用select into、在没创建索引的列上执行Orderby时就会在tempdb数据库中产生临时表来存储中间数据。因为创建和填充临时表会严重下降系统性能,因此在尽量的状况下应该为要排序的列创建索引。同时,tempdb数据库是为全部的用户和应用程序共享,因此若是一个用户占据了tempdb数据库的全部空间,则其余数据库将不能再使用。在可能的状况下,tempdb数据库应该单独放置在一个速度更快的硬盘或者RAID阵列上。分离tempdb数据库的I/O操做以加快性能。tempdb数据库应该有适当的容量,以知足用户的须要。应该容许tempdb数据库的空间自动增加。若是设置为不容许自动增加,当查询操做创建了超过tempdb数据库容量的临时表时,操做将没法完成。性能

适当设置tempdb数据库的增加幅度,太小的增加幅度会产生更多的外部碎片,会占用更多的资源。优化

3.避免热点数据的发生设计

在SQLServer7.0以前,对于没有汇集索引的表(堆集表),新插入的数据行老是放置在磁盘中表的物理结尾处。若是并发的用户不少,同时在对表执行插入或者更新数据的操做,这将使得十分繁忙的表的末尾有可能产生数据热点。并发的I/O操做集中对少数页面进行操做,将致使数据库性能的降低。指针

在SQLServer中,新的数据行的物理存储空间的分配是经过PFS页面来进行的。PFS页面的管理算法将插入操做进行分散来尽可能避免产生数据热点。日志

在设计应用系统和数据库时,要避免在天然增加的列上创建主键,这样有可能致使热点数据的发生。

4.数据类型要少

在设计表时,尽量少用数据类型。这样一个数据页面上能够保存最多的信息。数据页面就少,检索数据页面的I/O操做就少,因此效率会高。

5.监控和整理空间碎片

文件空间的自动增加提升了自动管理性,但可能致使空间碎片。物理空间与数据的逻辑空间再也不连续。按期的监控和空间碎片整理有利于提升I/O性能。

6.使用主数据文件和次要数据文件

每一个数据库的一个主数据文件属于主文件组。对于1GB左右规模的数据库,一个数据文件就够了,若是有次要数据文件,主数据文件中有管理次要数据文件的指针。

采用多个数据文件时,主数据文件用于存储系统对象和表,次要数据文件用于存储用户数据和索引。在可能的状况下,主数据文件和次要数据文件能够单独存放在不一样的磁盘上以分散I/O。

若是采用多个数据文件,推荐主数据文件存储系统数据,次要数据文件存放用户数据和索引,这样会有助于提升I/O性能。

7.利用文件组改善性能

在大型数据库系统中,能够考虑创建文件组来管理数据文件。将表和索引经过存放在不一样的物理磁盘上进行性能监控比较,最后得出优化的存储方案。

8.重视自动增加和自动收缩可能致使的性能问题

数据库文件的自动增加和自动收缩功能对于小型数据库的管理十分有用。但可能致使大型数据库的性能问题。由于文件的天然增加的同时会致使存储碎片的发生。当文件空间变大时,新分配的空间不必定和原来的空间连续。当文件空间收缩时,释放了部分空间。然而当文件又须要增加存储空间却不能利用原先释放的空间,也会致使碎片的发生。

9.分离系统数据和用户数据

将系统数据库和用户数据库分开存放在不一样的物理磁盘上有助于改善I/O性能,有助于数据库备份和恢复。

10.优化索引设计

索引的设计对数据库的性能十分重要。具体再也不阐述,可参见本博相关文章。

11.按期更新统计信息

SQLServer默认使用基于代价的优化,因此统计信息的及时更新对于查询优化十分重要。

12.按期的一致性检查

按期对数据库进行一致性检查,确保数据库的完整性。

相关文章
相关标签/搜索