使用基于策略的管理来管理服务器

基于策略的管理是一种用于管理一个或多个 SQL Server 2012 实例的系统。 当 SQL Server 策略管理员使用基于策略的管理时,他们使用 SQL Server Management Studio 创建策略以管理服务器上的实体,例如,SQL Server 实例、数据库或其他 SQL Server 对象。

基于策略的管理的优点

基于策略的管理有助于解决在以下情况下出现的问题:

  • 公司策略禁止启用数据库邮件或 SQL Mail。 创建了一个策略以检查这两个功能的服务器状态。 管理员将服务器状态与策略进行比较。 如果服务器状态不符合策略,管理员将选择“配置”模式,并且使服务器状态符合策略。

  • AdventureWorks2012 数据库的命名约定要求所有存储过程以字母 AW_ 开头。 创建了一个策略以强制实施此策略。 管理员对此策略进行测试,并找到一组不符合策略的存储过程。 如果将来的存储过程不符合此命名约定,这些存储过程的创建语句将会失败。

注意注意

注意策略会影响某些 SQL Server 功能的工作方式。 例如,变更数据捕捉和事务复制都使用没有索引的 systranschemas 表。 如果启用所有表都必须有索引的策略,则强制策略的兼容会导致这些功能都失效。

策略是使用 Management Studio 创建和管理的。 此过程包括以下步骤:

  1. 选择一个基于策略的管理方面,其中包含要配置的属性。

  2. 定义一个条件以指定管理方面状态。

  3. 定义一个策略,其中包含该条件、用于筛选目标集的附加条件以及评估模式。

  4. 检查 SQL Server 实例是否符合该策略。

对于失败的策略,对象资源管理器以红色图标的形式指示严重运行状态警告,此图标位于该目标以及对象资源管理器树中此目标上面的节点旁边。

注意注意

在系统计算某一策略的对象集时,默认情况下将排除系统对象。 例如,如果该策略的对象集引用所有表,则该策略将不适用于系统表。 如果用户想要评估针对系统对象的策略,可以显式向对象集添加系统对象。 但是,尽管“按计划检查”评估模式支持所有策略,但出于性能原因,“更改时检查”并不支持具有任意对象集的所有策略。 有关详细信息,请参阅 https://blogs.msdn.com/b/sqlpbm/archive/2009/04/13/policy-evaluation-modes.aspx

基于策略的管理概念

基于策略的管理包含以下三个组件:

  • 策略管理

    策略管理员创建策略。

  • 显式管理

    管理员选择一个或多个管理目标,并显式地检查这些目标是否符合特定策略,或者显式地使这些目标符合策略。

  • 评估模式

    共有四种评估模式,其中的三种模式可以自动执行:

    • 按需。 当用户直接指定这种模式时,它可对策略进行评估。

    • 更改时: 禁止。 这种自动模式使用 DDL 触发器来防止违反策略。

      重要说明重要提示

      如果禁用了 nested triggers 服务器配置选项,“更改时: 禁止”将不会正常工作。 基于策略的管理依靠 DDL 触发器来检测和回滚不符合使用此评估模式的策略的 DDL 操作。 删除基于策略的管理 DDL 触发器或禁用嵌套触发器将导致此评估模式失败或意外执行。

    • 更改时: 仅记录。 当做出相关更改时,这种自动模式使用事件通知对策略进行评估。

    • 按计划。 这种自动模式使用 SQL Server 代理作业定期对策略进行评估。

    在未启用自动策略时,基于策略的管理不会影响系统性能。

基于策略的管理术语

  • 基于策略的管理目标
    基于策略的管理所管理的实体,例如,SQL Server 数据库引擎实例、数据库、表或索引。 服务器实例中的所有目标构成了目标层次结构。 目标集是将一组目标筛选器应用于目标层次结构后得到的一组目标,例如,HumanResources 架构所拥有的数据库中的所有表。

  • 基于策略的管理方面
    一组逻辑属性,用于模拟某些类型的管理目标的行为或特征。 这些属性的数量和特征内置在方面中,只能由方面创建者添加或删除这些内容。 一种目标类型可以实现一个或多个管理方面,而一个管理方面可以由一种或多种目标类型进行实现。 方面的某些属性仅适用于特定版本。 例如,外围应用配置器方面的数据库邮件属性仅适用于 SQL Server 2005 及更高版本。

  • 基于策略的管理条件
    一个布尔表达式,用于针对管理方面指定基于策略的管理托管目标的一组允许状态。 SQL Server 在评估条件时尝试遵守排序规则。 当 SQL Server 排序规则与 Windows 排序规则不完全匹配时,请测试您的条件,以确定该算法如何解决冲突。

  • 基于策略的管理策略
    基于策略的管理条件和预期行为,例如,评估模式、目标筛选器以及计划。 每个策略只能包含一个条件。 您可以启用或禁用策略。 策略存储在 msdb 数据库中。

  • 基于策略的管理策略类别
    用于帮助管理策略的用户定义类别。 用户可以将策略划分到不同的策略类别。 每个策略属于一个策略类别,且仅属于一个策略类别。 策略类别应用于数据库和服务器。 在数据库级别,应用以下条件:

    • 数据库所有者可以为数据库订阅一组策略类别。

    • 仅订阅类别中的策略能够控制数据库。

    • 所有数据库隐式订阅默认策略类别。

    在服务器级别,策略类别可以应用于所有数据库。

  • 有效策略
    目标的有效策略是那些控制此目标的策略。 仅当满足所有以下条件时,策略才对目标有效:

    • 已启用此策略。

    • 目标属于此策略的目标集。

    • 目标或目标祖先之一订阅了包含此策略的策略组。

基于策略的管理任务

基于策略的管理是一个基于策略的系统,用于管理一个或多个 SQL Server 实例。 可以使用基于策略的管理来创建包含条件表达式的条件。 然后创建一些策略,将这些条件应用于数据库目标对象。

任务说明

主题

介绍如何存储基于策略的管理策略。

基于策略的管理存储

介绍如何配置警报以通知策略管理员策略失败情况。

配置警报以通知策略管理员策略失败情况

介绍如何创建、查看、修改和删除基于策略的管理条件。

创建新的基于策略的管理条件

删除基于策略的管理条件

查看或修改基于策略的管理条件的属性

介绍如何创建、查看、修改和删除基于策略的管理策略。

创建基于策略的管理策略

删除基于策略的管理策略

查看或修改基于策略的管理策略的属性

介绍如何导出和导入基于策略的管理策略。

导出基于策略的管理策略

导入基于策略的管理策略

介绍如何验证服务器实例、数据库、服务器对象或数据库对象符合策略。

评估来自对象的基于策略的管理策略

从基于策略的管理策略评估该策略

定期评估基于策略的管理策略

介绍如何查看基于策略的管理方面状态并将其复制到文件中。

使用基于策略的管理方面

提供一组可以作为最佳实践策略导入的策略文件,然后介绍如何针对包含实例、实例对象、数据库或数据库对象的目标集评估策略。

使用基于策略的管理来监视和强制执行最佳实践

提供 SQL Server Management Studio 中对象资源管理器的“策略管理”节点的 F1 帮助主题。

“策略管理”节点(对象资源管理器)

请参阅

参考

基于策略的管理视图 (Transact-SQL)