Агент SQL Server
Агент SQL Server — это служба Microsoft Windows, выполняющая запланированные административные задачи, которые называются заданиями в SQL Server 2012.
В этом разделе
Преимущества агента SQL Server
Компоненты агента SQL Server
Безопасность при администрировании агента SQL Server
Преимущества агента SQL Server
Агент SQL Server использует SQL Server для хранения сведений о заданиях. Задание состоит из одного или нескольких шагов. Каждый шаг содержит собственную задачу, например создание резервной копии базы данных.
Агент SQL Server может выполнять задания по расписанию в ответ на определенное событие или по требованию. Например, можно автоматизировать задачу создания резервной копии всех серверов компании, чтобы она выполнялась ежедневно по окончании рабочего дня. Запланируйте запуск резервного копирования после 22:00 с понедельника по пятницу; если во время создания резервной копии возникает проблема, агент SQL Server регистрирует соответствующее событие и выдает уведомление.
Примечание |
---|
Служба агента SQL Server по умолчанию отключена, если во время установки SQL Server 2012 явно не выбран автоматический запуск службы. |
[В начало]
Компоненты агента SQL Server
Агент SQL Server использует следующие компоненты, чтобы определить задачи для выполнения, время для выполнения задач и порядок уведомления об успешном или неудачном завершении задач.
Задания
Задание — это указанная последовательность действий, выполняемых агентом SQL Server. Используйте задания, чтобы определить задачу управления, которую можно выполнить однажды или неоднократно и контролировать на предмет успешного или неудачного выполнения. Задание может выполняться на одном локальном сервере или на нескольких удаленных серверах.
Важно! |
---|
Задания агента SQL Server, которые выполнялись во время отработки отказа на экземпляре отказоустойчивого кластера SQL Server, не возобновляются после отработки отказа и переключения на другой узел отказоустойчивого кластера. Задания агента SQL Server, которые выполнялись во время приостановки работы узла Hyper-V, не возобновляются, если приостановка вызывает отработку отказа с переходом на другой узел. Задания, выполнение которых было начато, но не завершилось в связи с событием отработки отказа, регистрируются в журнале как начатые, но дополнительных записей журнала о завершении или сбое нет. Задания агента в этих сценариях SQL Server выглядят как незавершенные. |
Выполнять задания можно несколькими способами.
По одному или нескольким расписаниям.
В ответ на одно или несколько предупреждений.
С помощью выполнения хранимой процедуры sp_start_job.
Каждое действие в задании является шагом задания. Например шаг задания может состоять из выполнения инструкции Transact-SQL, выполнения пакета служб Службы SSIS или выдачи команды серверу служб Analysis Services. Шагами задания управляют как частью задания.
Каждый шаг задания выполняется в указанном контексте безопасности. Для шагов заданий, использующих Transact-SQL, применяйте инструкцию EXECUTE AS, чтобы указать контекст безопасности для шага задания. Для других типов шагов заданий используйте учетную запись-посредник, чтобы указать контекст безопасности для шага задания.
Расписания
Расписание определяет время выполнения задания. Сразу несколько заданий могут выполняться по одному и тому же расписанию, а несколько расписаний могут применяться к одному и тому же заданию. Расписание может определить следующие условия для времени выполнения задания:
При каждом запуске агента SQL Server.
Каждый раз, когда использование ЦП компьютера будет достигать уровня, который определен как уровень простоя.
Однажды, в указанные дату и время.
Согласно повторяющемуся расписанию.
Дополнительные сведения см. в разделе Создание и присоединение расписаний к заданиям.
Предупреждения
Предупреждение — это автоматический ответ на наступление указанного события. Например, событие может быть заданием, которое начинает выполняться, или системным ресурсом, достигшим указанного порогового значения. Пользователь определяет условия, при которых выдается предупреждение.
Предупреждение может быть реакцией на одно из следующих условий:
События SQL Server
Условия производительности SQL Server
События инструментария управления Microsoft Windows (WMI) на компьютере, где работает агент SQL Server Agent
Предупреждение может выполнять следующие действия:
Уведомить один или несколько операторов
Осуществить запуск задания
Дополнительные сведения см. в разделе Предупреждения.
Операторы
Оператор определяет контактные сведения о лице, ответственном за обслуживание одного или нескольких экземпляров 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 в базе данных msdb для управления доступом к агенту SQL Server для пользователей, не входящих в предопределенную роль сервера sysadmin. Помимо этих предопределенных ролей базы данных, подсистемы и учетные записи-посредники позволяют администраторам базы данных гарантировать, что каждый шаг задания выполняется с минимальными разрешениями, необходимыми для выполнения задачи.
Роли
Доступ к агенту SQL Server имеют члены предопределенных ролей базы данных SQLAgentUserRole, SQLAgentReaderRole и SQLAgentOperatorRole в базе данных msdb, а также члены предопределенной роли сервера sysadmin. Пользователь, не принадлежащий ни к одной из этих ролей, не может использовать агент SQL Server. Дополнительные сведения о ролях, используемых агентом SQL Server, см. в разделе Обеспечение безопасности агента SQL Server.
Подсистемы
Подсистема — это предопределенный объект, который содержит функции, доступные шагу задания. Каждая учетная запись-посредник имеет доступ к одной или нескольким подсистемам. Подсистемы обеспечивают безопасность, поскольку разграничивают доступ учетных записей-посредников к функциям. Каждый шаг задания выполняется в контексте учетной записи-посредника, за исключением этапов задания Transact-SQL. Для шагов заданий, использующих Transact-SQL, применяйте команду EXECUTE AS, чтобы задать контекст безопасности для шага задания.
SQL Server определяет подсистемы, перечисленные в следующей таблице:
Имя подсистемы |
Описание |
||
---|---|---|---|
Скрипт Microsoft ActiveX |
Выполните шаг задания со скриптом ActiveX.
|
||
Операционная система (CmdExec) |
Запустите исполняемую программу. |
||
PowerShell |
Выполните шаг задания со скриптом PowerShell. |
||
Распространитель репликации |
Выполните шаг задания, на котором активируется агент распространителя репликации. |
||
Репликация слиянием |
Выполните шаг задания, на котором активируется агент репликации слиянием. |
||
Агент чтения очереди репликации |
Выполните шаг задания, на котором активируется агент чтения очереди репликации. |
||
Моментальный снимок репликации |
Выполните шаг задания, на котором активируется агент моментальных снимков. |
||
Агент чтения журнала транзакций репликации |
Выполните шаг задания, на котором активируется агент чтения журнала. |
||
Команда служб Analysis Services |
Выполните команду служб Analysis Services. |
||
Запрос служб Analysis Services |
Выполните запрос служб Analysis Services. |
||
Выполнение пакета служб Службы SSIS |
Выполните пакет служб Службы SSIS. |
Примечание |
---|
Поскольку в шагах задания Transact-SQL учетные записи-посредники не используются, какие-либо подсистемы агента SQL Server для шагов задания Transact-SQL отсутствуют. |
Агент SQL Server применяет ограничения подсистемы принудительно, даже если обычно субъект безопасности для учетной записи-посредника имеет разрешение на выполнение задачи на шаге задания. Например, учетная запись-посредник для пользователя, входящего в предопределенную роль сервера sysadmin, не может выполнить шаг задания служб Службы SSIS, если эта запись не имеет доступа к подсистеме служб Службы SSIS, даже если пользователь может выполнять пакеты служб Службы SSIS.
Учетные записи-посредники
Агент SQL Server для управления контекстами безопасности использует учетные записи-посредники. Учетная запись-посредник может быть использована на нескольких шагах задания. Создавать учетные записи-посредники могут члены предопределенной роли сервера sysadmin.
Каждая учетная запись-посредник соответствует учетной записи безопасности и может быть связана с множеством подсистем и множеством имен входа. Учетная запись-посредник может применяться только для шагов задания, которые используют связанную с этой учетной записью-посредником подсистему. Чтобы создать шаг задания, использующий определенную учетную запись-посредник, владелец задания должен либо использовать связанное с ней имя входа, либо быть членом роли, имеющей неограниченный доступ к учетным записям-посредникам. Члены предопределенной роли сервера sysadmin имеют неограниченный доступ к учетным записям-посредникам. Члены ролей SQLAgentUserRole, SQLAgentReaderRole и SQLAgentOperatorRole могут использовать только учетные записи-посредники, на которые им был предоставлен особый доступ. Каждому пользователю, входящему в одну из предопределенных ролей базы данных агента SQL Server, необходимо предоставить доступ к конкретным учетным записям-посредникам, чтобы пользователь мог создавать шаги задания, которые будут использовать эти учетные записи-посредники.
Связанные задачи
Используйте следующие шаги для настройки агента SQL Server для автоматического администрирования SQL Server.
Определите, какие административные задачи или события сервера происходят регулярно, а также можно ли эти задачи или события администрировать программным путем. Подходящей для автоматизации является такая задача, которая включает предсказуемую последовательность шагов и выполняется в определенное время или в ответ на определенное событие.
Определите набор заданий, расписаний, предупреждений и операторов, используя среду Среда SQL Server Management Studio, скрипты Transact-SQL или управляющие объекты (SMO) SQL Server. Дополнительные сведения см. в разделе Создание заданий.
Запустите назначенные задания агента SQL Server.
Примечание |
---|
В экземпляре SQL Server по умолчанию служба SQL Server имеет имя SQLSERVERAGENT. В именованных экземплярах служба агента SQL Server имеет имя SQLAgent$instancename. |
Если запущено несколько экземпляров SQL Server, то чтобы автоматизировать общие для всех экземпляров задания, можно использовать администрирование нескольких серверов. Дополнительные сведения см. в разделе Автоматизация администрирования в масштабах предприятия.
Используйте следующие задачи, чтобы начать работу с агентом SQL Server.
Описание |
Раздел |
Содержит инструкции по настройке агента SQL Server. |
|
Описывает запуск, остановку и приостановку службы агента SQL Server. |
|
Описывает вопросы задания учетных записей для службы агента SQL Server. |
|
Описывает использование журнала ошибок агента SQL Server. |
|
Содержит инструкции по использованию объектов производительности. |
|
Описывает мастер планов обслуживания программу, которая используется для создания заданий, оповещений и операторов для автоматизации администрирования экземпляра SQL Server. |
|
Описывает автоматизацию задач администрирования с помощью агента SQL Server. |
Задачи автоматизированного администрирования (агент SQL Server) |
[В начало]