热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

作业迁移

背景:数据库服务器更换,1、数据库迁移(BACKUPRESTORE);2、数据库登录名用户迁移(注意孤立用户);3、作业迁移数据库迁移,备份数据库、拷贝备份文件到新服务器,还原数据

背景:数据库服务器更换,1、数据库迁移(BACKUP/RESTORE);2、数据库登录名/用户迁移(注意孤立用户);3、作业迁移
数据库迁移,备份数据库、拷贝备份文件到新服务器,还原数据库

技术分享技术分享
--还原示例
USE [master]
RESTORE DATABASE [DBA_Monitor] FROM  DISK = ND:\rsyncroot\PLAY_DBA_Monitor_F_20150630_1.bak 
WITH  FILE = 1
,  MOVE NDBA_Monitor TO ND:\LoveGame\Data\DBA_Monitor\DBA_Monitor.mdf
,  MOVE NDBA_Monitor_log TO ND:\LoveGame\Data\DBA_Monitor\DBA_Monitor_log.ldf
,  NOUNLOAD,  REPLACE,  STATS = 5
GO
View Code

数据库登录名迁移,新实例中创建同名数据库登录名,待数据库还原后,使用以下语句处理孤立用户

技术分享技术分享
--孤立用户
USE DBA_Monitor
GO
exec sp_change_users_login REPORT
exec sp_change_users_login UPDATE_ONE,用户名,登录名--更新库下用户的sid成登录名的sid
GO
View Code

创建数据库登录名时带上sid可避免孤立用户的产生。
作业迁移,如果数据库版本与原数据库版本保持一致,则可直接还原msdb数据库;如果数据库版本不一致,且迁移的作业比较多,可使用以下语句进行迁移

技术分享技术分享
/******************************************************************
【概要说明】
    <创建时间>    2015/6/8 11:14
    <中文名称>    作业迁移
    <功能说明>    通过insert、update语句导入作业信息,目的是将实例A中的作业迁移到实例B中
    <调用方式>    手动执行
    <执行说明>    先决条件:还原前请先备份两边的msdb数据库,将实例A中的msdb还原到实例B的msdbnew
                 出错处理:如果出错,请还原原备份文件
                 注意事项:此代码适用用于数据库版本不一致,且迁移的作业比较多的情况;如果版本号相同,可直接还原数据库
【修订记录】
-------------------------------------------------------------------
    <2015/6/8 11:14>  : 创建
******************************************************************/
--作业Job
insert into [msdb].[dbo].[sysjobs]
SELECT a.[job_id]
      ,a.[originating_server_id]
      ,109Job_+a.[name]--作业名称加前缀区分
      ,a.[enabled]
      ,a.[description]
      ,a.[start_step_id]
      ,a.[category_id]
      ,suser_sid()--将所有者更新为当前登录用户
      ,a.[notify_level_eventlog]
      ,a.[notify_level_email]
      ,a.[notify_level_netsend]
      ,a.[notify_level_page]
      ,a.[notify_email_operator_id]
      ,a.[notify_netsend_operator_id]
      ,a.[notify_page_operator_id]
      ,a.[delete_level]
      ,a.[date_created]
      ,a.[date_modified]
      ,a.[version_number]
  FROM [msdbnew].[dbo].[sysjobs] a
  left join [msdb].[dbo].[sysjobs] b
  on a.job_id=b.job_id
  where a.enabled=1
  and b.job_id is null
order by date_created
go
--步骤jobsteps
insert into [msdb].[dbo].[sysjobsteps]
SELECT a.[job_id]
      ,a.[step_id]
      ,a.[step_name]
      ,a.[subsystem]
      ,a.[command]
      ,a.[flags]
      ,a.[additional_parameters]
      ,a.[cmdexec_success_code]
      ,a.[on_success_action]
      ,a.[on_success_step_id]
      ,a.[on_fail_action]
      ,a.[on_fail_step_id]
      ,a.[server]
      ,a.[database_name]
      ,a.[database_user_name]
      ,a.[retry_attempts]
      ,a.[retry_interval]
      ,a.[os_run_priority]
      ,a.[output_file_name]
      ,a.[last_run_outcome]
      ,a.[last_run_duration]
      ,a.[last_run_retries]
      ,a.[last_run_date]
      ,a.[last_run_time]
      ,a.[proxy_id]
      ,a.[step_uid]
  FROM [msdbnew].[dbo].[sysjobsteps] a
  inner join [msdb].[dbo].[sysjobs] b
  on a.job_id=b.job_id
  left join [msdb].[dbo].[sysjobsteps] c
  on a.job_id=c.job_id
  where c.job_id is null
