注意:这不是重复的问题。
我已经设置了 AlwaysOn。我已经在两个节点上手动创建了 SQL 代理作业。如果节点是 PRIMARY,现在所有活动的作业都在运行。
挑战
我的 DBA 将根据业务需求仅在一个节点中手动禁用几个 SQL 代理作业。现在它如何同步到节点 2?DBA 是否必须在所有辅助节点中手动禁用这些相关作业?
我正在考虑创建一个表(该表将是可用性组的一部分),我在其中维护作业的状态。在故障转移期间,我计划运行脚本以从该表中读取数据并设置其他节点上的作业状态。这是正确的方式吗?或者我们有什么推荐的步骤吗?
请建议
有几种方法可以自动执行此操作,并且您正朝着正确的方向前进……您可以依靠 DBA 手动禁用和启用(不是很好;),您可以在表中跟踪作业状态并启用和禁用使用定期运行的作业,或者您可以对作业进行分类并响应角色更改警报……这就是我所做的。
一个粗略的大纲是:
Michael K. Campbell撰写了一个非常详细的SQL 杂志系列文章,其中提供了如何构建任一解决方案的代码示例,我从那篇文章开始,只需要进行少量修改。