0

0

如何配置并使用SQLServer代理服务_SQL Server Agent与定时任务

P粉602998670

P粉602998670

发布时间:2026-03-16 18:30:12

|

908人浏览过

|

来源于php中文网

原创

SQL Server Agent未启动是作业不执行的主因,需设为自动启动并配置NT Service\SQLSERVERAGENT账户;xp_cmdshell须启用且作业所有者需为sysadmin;调度受本地时区影响,跨午夜易出错;邮件通知需单独配置operator且域名须匹配。

如何配置并使用sqlserver代理服务_sql server agent与定时任务

SQL Server Agent 服务没启动,定时作业根本不会跑

SQL Server Agent 是 Windows 服务,不是 SQL Server 数据库引擎的一部分。装完 SQL Server 默认不自动启动它,更不会设为开机自启——这是绝大多数“作业不执行”的根源。

实操建议:

  • 打开 services.msc,找到 SQL Server Agent (MSSQLSERVER)(或带实例名的变体,如 SQL Server Agent (SQLEXPRESS)
  • 右键 → “属性” → “启动类型”设为 自动,然后点“启动”
  • 如果启动失败,常见原因是登录账户权限不足:在“登录”选项卡里,把“此账户”改成 NT Service\SQLSERVERAGENT(推荐)或一个有足够权限的域/本地账户
  • 改完重启服务,再进 SSMS 看 SQL Server Agent 节点是否变成绿色小箭头

作业步骤里 exec xp_cmdshell 失败:权限和配置双关卡

想用作业调外部命令(比如备份后发邮件、压缩文件),常写 EXEC xp_cmdshell 'xxx',但默认禁用,且代理账户没权限时直接报错 Msg 15281, Level 16

实操建议:

  • 先启用外围配置:sp_configure 'show advanced options', 1; RECONFIGURE; sp_configure 'xp_cmdshell', 1; RECONFIGURE;
  • 确认作业所有者(Owner)是 sysadmin 角色成员;否则即使启用 xp_cmdshell,非 sa 用户运行的作业仍被拦截
  • 避免用 sa 当作业所有者——改用一个专用账号,并只授予 sysadmin 权限(不要给它登录 SQL Server 的能力)
  • 如果脚本依赖环境变量或当前路径,xp_cmdshell 启动的是全新会话,得显式 cd 或用绝对路径

作业调度时间不准:注意 SQL Server Agent 的时区和夏令时逻辑

SQL Server Agent 内部全部按服务器本地时区解析时间,不读取 Windows 的“自动调整夏令时”设置。一旦系统时间因夏令时切换,你设的“每天 2:00 执行”可能某天跳成 1:00 或 3:00,甚至跳过一次。

知我AI
知我AI

一款多端AI知识助理,通过一键生成播客/视频/文档/网页文章摘要、思维导图,提高个人知识获取效率;自动存储知识,通过与知识库聊天,提高知识利用效率。

下载

实操建议:

  • 检查服务器 BIOS 时间是否准确,Windows 时间服务是否同步可靠(w32tm /query /status
  • 避免跨午夜调度(比如 23:50 → 00:10),Agent 在时钟回拨/前进时容易丢触发
  • 若业务强依赖 UTC 时间,别靠 Agent 调度,改用外部调度器(如 Windows Task Scheduler + sqlcmd)来绕过时区问题
  • 用 T-SQL 查最近作业历史:SELECT * FROM msdb.dbo.sysjobhistory WHERE step_id = 0 ORDER BY run_date DESC, run_time DESC,看 run_date/run_time 字段是否符合预期

邮件通知总收不到:Database Mail 和作业警报不是一回事

很多人以为配好 Database Mail 就能收到作业失败提醒,结果发现作业挂了也没邮件——因为“邮件通知”必须在作业属性里单独开启,且依赖 msdb.dbo.sp_notify_operator 这类系统过程,不是开 Database Mail 就自动生效。

实操建议:

  • 先确保 Database Mail 测试通过(SSMS → “管理” → “Database Mail” → 右键“发送测试电子邮件”)
  • 在作业属性 → “通知”页,勾选“当作业完成时通知”,再选“电子邮件”,并指定 operator(需提前在 msdb 里建好)
  • operator 的邮箱地址必须和 Database Mail 配置里的“发件人地址”域名一致,否则某些 SMTP 服务器拒信
  • 作业失败通知默认只发一次;如果想每次失败都发,得在“通知”页勾选“当作业失败时重复通知”,并设间隔(单位分钟)

Agent 的日志细节藏得深,sysjobhistory 表里 message 字段经常比 SSMS GUI 显示的更全;遇到“执行成功但结果不对”,一定去翻它。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1135

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

381

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

2256

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

380

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1743

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

586

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

441

2024.04.29

chatgpt使用指南
chatgpt使用指南

本专题整合了chatgpt使用教程、新手使用说明等等相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号