第十五周翻译

到SQL Server代理的阶梯:级别1:设置和概述

理查德·韦米尔,2013-01-02(首次出版:2011-02-17)

级别1:SQL Server代理安装和概述
SQL Server代理是SQL Server的作业调度和警报服务,如果使用得当,它可以大大简化数据库管理员(DBA)的工作负载。
SQL Server代理的核心是运行批处理作业的功能。“批”只是一组“操作”,通常使用Transact-SQL脚本定义。然后,可以按特定的计划作为作业运行,你可能会选择在很少有用户访问系统的时候运行;换句话说,使用SQL Server代理将这些作业计划为批处理作业。这些批处理作业可以是任何东西,从简单的T-SQL任务到跨多个SQL Server实例和多台计算机运行的复杂的多系统作业。SQL Server代理还允许你通过电子邮件通知用户,例如,当特定的批处理作业完成时,或者当发生错误时(通知引擎在级别3中介绍)。
作为DBA,你很有可能立即能够利用SQL Server代理在新的SQL Server部署上安排作业。例如,你的第一个任务可能是备份系统数据库,并通过邮件通知你备份作业是完成还是失败。后续作业可能包括设置和调度用户数据库的备份、索引维护操作(重建或重新组织)等。如果你管理的是非常简单的SQL Server系统,那么你将启用维护计划作业调度,例如,使用SSMS数据库维护计划向导。
本文是探索SQL Server代理特性的阶梯的第一个层次,并讨论如何充分利用SQL Server代理。它将介绍SQL Server代理的大部分组件和功能,向你展示如何让服务运行,并演示如何从SSMS创建和运行简单的批处理作业。随后的级别将深入到每个主要组件中,包括如何使用SMO、PowerShell和Transact-SQL来使用SQL Server代理。
本系列将重点介绍SQL Server 2005、SQL Server 2008和SQL Server 2008 R2;但是,本系列中的大部分信息也适用于SQL Server 2000。
正在运行SQL Server代理
在初始安装SQL Server期间,默认情况下不启用SQL Server代理,因此使用SQL Server代理的第一个简单步骤是使SQL Server代理服务运行。
将代理设置为使用SQL Server自动启动
要将SQL Server代理设置为自动启动,请打开“Microsoft SQL Server 2008”“配置工具”文件夹中的SQL Server配置管理器实用工具。要运行此实用程序,你需要是本地Windows管理员(或是最好的朋友)。
启动后,实用程序应自动连接到本地计算机。单击树中的“SQL Server服务”选项。在右侧面板中,你应该看到已安装的SQL Server服务的列表。其中之一应该是“SQL Server代理(instance name)”,其中instancename是安装SQL Server时使用的实例的名称,或者是配置默认实例时使用的“mssqlserver”。如果启动模式已经设置为自动,很好,它在安装过程中配置正确。如果没有,请双击SQL Server代理,单击出现的“属性”对话框中的“服务”选项卡,然后单击“启动模式”旁边的下拉列表。选择Automatic,然后单击Apply(参见图1.1了解应该是什么样子)。现在,当服务器重新启动并且SQL Server正在运行时,SQL Server代理将自动启动。如果出于某种原因,SQL Server代理没有运行,请立即启动该服务。
图1.1–用于SQL Server代理的SQL Server配置管理器
服务帐户选择
你需要确保根据计划对SQL Server代理执行的操作配置了适当的服务帐户。如果你正在跟踪,则位于SQL Server代理属性的“服务”选项卡上。单击“登录”选项卡。对于SQL Server代理的基本操作,可以使用内置帐户,例如网络服务(服务帐户将设置为在SQL Server的初始安装期间选择的任何帐户)。图2显示了选择对话框。只需从“内置帐户”下的列表中选择“网络服务”。如果你打算让SQL Server代理连接到远程计算机(例如复制文件或管理多个系统),那么你将希望切换到使用域用户帐户(图1.2下拉列表中包含的“this account”选项);可能是为此专门创建的帐户。这是你需要向域管理员请求的内容。从域管理员的角度来看,你需要一个普通的用户帐户。在这两种情况下,请选择正确的服务帐户,一旦进行了任何更改,则需要选择“重新启动”按钮以使新更改生效。完成后,单击“确定”按钮完成对SQL Server代理服务的配置。你可以在http://msdn.microsoft.com/en-us/library/cc281953.aspx上阅读有关服务帐户选择的更多信息。
图1.2–SQL Server代理的服务帐户选择
创造你的第一份作业
现在SQL Server代理正在运行,你可以创建第一个作业。通过演示,我们将设置一个作业来执行其中一个关键DBA任务,即备份你的系统数据库,这样,你就可以创建一个自动作业来为你执行该任务,而不必记住手动备份这些数据库。
作业
作业是单个逻辑任务(如备份数据库)的核心容器。该任务将包含一个或多个作业步骤。作业可能包括通知(例如,如果作业失败,请向DBA发送电子邮件)、计划(希望作业运行时),甚至可能在多个系统上运行。然而,对于我们的第一个备份工作,我们将保持简单。
要创建作业,请打开SSMS并连接到你的SQL Server实例。展开SQL Server代理节点,然后右键单击作业。选择创建新作业(“新作业…”)的选项,如图1.3所示。
图1.3–启动“新建作业”对话框
一个作业有许多组件,如图1.4所示。
图1.4–新建作业对话框
我们将把作业命名为“备份主数据库”。这将是用于引用SSMS GUI或PowerShell中的作业的名称。工作类别可以是组织工作的一种有用方式,但对于你的第一份工作来说,设置类别并不重要。你将学习如何在以后的级别中指定类别。在描述框中,写一些能帮助你记住你为什么创建这个工作以及它应该做什么的东西。记住,其他人很可能需要在以后管理这个系统,因为他们没有创建这个工作,所以他们不知道该完成什么,也不知道它是否重要。
完成所有这些之后,你基本上已经完成了创建作业“shell”的工作,它只是“shell容器”,用于显示在“新建作业”对话框中作为选项卡的所有组件。作业最重要的部分是其他选项卡上的组件。
作业步骤
SQL Server代理中的作业至少由一个作业步骤组成。当大多数人想到SQL Server作业执行某些工作时,他们真正的意思是一个作业步骤。作业步骤由你希望执行的操作类型定义,包括运行以下作业子系统的能力:
ActiveX
操作系统(CMD的运行)
PowerShell
各种复制任务
SQL Server分析服务(SSAS)命令(例如XML/A)
SQL Server分析服务(SSAS)查询(MDX)
SQL Server集成服务(SSIS)包(SQL Server 2000li de DTS包)
T-SQL脚本
对于大多数SQL Server DBA,大多数作业将使用最后一种类型的作业步骤T-SQL。作业可以作为作业所有者运行,也可以使用其他安全上下文运行,具体取决于作业所有者的权限和代理的配置。工作步骤和子系统将在下一个级别中更详细地介绍。
正如你在SSMS GUI中看到的,控制作业步骤的选项卡简单地称为“步骤”。现在单击它,我们将创建一个作业步骤。点击对话框底部的“新建”按钮,启动“新建作业步骤”对话框(见图1.5)。
图1.5:新工作步骤
给作业步骤一个有用的名称——在我们的例子中,作业名称和步骤名称可能是相同的——“备份主数据库”。作业步骤类型将是T-SQL,因为我们将使用一个简单的备份命令进行数据库备份。你现在可以忽略“运行方式”,因为默认情况下,我们将以作业所有者(即你)的身份运行作业步骤。默认情况下,数据库设置正确,可以在master中工作。
对于命令本身,你可以打开一个文件,或者复制并粘贴到你在查询窗口中编写的一些有效的T-SQL中。为了简单起见,我们正在执行一个简单的备份命令。如果没有在C驱动器上安装SQL Server,则需要将文件位置更改为在计算机上工作的位置。我展示的示例来自一个简单的SQL Server虚拟机安装,所有这些都在一个硬盘上。你不应该在一个这样的硬盘驱动器上看到一个完整的SQL生产服务器!
BACKUP DATABASE master
TO DISK=‘C:\Program Files\Microsoft SQL Server\MSSQL10.MSSQLSERVER\MSSQL\Backup\master.bak’
WITH INIT
完成后,应如图1.6所示。单击“确定”创建作业步骤。
图1.6–完成的作业步骤
工作时间表
作业调度控制实际开始作业的时间。作业计划有四种类型:
1、SQL Server代理启动的自动启动
2、CPU空闲时启动
3、循环执行
4、执行一次
大多数作业计划都是定期的(例如,每周在周日晚上7点运行一次备份)。调度是SQL Server代理中的独立对象,一个调度可以连接到多个作业。
对于我们的工作,我们希望每周备份数据库。因此,单击Schedules选项卡,选择New来创建一个新的作业调度,如图1.7所示。将作业计划命名为一些实用的内容(因为它们可以在作业之间共享)。我将此计划称为“每周系统备份”。幸运的是,这个页面上的默认设置会很好地工作!我们一周一次,星期天,午夜。命名计划后单击“确定”,然后再次单击“确定”以完成作业创建。
图1.7-新工作时间表
运行刚刚创建的作业
既然我们已经创建了备份作业,那么运行该作业来验证我们是否正确执行了所有操作是一个好主意。即使我们计划每周运行此作业,我们也可以根据需要手动运行作业。在ssms中的jobs文件夹下,现在应该可以看到你的作业了。右键单击作业,然后选择“Start job at step…”,如图1.8所示。作业将运行,现在你的主数据库已备份。
图1.8–在SSMS中启动作业
接下来是什么?
在接下来的几个级别中,我们将更深入地探讨SQL Server代理的每个领域,以及作业和警报可以大大增强SQL Server系统功能并使你的生活更轻松的具体示例。下一个级别将集中于创建和配置作业步骤、了解各种作业子系统和作业步骤安全性。
本文是SQL Server代理的父级阶梯的一部分

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值