SQL Server 服务器优化技巧浅谈

时间:2024-01-13 17:31:01 

1.数据和日志文件分开存放在不同磁盘上

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

2.tempdb数据库单独存放在不同磁盘上

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性能。

标签:SQL,Server,服务器优化
0
投稿

猜你喜欢

  • Pyqt QImage 与 np array 转换方法

    2022-01-03 01:18:53
  • Python math库 ln(x)运算的实现及原理

    2023-09-11 18:12:28
  • sql脚本查询数据库表,数据,结构,约束等操作的方法

    2024-01-19 17:23:26
  • MySQL两种表存储结构MyISAM和InnoDB的性能比较测试

    2024-01-28 02:35:55
  • python获得命令行输入的参数的两种方式

    2022-09-30 23:25:02
  • Go 语言结构实例分析

    2024-04-23 09:46:36
  • smarty缓存用法分析

    2024-06-07 15:44:41
  • asp实现*号隐藏IP地址

    2008-08-10 18:51:00
  • 在pycharm上mongodb配置及可视化设置方法

    2022-12-04 07:05:31
  • 在Linux系统的命令行中为MySQL创建用户的方法

    2024-01-18 00:52:30
  • 浅谈Python的正则表达式

    2022-05-11 00:54:16
  • 浅谈python配置与使用OpenCV踩的一些坑

    2022-10-12 07:16:26
  • Python爬虫使用Selenium+PhantomJS抓取Ajax和动态HTML内容

    2023-04-01 15:20:05
  • anaconda如何查看并管理python环境

    2023-11-10 13:31:38
  • PyQt5每天必学之QSplitter实现窗口分隔

    2021-12-26 16:33:48
  • Pycharm虚拟环境创建并使用命令行指定库的版本进行安装

    2022-10-24 18:24:40
  • python 计算数组中每个数字出现多少次--“Bucket”桶的思想

    2023-06-28 19:37:55
  • 重新发现HTML表格

    2009-12-02 09:47:00
  • python字典序问题实例

    2023-07-31 05:46:58
  • 在ASP.NET 2.0中操作数据之五十二:使用FileUpload上传文件

    2023-07-07 04:19:18
  • asp之家 网络编程 m.aspxhome.com