Бөлісу құралы:


Агент SQL Server

Область применения: SQL Server Управляемый экземпляр SQL Azure

В этой статье представлен обзор агент SQL Server, которая является службой Microsoft Windows, которая выполняет запланированные административные задачи (называемые заданиями) в SQL Server и Управляемый экземпляр SQL Azure.

Внимание

В Управляемом экземпляре Azure SQL в настоящее время поддерживается большинство функций агента SQL Server (но не все). Подробные сведения см. в статье Различия в T-SQL между Управляемым экземпляром SQL Azure и SQL Server.

Преимущества агента SQL Server

Агент SQL Server использует SQL Server для хранения сведений о задании. Задание состоит из одного или нескольких шагов. Каждый шаг содержит собственную задачу, например создание резервной копии базы данных.

Агент SQL Server может выполнять задания по расписанию в ответ на определенное событие или по требованию. Например, можно автоматизировать задачу создания резервной копии всех серверов компании, чтобы она выполнялась ежедневно по окончании рабочего дня. Запланируйте выполнение резервного копирования после 22:00 с понедельника по пятницу. Если во время создания резервной копии возникает проблема, агент SQL Server регистрирует соответствующее событие и выдает уведомление.

Примечание.

Служба агента SQL Server по умолчанию отключена, если во время установки SQL Server явно не выбран автоматический запуск службы.

Компоненты агента SQL Server

Агент SQL Server использует следующие компоненты, чтобы определить задачи для выполнения, время для выполнения задач и порядок уведомления об успешном или неудачном завершении задач.

Используйте диспетчер конфигурации SQL Server для управления службой агент SQL Server и использования SQL Server Management Studio (SSMS) для агент SQL Server управления свойствами, заданиями, оповещениями, операторами и прокси-серверами SQL Server Management Studio (SSMS) в графическом пользовательском интерфейсе.

Работы

Задание — это указанная последовательность действий, выполняемая агентом SQL Server. Используйте задания, чтобы определить задачу администрирования, которую можно запустить один или несколько раз и отслеживать ее успешное выполнение или сбой. Задание может выполняться на одном локальном или на нескольких удаленных серверах.

Внимание

Задания агента SQL Server, которые выполнялись во время отработки отказа в экземпляре отказоустойчивого кластера SQL Server, не возобновляются после отработки отказа и переключения на другой узел отказоустойчивого кластера. Задания агента SQL Server, которые выполнялись во время приостановки работы узла Hyper-V, не возобновляются, если приостановка вызывает отработку отказа с переходом на другой узел. Задания, выполнение которых было начато, но не завершилось в связи с событием отработки отказа, регистрируются в журнале как начатые, но дополнительных записей журнала о завершении или сбое нет. Задания агента SQL Server выглядят как незавершенные.

Выполнять задания можно несколькими способами:

  • по одному или нескольким расписаниям;

  • в ответ на одно или несколько предупреждений;

  • Выполнив хранимую sp_start_job процедуру.

Каждое действие в задании является шагом задания. Например, шаг задания может состоять из выполнения инструкции Transact-SQL, выполнения пакета служб SQL Server Integration Services или выдачи команды серверу служб Analysis Services. Шагами задания управляют как частью задания.

Каждый шаг задания выполняется в указанном контексте безопасности. Для шагов заданий, использующих Transact-SQL, применяйте инструкцию EXECUTE AS, чтобы указать контекст безопасности для шага задания. Для других типов шагов заданий используйте учетную запись-посредник, чтобы указать контекст безопасности для шага задания.

Используйте хранимую процедуру sp_help_job системы, чтобы узнать сведения о конкретном задании. Используйте системную таблицу dbo.sysjobs для просмотра сведений о заданиях. Например, используйте следующую инструкцию Transact-SQL (T-SQL) для просмотра сведений обо всех заданиях на сервере:

USE MSDB
GO
SELECT job_id, [name] FROM dbo.sysjobs;

Расписания

Расписание определяет время выполнения задания. Несколько заданий могут выполняться по тому же расписанию, а несколько расписаний могут применяться для одного задания. Расписание может определить следующие условия для времени выполнения задания:

  • при каждом запуске агента SQL Server;

  • каждый раз, когда загрузка ЦП компьютера достигает уровня, который определен как уровень простоя;

  • однажды, в указанные дату и время;

  • Для повторяющегося расписания.

Дополнительные сведения см. в статье "Создание и присоединение расписаний к заданиям".

видны узлы