go
--调度schedules
insert into [msdb].[dbo].[sysschedules]
SELECT a.[schedule_uid]
      ,a.[originating_server_id]
      ,a.[name]
      ,suser_sid()--将所有者更新为当前登录用户
      ,a.[enabled]
      ,a.[freq_type]
      ,a.[freq_interval]
      ,a.[freq_subday_type]
      ,a.[freq_subday_interval]
      ,a.[freq_relative_interval]
      ,a.[freq_recurrence_factor]
      ,a.[active_start_date]
      ,a.[active_end_date]
      ,a.[active_start_time]
      ,a.[active_end_time]
      ,a.[date_created]
      ,a.[date_modified]
      ,a.[version_number]
  FROM [msdbnew].[dbo].[sysschedules] a
  inner join [msdbnew].[dbo].[sysjobschedules] b
  on a.schedule_id=b.schedule_id
  inner join [msdb].[dbo].[sysjobs] c
  on b.job_id=c.job_id
  left join [msdb].[dbo].[sysschedules] d
  on a.schedule_uid=d.schedule_uid
  where d.schedule_uid is null
go
--关联job_id和schedule_id
insert into [msdb].[dbo].[sysjobschedules]
SELECT c.schedule_id
      ,a.[job_id]
      ,a.[next_run_date]
      ,a.[next_run_time]
  FROM [msdbnew].[dbo].[sysjobschedules] a
  inner join [msdbnew].[dbo].[sysschedules] b
  on a.schedule_id=b.schedule_id
  inner join [msdb].[dbo].[sysschedules] c
  on b.schedule_uid=c.schedule_uid
  left join [msdb].[dbo].[sysjobschedules] d
  on a.job_id=d.job_id
  where d.job_id is null
go
--指定目标服务器
insert into [msdb].[dbo].[sysjobservers]
SELECT a.[job_id]
      ,a.[server_id]
      ,a.[last_run_outcome]
      ,a.[last_outcome_message]
      ,a.[last_run_date]
      ,a.[last_run_time]
      ,a.[last_run_duration]
  FROM [msdbnew].[dbo].[sysjobservers] a
  inner join [msdb].[dbo].[sysjobs] b
  on a.job_id=b.job_id
  left join [msdb].[dbo].[sysjobservers] c
  on a.job_id=c.job_id
  where c.job_id is null
go

/********如果对作业的所有者有特殊要求,参考下面代码进行修改********/
--Start
--原实例下获取作业所有者
select sj.name,sj.date_created,sj.date_modified,ssp.name OwnName,sj.owner_sid
from msdb.dbo.sysjobs sj
inner join sys.server_principals ssp
on sj.owner_sid=ssp.sid
where ssp.name=USER_JOB
order by sj.name

--新实例下更新需要修改的所有者
update msdb.dbo.sysjobs 
set owner_sid=suser_sid(user_job)
where job_id in(
select job_id from msdbnew.dbo.sysjobs
where owner_sid=convert(varbinary,0x047EC52E6005D241932C0DC5F0827615))--原作业所有者

update [msdb].[dbo].[sysschedules]
set owner_sid=suser_sid(user_job)
where schedule_id in(
select schedule_id from [msdbnew].[dbo].[sysschedules]
where owner_sid=convert(varbinary,0x047EC52E6005D241932C0DC5F0827615))--原作业所有者
--End

--上面操作完成后,作业并不会按计划执行作业。可用下面方式中的任意一种使作业按计划运行
--1重启代理服务;2禁用作业再启用作业;3修改并保存作业
--应该可以直接执行某个语句(暂时没找到)
View Code

如果创建数据库登录名时指定了sid,则以此登录名为所有者的作业对应的[sysjobs]、[sysschedules]表中的owner_sid可以直接从原表获取。

