SQLServer 以备份初始化订阅

原文: SQLServer 以备份初始化订阅

在创建事务复制时,如果发布数据库很大,使用快照初始化时,将等待很久,如果出现问题可能又得重新初始化。使用备份初始化会省很多时间,但是数据库在创建发布订阅期间不能访问。使用备份代替快照迁移数据,备份可以压缩或使用 FTP 传输,若在同一个机房,拷贝复制更快。


现在测试:

创建测试库(发布服务器)

--	创建测试库(发布服务器)
USE [master]
GO
CREATE DATABASE [PubDB]
ON  PRIMARY 
(
	NAME = N'PubDB', 
	FILENAME = N'D:\Program Files\Microsoft SQL Server\MSSQL12.MSSQLSERVER\MSSQL\DATA\PubDB.mdf' , 
	SIZE = 5120KB , 
	FILEGROWTH = 1024KB )
LOG ON 
(
	NAME = N'PubDB_log', 
	FILENAME = N'D:\Program Files\Microsoft SQL Server\MSSQL12.MSSQLSERVER\MSSQL\DATA\PubDB_log.ldf' , 
	SIZE = 1024KB , 
	FILEGROWTH = 10%)
GO


--	创建测试表(发布服务器)
USE [PubDB]
GO
CREATE TABLE [dbo].[PubTab](
	[ID] [int] IDENTITY(1,1) NOT NULL,
	[Name] [varchar](20) NOT NULL,
	[Value] [decimal](18, 4) NULL,
	CONSTRAINT [PK_PubTab] PRIMARY KEY CLUSTERED ([id] ASC),
) ON [PRIMARY]
GO

INSERT INTO [dbo].[PubTab]([name],[Value])
VALUES('aa',99),('bb',100)
GO


添加复制用的登录账户和数据库用户。订阅不是同一个实例的添加登录账户(发布服务器/订阅服务器)

--	添加复制用的登录账户和数据库用户。订阅不是同一个实例的添加登录账户(发布服务器/订阅服务器)
USE [master]
GO
CREATE LOGIN [ReplUser] WITH PASSWORD=N'ReplUser', DEFAULT_DATABASE=[master], CHECK_EXPIRATION=OFF, CHECK_POLICY=OFF
GO
ALTER SERVER ROLE [sysadmin] ADD MEMBER [ReplUser]
GO
USE [PubDB]
GO
CREATE USER [ReplUser] FOR LOGIN [ReplUser]
GO

创建发布(发布服务器)














创建完备份后,设置允许从备份文件初始化(发布服务器发布数据库)

--	允许从备份文件初始化(发布服务器发布数据库)
USE [PubDB]
GO
EXEC sp_changepublication
    @publication = N'PublName', 
    @property = N'allow_initialize_from_backup', 
    @value = true
GO

备份数据库(发布服务器)

USE [master]
GO
BACKUP DATABASE [PubDB] 
TO  DISK = N'D:\Program Files\Microsoft SQL Server\MSSQL12.MSSQLSERVER\MSSQL\Backup\PubDB.bak' 
WITH NOFORMAT, NOINIT,  NAME = N'PubDB-完整 数据库 备份', SKIP, NOREWIND, NOUNLOAD,  STATS = 10
GO

还原最新的备份数据库,将作为订阅库(订阅服务器)

USE [master]
GO
RESTORE DATABASE [SubDB] 
FROM  DISK = N'D:\Program Files\Microsoft SQL Server\MSSQL12.MSSQLSERVER\MSSQL\Backup\PubDB.bak' 
WITH  FILE = 1,  
MOVE N'PubDB' TO N'D:\Program Files\Microsoft SQL Server\MSSQL12.MSSQLSERVER\MSSQL\DATA\SubDB.mdf', 
MOVE N'PubDB_log' TO N'D:\Program Files\Microsoft SQL Server\MSSQL12.MSSQLSERVER\MSSQL\DATA\SubDB_log.ldf',  
NOUNLOAD,  STATS = 5
GO

添加订阅,指定备份文件(发布服务器发布数据库)

USE [PubDB]
GO
EXEC sp_addsubscription
@publication = N'PublName',
@subscriber = N'HZC',
@destination_db = N'SubDB',
@subscription_type = N'Push',
@sync_type = N'initialize with backup',
@backupdevicetype='disk',
@backupdevicename='D:\Program Files\Microsoft SQL Server\MSSQL12.MSSQLSERVER\MSSQL\Backup\PubDB.bak'