Предупреждение — это автоматический ответ на наступление указанного события. Например, событие может быть заданием, которое начинает выполняться, или системным ресурсом, достигшим указанного порогового значения. Пользователь определяет условия, при которых выдается предупреждение.

Предупреждение может быть реакцией на одно из следующих условий:

  • события SQL Server;

  • условия производительности SQL Server;

  • события инструментария управления Microsoft Windows (WMI) на компьютере, где работает агент SQL Server;

Предупреждение может выполнять следующие действия:

  • уведомить один или несколько операторов;

  • Выполнение задания

Дополнительные сведения см. в статье Оповещения.

Операторы

Оператор определяет контактные сведения о лице, ответственном за обслуживание одного или нескольких экземпляров SQL Server. В некоторых организациях обязанности оператора возлагаются на одно лицо. В организациях, использующих несколько серверов, обязанности оператора могут быть разделены между несколькими лицами. Оператор не содержит сведений о безопасности и не определяет субъект безопасности.

SQL Server может уведомлять операторов о предупреждениях через...

  • Эл. почта

  • пейджер (через электронную почту);

  • команда net send.

Примечание.

Чтобы отправлять уведомления с помощью net send, служба Windows Messenger должна быть запущена на компьютере, где работает агент SQL Server.

Внимание

Режимы отправки уведомлений с помощью пейджера и команды net send будут удалены из агента SQL Server в следующей версии SQL Server. Старайтесь не использовать эти функции в новых разработках и предусмотрите соответствующие изменения в приложениях, которые используют их в настоящее время.

Для отправки операторам уведомлений по электронной почте или на пейджер необходимо настроить агент SQL Server для использования компонента Database Mail. Дополнительные сведения см. в разделе о компоненте Database Mail.

Можно определить оператора как псевдоним для группы лиц. Таким способом все члены этого псевдонима не будут проверяться одновременно. Дополнительные сведения см. в статье Операторы.

Безопасность для администрирования агент SQL Server

агент SQL Server использует Роли базы данных SQLAgentUserRole, SQLAgentReaderRole и SQLAgentOperatorRole для управления доступом к агент SQL Server для пользователей, не являющихся членами предопределенной роли сервера sysadmin. msdb Помимо этих предопределенных ролей базы данных, подсистемы и учетные записи-посредники позволяют администраторам базы данных гарантировать, что каждый шаг задания выполняется с минимальными разрешениями, необходимыми для выполнения задачи.

Роли

Члены предопределенных ролей msdbбазы данных SQLAgentUserRole, SQLAgentReaderRole и SQLAgentOperatorRole, а члены предопределенной роли сервера sysadmin имеют доступ к агент SQL Server. Пользователь, не принадлежащий ни к одной из этих ролей, не может использовать агент SQL Server. Дополнительные сведения о ролях, используемых агентом SQL Server, см. в разделе Обеспечение безопасности агента SQL Server.

Подсистемы

Подсистема — это предопределенный объект, который содержит функции, доступные шагу задания. Каждая учетная запись-посредник имеет доступ к одной или нескольким подсистемам. Подсистемы обеспечивают безопасность, поскольку разграничивают доступ учетных записей-посредников к функциям. Каждый шаг задания выполняется в контексте учетной записи-посредника, за исключением этапов задания Transact-SQL. На этапах задания Transact-SQL применяйте команду EXECUTE AS, чтобы задать контекст безопасности для владельца задания.

SQL Server определяет подсистемы, перечисленные в следующей таблице:

Имя подсистемы Description
Скрипт Microsoft ActiveX Выполните шаг задания со скриптом ActiveX.

Предупреждение. Подсистема скриптов ActiveX будет удалена из агента SQL Server в будущей версии Microsoft SQL Server. Избегайте использования этого компонента в новых разработках и запланируйте изменение существующих приложений, в которых он применяется.
Операционная система (CmdExec) Запустите исполняемую программу.
PowerShell Выполните шаг задания со скриптом PowerShell.
Распространитель репликации Выполните шаг задания, на котором активируется агент распространителя репликации.
Репликация слиянием Выполните шаг задания, на котором активируется агент репликации слиянием.
Агент чтения очереди репликации Выполните шаг задания, на котором активируется агент чтения очереди репликации.
Моментальный снимок репликации Выполните шаг задания, на котором активируется агент моментальных снимков.
Агент чтения журнала транзакций репликации Выполните шаг задания, на котором активируется агент чтения журнала.
Команда служб Analysis Services Выполните команду служб Analysis Services.
Запрос служб Analysis Services Выполните запрос служб Analysis Services.
Выполнение пакетов служб SSIS Запустите пакет SSIS.