作业迁移


推荐阅读
  • 优化局域网SSH连接延迟问题的解决方案
    本文介绍了解决局域网内SSH连接到服务器时出现长时间等待问题的方法。通过调整配置和优化网络设置,可以显著缩短SSH连接的时间。 ... [详细]
  • 通过Web界面管理Linux日志的解决方案
    本指南介绍了一种利用rsyslog、MariaDB和LogAnalyzer搭建集中式日志管理平台的方法,使用户可以通过Web界面查看和分析Linux系统的日志记录。此方案不仅适用于服务器环境,还提供了详细的步骤来确保系统的稳定性和安全性。 ... [详细]
  • 本文介绍如何在Linux服务器之间使用SCP命令进行文件传输。SCP(Secure Copy Protocol)是一种基于SSH的安全文件传输协议,支持从远程机器复制文件到本地服务器或反之。示例包括从192.168.45.147复制tomcat目录到本地/home路径。 ... [详细]
  • 本题探讨如何通过最大流算法解决农场排水系统的设计问题。题目要求计算从水源点到汇合点的最大水流速率,使用经典的EK(Edmonds-Karp)和Dinic算法进行求解。 ... [详细]
  • Startup 类配置服务和应用的请求管道。Startup类ASP.NETCore应用使用 Startup 类,按照约定命名为 Startup。 Startup 类:可选择性地包括 ... [详细]
  • 本文将介绍网易NEC CSS框架的规范及其在实际项目中的应用。通过详细解析其分类和命名规则,探讨如何编写高效、可维护的CSS代码,并分享一些实用的学习心得。 ... [详细]
  • 创建项目:Visual Studio Online 入门指南
    本文介绍如何使用微软的 Visual Studio Online(VSO)创建和管理开发项目。作为一款基于云计算的开发平台,VSO 提供了丰富的工具和服务,简化了项目的配置和部署流程。 ... [详细]
  • 并发编程:深入理解设计原理与优化
    本文探讨了并发编程中的关键设计原则,特别是Java内存模型(JMM)的happens-before规则及其对多线程编程的影响。文章详细介绍了DCL双重检查锁定模式的问题及解决方案,并总结了不同处理器和内存模型之间的关系,旨在为程序员提供更深入的理解和最佳实践。 ... [详细]
  • 本文详细探讨了JDBC(Java数据库连接)的内部机制,重点分析其作为服务提供者接口(SPI)框架的应用。通过类图和代码示例,展示了JDBC如何注册驱动程序、建立数据库连接以及执行SQL查询的过程。 ... [详细]
  • 深入理解ASP.NET MVC中的_ViewStart.cshtml
    本文介绍了_ViewStart.cshtml文件在ASP.NET MVC 3.0及以上版本中的作用和使用方法。该文件位于Views目录下,主要用于统一配置视图布局和其他全局设置。 ... [详细]
  • 本文介绍了如何使用Java中的同步方法和同步代码块来实现两个线程的交替打印。一个线程负责打印1到52的数字,另一个线程负责打印A到Z的字母,确保输出顺序为12A34B...5152Z。 ... [详细]
  • 本文详细探讨了 Django 的 ORM(对象关系映射)机制,重点介绍了其如何通过 Python 元类技术实现数据库表与 Python 类的映射。此外,文章还分析了 Django 中各种字段类型的继承结构及其与数据库数据类型的对应关系。 ... [详细]
  • 探讨了在有序数列中实现多种查询和修改操作的高效数据结构设计,主要使用线段树与平衡树(Treap)结合的方法。 ... [详细]
  • 深入理解T-SQL中的NULL与三值逻辑
    本文探讨了SQL Server中的三值逻辑,解释了谓词计算结果为TRUE、FALSE和UNKNOWN的规则。通过具体示例,详细说明了如何正确处理NULL值,并探讨了在不同约束条件下的行为。 ... [详细]
  • 本文介绍如何通过 JavaScript 实现一个基于鼠标坐标的 Tooltip 弹出层,详细解释了如何获取窗口和文档的尺寸及滚动位置,并优化了代码结构。 ... [详细]
author-avatar
手机用户2502917141
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有