创建订阅后,更改订阅服务器连接账号




至此,发布订阅据配置完成了,现在看看表中的数据。

SELECT *  FROM [PubDB].[dbo].[PubTab]
SELECT *  FROM [SubDB].[dbo].[PubTab]


增加一行记录再查看,复制正常!

INSERT INTO [PubDB].[dbo].[PubTab]([name],[Value]) VALUES('cc',0)
GO

SELECT *  FROM [PubDB].[dbo].[PubTab]
SELECT *  FROM [SubDB].[dbo].[PubTab]


但是,当添加新表发布时,不能使用快照发布来同步了!~


创建测试表(发布服务器发布数据库),新表 identity 字段需要增加 NOT FOR REPLICATION

--	创建测试表(发布服务器发布数据库)
USE [PubDB]
GO
CREATE TABLE [dbo].[PubTab02](
	[ID] [int] IDENTITY(1,1) NOT FOR REPLICATION NOT NULL,
	[Name] [varchar](20) NOT NULL,
	[Value] [decimal](18, 4) NULL,
	CONSTRAINT [PK_PubTab02] PRIMARY KEY CLUSTERED ([id] ASC),
) ON [PRIMARY]
GO

正常的添加发布(发布服务器发布数据库)



这时不能启用快照同步了,快照没有用。

右键发布的表查看创建表的结构(发布服务器发布数据库),接着到订阅服务器数据库执行。

USE [SubDB]
GO
CREATE TABLE [dbo].[PubTab02](
	[ID] [int] IDENTITY(1,1) NOT FOR REPLICATION NOT NULL,
	[Name] [varchar](20) NOT NULL,
	[Value] [decimal](18, 4) NULL,
 CONSTRAINT [PK_PubTab02] PRIMARY KEY CLUSTERED 
(
	[ID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
GO

好了,添加算是完成了,现在测试添加数据(发布服务器发布数据库)

USE [PubDB]
GO
INSERT INTO [dbo].[PubTab02]([name],[Value]) VALUES('aa',99)
GO

SELECT *  FROM [PubDB].[dbo].[PubTab02]
SELECT *  FROM [SubDB].[dbo].[PubTab02]


若是添加 / 删除 字段,按正常添加 / 删除即可,直接在发布服务器数据库执行,如。

USE [PubDB]
GO
ALTER TABLE [dbo].[PubTab02] ADD InsertDate DATETIME NULL
GO

INSERT INTO [dbo].[PubTab02]([name],[Value],[InsertDate]) VALUES('aa',99,GETDATE())
GO

SELECT *  FROM [PubDB].[dbo].[PubTab02]
SELECT *  FROM [SubDB].[dbo].[PubTab02]


参考:

初始化事务订阅(不使用快照)

SQL Server 通过备份文件初始化复制



优秀的个人博客,低调大师

微信关注我们

原文链接:https://yq.aliyun.com/articles/485457

转载内容版权归作者及来源网站所有!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

相关文章

发表评论

资源下载

更多资源
Mario,低调大师唯一一个Java游戏作品

Mario,低调大师唯一一个Java游戏作品

马里奥是站在游戏界顶峰的超人气多面角色。马里奥靠吃蘑菇成长,特征是大鼻子、头戴帽子、身穿背带裤,还留着胡子。与他的双胞胎兄弟路易基一起,长年担任任天堂的招牌角色。

Oracle Database,又名Oracle RDBMS

Oracle Database,又名Oracle RDBMS

Oracle Database,又名Oracle RDBMS,或简称Oracle。是甲骨文公司的一款关系数据库管理系统。它是在数据库领域一直处于领先地位的产品。可以说Oracle数据库系统是目前世界上流行的关系数据库管理系统,系统可移植性好、使用方便、功能强,适用于各类大、中、小、微机环境。它是一种高效率、可靠性好的、适应高吞吐量的数据库方案。

Apache Tomcat7、8、9(Java Web服务器)

Apache Tomcat7、8、9(Java Web服务器)

Tomcat是Apache 软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache、Sun 和其他一些公司及个人共同开发而成。因为Tomcat 技术先进、性能稳定,而且免费,因而深受Java 爱好者的喜爱并得到了部分软件开发商的认可,成为目前比较流行的Web 应用服务器。

Eclipse(集成开发环境)

Eclipse(集成开发环境)

Eclipse 是一个开放源代码的、基于Java的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。幸运的是,Eclipse 附带了一个标准的插件集,包括Java开发工具(Java Development Kit,JDK)。