Примечание.

Поскольку в шагах задания Transact-SQL учетные записи-посредники не используются, какие-либо подсистемы агента SQL Server для шагов задания Transact-SQL отсутствуют.

Агент SQL Server применяет ограничения подсистемы принудительно, даже если обычно субъект безопасности для учетной записи-посредника имеет разрешение на выполнение задачи на шаге задания. Например, пользователь, являющийся членом предопределенной роли администратора сервера, не сможет выполнить шаг задания служб SQL Server Integration Services, если его учетная запись-посредник не имеет доступа к подсистеме служб SQL Server Integration Services, несмотря на то, что пользователь может выполнять пакеты служб SQL Server Integration Services.

Прокси

Агент SQL Server для управления контекстами безопасности использует учетные записи-посредники. Учетная запись-посредник может быть использована на нескольких шагах задания. Создавать учетные записи-посредники могут члены предопределенной роли администратора сервера.

Каждой учетной записи-посреднику соответствует учетная запись системы безопасности. и может быть связана с множеством подсистем и множеством имен входа. Учетная запись-посредник может применяться только для шагов задания, которые используют связанную с этой учетной записью-посредником подсистему. Чтобы создать шаг задания, использующий определенную учетную запись-посредник, владелец задания должен либо использовать связанное с ней имя входа, либо быть членом роли, имеющей неограниченный доступ к учетным записям-посредникам. Члены предопределенной роли администратора сервера имеют неограниченный доступ к учетным записям-посредникам. Члены ролей SQLAgentUserRole, SQLAgentReaderRoleи SQLAgentOperatorRole могут использовать только учетные записи-посредники, на которые им был предоставлен особый доступ. Каждому пользователю, входящему в одну из предопределенных ролей базы данных агента SQL Server, необходимо предоставить доступ к конкретным учетным записям-посредникам, чтобы пользователь мог создавать шаги задания, которые будут использовать эти учетные записи-посредники.

Автоматизация администрирования

Используйте следующие шаги для настройки агента SQL Server для автоматического администрирования SQL Server:

  1. Определите, какие административные задачи или события сервера происходят регулярно, а также можно ли эти задачи или события администрировать программным путем. Подходящей для автоматизации является такая задача, которая включает предсказуемую последовательность шагов и выполняется в определенное время или в ответ на определенное событие.

  2. Определите набор заданий, расписаний, предупреждений и операторов, используя среду SQL Server Management Studio, скрипты Transact-SQL или управляющие объекты SQL Server (SMO). Дополнительные сведения см. в разделе Создание работ.

  3. Выполните определенные задания агента SQL Server.

Примечание.

Для экземпляра SQL Server по умолчанию служба SQL Server называется SQLSERVERAGENT. В именованных экземплярах служба агента SQL Server имеет имя SQLAgent$имя_экземпляра.

Если запущено несколько экземпляров SQL Server, то, чтобы автоматизировать общие для всех экземпляров задания, можно использовать администрирование нескольких серверов. Дополнительные сведения см. в статье Автоматизация администрирования в масштабах предприятия.

Используйте следующие задачи, чтобы начать работу с агентом SQL Server:

Description Статья
Содержит инструкции по настройке агента SQL Server. Настройка агента SQL Server
Описывает запуск, остановку и приостановку службы агента SQL Server. Запуск, остановка или приостановка службы агента SQL Server
Описывает вопросы задания учетных записей для службы агента SQL Server. Выбор учетной записи для службы агента SQL Server
Описывает использование журнала ошибок агента SQL Server. Журнал ошибок агента SQL Server
Содержит инструкции по использованию объектов производительности. Использование объектов производительности
Описывает мастер планов обслуживания — программу, которая используется для создания заданий, оповещений и операторов для автоматизации администрирования экземпляра SQL Server. Использование мастера планов обслуживания
Описывает автоматизацию задач администрирования с помощью агента SQL Server. Задачи автоматизированного администрирования (агент SQL Server)

NOSQLPS

Начиная с версии SQL Server 2019, вы можете отключить SQLPS. Для этого в первой строке шага задания типа PowerShell можно добавить #NOSQLPS, чтобы Агент SQL не запускал автоматическую загрузку модуля SQLPS. После этого задание Агента SQL запустит установленную на компьютере версию PowerShell, и вы можете использовать любой другой модуль PowerShell.

Если вы хотите использовать модуль SqlServer в шаге задания Агента SQL, можно поместить этот код в первые две строки скрипта.

#NOSQLPS
Import-Module -Name SqlServer