让SQL Server数据库自动执行管理任务(一)

作者:彭芬 来源:IT专家网 时间:2009-03-20 10:35:00 

如要让数据库进行自动管理,则管理员需要预先定义一些可预测的管理任务以及这些任务发送的条件。当满足这些指定的条件,则数据库会自动运行管理员指定的操作。使用自动管理来处理日常事务,则让管理员可以抽出时间去关注其他的事情,如数据库优化等等更加具有价值的作业。

计划就是自动化管理组件的一个成员。计划指定了作业运行的时间。多个作业可以根据一个计划运行;多个计划也可以应用到一个作业。但是这个时间跟我们普通上的几点几分又有差异。这个时间不仅指特定的日期或者时间,而且还可以表示特定的时间。如当SQL Server代理启动的时候或者服务器的CPU使用率处于定义的空闲状态水平时。也就是说,这里指的时间计划也可以实现一定的条件状态控制。简而言之,计划作业就是定义使得作业在没有哦能够互交互情况下开始运行的条件,包括具体的日期或者特定的在状况。通过为作业创建新计划或者将现有的计划添加到作业可以将作业计划设置为自动运行。不过在设置自动执行计划的时候,需要注意一个问题。即一次只能够运行一个作业实例。如果在作业按计划运行时尝试手工运行该作业,则SQL Server代理将拒绝这个请求。另外,即使计划未启用,作业仍可以为响应警报而运行,或者由用户手动运行。如果作业计划未启用,则任何使用该计划的作业都不会启用该计划。

一、 计划触发的时间与事件。

上面笔者说过,计划可以基于特定的时间与事件而触发。那么这些具体的时间与事件是什么呢?笔者平时用到的最多的就是如下几种情况。

一是特定的日期和时间运行一次。这个计划时间在数据库备份的时候特别有用。大家都知道,数据库备份会占用比较多的系统资源。如果在数据库服务器使用高峰期(如白天上班时间)进行备份的话,那么会对用户的访问造成比较大的影响。为此笔者就把数据库备份的时间放在晚上12点之后。这个时段相对来说,很少有用户会访问数据库。此时管理员就可以利用计划功能,让其在每天的12点之后进行数据库备份。这就是基于特定的日期和时间计划的典型应用。

二是安重复执行的计划运行。这个跟上面讲的特定日期和时间运行一次比较类似。只是上面的情况只运行一次。而这个按重复执行计划运行则是指会重复运行多次。如每天晚上12点都进行数据库备份等等。在实际工作中,特定日期和时间运新一次往往只是针对一些特殊的情况。如今天刚对数据库结构进行了比较大的更改,如添加了几张表或者视图,此时就需要对数据库进行一次完全备份。如故不急于进行备份的话,则就可以建立一个在特定的日期和时间运行的数据库完全备份计划,让其在午后进行数据库备份。但是对于常规的数据库备份,则需要采取这个按重复执行计划运行。

三是当计算机的CPU使用率处于定义的空闲状态水平时。也就是说,数据库服务器当前的CPU使用率比较低,可以执行其他一些比较复杂的管理任务。如有些数据库系统在设计的时候,有一个库存补货点作业。当库存低于安全库存的时候,系统就会自动生成一张物料请购单,来满足安全库存的需要。由于这张表设计到的物料比较多,会占用比较多的系统资源。故可以设置每天运行一次,而运行的时间就定在CPU使用率比较低的时候。如此就可以减少对其他作业造成的负面影响。

二、 CPU空闲计划的典型应用。

其他的几种计划类型,不少数据库管理员已经非常了解。笔者今天想谈的是CPU空闲计划的应用。这个计划如果应用的好的话,可以大大提高数据库的性能。如果要想利用好这个功能,则需要回答如下两个问题。

一是什么作业需要使用CPU空闲计划?这个问题比较难回答。从理论上来说,任何作业都可以采用CPU空闲计划在自动执行。只是他们带来的效果不同。有的作业即使采用了CPU空闲计划,也不能够带来很大的性能改善。简单的来说,一些占用CPU资源比较大的作业,采用CPU空间计划规则来自动执行,可以取得比较好的效果。如数据库有时候需要重新生成索引,这项工作会占用比较多的CPU资源。而且随着数据量的增多,这个CPU使用率也会越来越高。为此,如果可以把重新生成索引的作业,放在CPU空闲时间来进行的话,那么对于提高数据库的性能效果是比较明显的。总之当某个作业比较复杂,可能需要占用到比较多的CPU或者内存资源的话,则可以采用这个CPU空闲计划。

标签:SQL,Server数据库,自动,执行,管理任务
0
投稿

猜你喜欢

  • Vue便签的简单实现

    2024-05-02 17:03:31
  • 图文详解Mysql使用left join写查询语句执行很慢问题的解决

    2024-01-13 17:14:52
  • php json_encode与json_decode详解及实例

    2023-07-04 22:46:27
  • Python类绑定方法及非绑定方法实例解析

    2022-08-10 11:36:38
  • Django rest framework如何自定义用户表

    2022-03-12 01:15:02
  • python学习实操案例(四)

    2023-10-12 04:43:57
  • MySQL数据库十大优化技巧

    2024-01-25 22:51:28
  • PHP中isset()和unset()函数的用法小结

    2023-11-19 14:19:24
  • Python中staticmethod和classmethod的作用与区别

    2022-03-12 21:30:00
  • python PyGame五子棋小游戏

    2023-09-29 13:32:45
  • PHP bin2hex()函数基础实例讲解

    2023-06-12 16:30:44
  • golang:json 反序列化的[]和nil操作

    2024-04-26 17:19:24
  • Burpsuite入门及使用详细教程

    2023-08-15 19:07:07
  • ZeroClipboard.js使用一个flash复制多个文本框

    2024-04-27 15:19:14
  • 在数据库中自动生成编号的实现方法分享

    2011-11-03 16:55:24
  • 个人网站与动网整合非官方方法

    2009-07-05 18:42:00
  • Bootstrap复选框和单选按钮美化插件(推荐)

    2023-07-02 05:24:53
  • Typecho插件实现添加文章目录的方法详解

    2023-05-25 07:19:04
  • windows下wxPython开发环境安装与配置方法

    2021-10-22 07:51:01
  • Python学习笔记之图片人脸检测识别实例教程

    2021-12-03 06:17:28
  • asp之家 网络编程 m.aspxhome.com