iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >在异步镜像中移动镜像数据库文件实战
  • 170
分享到

在异步镜像中移动镜像数据库文件实战

2024-04-02 19:04:59 170人浏览 独家记忆
摘要

在异步数据库镜像中,移动镜像数据库文件实战某数据库部署为异步数据库镜像,镜像数据库所在磁盘空间不足,我得移动镜像数据库文件到新的磁盘上。 在异步数据库镜像中,应用程序连接到主数据库访问。我们这里要

在异步数据库镜像中,移动镜像数据库文件实战


数据库部署为异步数据库镜像,镜像数据库所在磁盘空间不足,我得移动镜像数据库文件到新的磁盘上。

 

在异步数据库镜像中,应用程序连接到主数据库访问。我们这里要根据你的线上环境考虑选择哪种方式合适:

  1. 直接重做镜像,将数据文件放在新的位置。

  2. 直接移动镜像数据库文件。

 

移动数据库文件的所有操作都是对镜像数据库实例,如果镜像数据库实例上没有其他线上主数据库,不会对线上业务产生影响的情况下,可以直接移动镜像数据库文件。


1. 在主库上点击“Pause”,暂停镜像会话。


2. 在镜像库上使用Alter Database指向一个新的位置。

a) 确定DXListing数据库的逻辑文件名称以及这些文件在磁盘上的当前位置。

SELECT name, physical_name
FROM sys.master_files
WHERE database_id = DB_ID('DXListing');
Go


b) 使用 ALTER DATABASE更改每个文件的位置。

USE master;
GO
ALTER DATABASE DXListing
MODIFY FILE (NAME = DXListing, FILENAME = 'E:\sql-DATA\DXListing.mdf');
GO
ALTER DATABASE DXListing
MODIFY FILE (NAME = DXListing_log, FILENAME = 'E:\SQL-DATA\DXListing.ldf');
GO


3. 停止镜像数据库所在实例的SQL Server服务。

4. 移动镜像数据库文件到一个新位置,并确保文件上的权限也还在。

5. 启动镜像数据库所在实例的SQL Server服务。

6. 在主库上点击“RESUME”,恢复镜像恢复,并验证镜像成功恢复。



还有一种方式,只需要重启镜像数据库所在实例的SQL Server服务,而不用暂停服务一段时间用于移动数据文件,实际线上我是用这种方式操作的。


1. 在主库上点击“Pause”,暂停镜像会话。


2. 在镜像库上使用Alter Database指向一个新的位置。

a) 确定DXListing数据库的逻辑文件名称以及这些文件在磁盘上的当前位置。

SELECT name, physical_name
FROM sys.master_files
WHERE database_id = DB_ID('DXListing');
GO


b) 使用 ALTER DATABASE更改每个文件的位置。

USE master;
GO
ALTER DATABASE DXListing
MODIFY FILE (NAME = DXListing, FILENAME = 'E:\SQL-DATA\DXListing.mdf');
GO
ALTER DATABASE DXListing
MODIFY FILE (NAME = DXListing_log, FILENAME = 'E:\SQL-DATA\DXListing.ldf');
GO


3. 重启镜像数据库所在实例的SQL Server服务。

4. 移动镜像数据库文件到一个新位置,并确保文件上的权限也还在。


这时,我们来看看镜像状态。

在主库上:

在异步镜像中移动镜像数据库文件实战

在异步镜像中移动镜像数据库文件实战

在镜像库上:

在异步镜像中移动镜像数据库文件实战


可以看到,镜像库状态不正常。这时,我在镜像库上执行以下操作:

USE master
GO
ALTER DATABASE DXListing SET PARTNER RESUME
GO


报错如下:

Msg 945, Level 14, State 2, Line 1

Database 'DXListing' cannot be opened due to inaccessible files or insufficient memory or disk space. See the SQL Server errorlog for details.


5. 使DXListing数据库 OFFLINE 再 ONLINE,以实施更改。(当然,此时重启SQL Server服务应该也可以,但建议还是在数据库级别操作)

USE master
GO
ALTER DATABASE DXListing SET OFFLINE
ALTER DATABASE DXListing SET ONLINE
GO


错误如下:

Msg 954, Level 14, State 1, Line 1

The database "DXListing" cannot be opened. It is acting as a mirror database.

Msg 5069, Level 16, State 1, Line 1

ALTER DATABASE statement failed.


这时,我们再来看看数据库状态。

在镜像库上:

在异步镜像中移动镜像数据库文件实战

在主库上:

在异步镜像中移动镜像数据库文件实战

在异步镜像中移动镜像数据库文件实战

发现状态已经正常。之前的错误可以忽略。


6. 在主库上点击“RESUME”,恢复镜像会话。验证镜像状态已同步。

在异步镜像中移动镜像数据库文件实战


参考:

https://msdn.microsoft.com/zh-cn/library/bb522469.aspx



您可能感兴趣的文档:

--结束END--

本文标题: 在异步镜像中移动镜像数据库文件实战

本文链接: https://www.lsjlt.com/news/39094.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作