SyncNavigator是一款功能强大的数据库同步软件,适用于SQL SERVER, MySQL,具有自动/定时同步数据、无人值守、故障自动恢复、同构/异构数据库同步、断点续传和增量同步等功能,支持Windows xp以上所有操作系统,适用于大容量数据库快速同步。
安装包下载地址:https://www.syncnavigator.cn/Setup.zip
帮助文档地址:https://www.syncnavigator.cn/Help_zh-CN.chm
Web文档地址:https://www.syncnavigator.cn/chm/index.htm
Sql Server 2012 主从数据库同步(备份机制)
一、准备工作:
注意点:
服务器名称(主机名)最好在确定好后再安装SQL Server 2012数据库这样能确保主机名,实例名保持一致
如果是在安装好sqlserver2008后修改了主机名,通常会导致主机名和实例名不一致问题;
可通过下面的命令进行检测和修复
查看服务名称(默认安装时的实例名也是和主机名一致)和主机名是否一致
select @@servername
select serverproperty('servername')
如果不一致请进行修改:
if serverproperty('servername') <> @@servername
begin
declare @server sysname
set @server = @@servername
exec sp_dropserver @server = @server
set @server = cast(serverproperty('servername') as sysname)
exec sp_addserver @server = @server , @local = 'LOCAL'
End
主数据库服务器:
OS:虚拟机安装了Windows Server 2008 R2 DB: SQL Server 2012,虚拟机推荐使用NAT推荐网络适配
Hostname : CXMasterDB
IP: 192.168.132.128 dg: 192.168.3.1
DNS: 192.168.1.19 DNS: 202.96.209.133
从数据库服务器:
OS: Windows 10 DB: SQL Server 2012
Hostname : CXSlaveDB
IP: 192.168.3.2 dg: 192.168.1.1
DNS: 192.168.1.19 DNS: 202.96.209.133
//主数据库Northwind,如下图所示:
//从CXSlave中,没有数据库Northwind,如下图所示:
二、创建SQL Server数据库的管理员用户和共享文件夹权限,设置SQL Server服务和SQL Server代理的登录用户为sqladmin
1. 在主数据库CXMasterDB服务器上创建用户sqladmin,如下图所示:
win + R ---> lusrmgr.msc回车,如下图所示:
//设置sqladmin的权限
2. 同理,在从数据库CXSlaveDB服务器上创建用户sqladmin且加入administrators组,其他都删除之!
3. 分别在主从数据库服务器上创建用于存放主从备份日志文件的共享文件夹DB_Backpup且共享权限和NTFS权限,如下图所示:
4. 分别从主数据库服务器上和从数据库服务器上打开SQLServer配置管理器,将SQLServer服务和SQLServer代理服务的“登录身份为”sqladmin用户且启动模式为:自动,如下图所示:
三、配置SQLServer日志传送
1. 在主数据库服务器CXMasterDB上配置
//用sqladmin连接到本地SQL Server数据库服务器
//以上用Windows身份验证的时候,如果出现如下图所示:
此时,可以使用Windows身份验证模式登陆。但是无法使用这个账号创建数据库。因此,还需进行以下操作:1、使用SQL Server sa身份验证模式登陆->安全性"->“登陆名”->,查看是否有sqladmin登录名,有就双击之前创建的登陆名打开该登陆名的属性,如下图所示。
2、在“登陆属性”界面->"选择页"->"服务器角色"->选中“puplic”和“sysadmin“->"确定",如下图所示:
3、重新启动,以上解决掉用windows身份验证无法登录情况!
//在数据库实例中,配置 服务器身份验证模式 和 服务器代理帐户
2. 在主数据库CXMasterDB中的Northwind数据库的属性的配置
//在Northwind数据库的属性 --> 选项 的配置
//在Northwind数据库的属性 --> 事务日志传送 的配置
//事务日志备份设置,如下图所示:
//在上图中,点击 计划… 后,弹出如下图所示:
一路“ 确定” !见到下图为止!
//添加 辅助数据库实例和数据库
//连接到 辅助服务器实例和辅助数据库,如果网络服务器没有查找到辅助服务器,可以直接输入辅助服务器的名称或者IP地址也可以链接上
//辅助数据库设置--->初始化辅助数据库,如果网络服务器找不到从机Server,可以直接输入从服务器的Ip:192.168.3.2,或者名称
注:
下面查看看,辅助服务器CXSlaveDB中数据库的 数据文件和日志文件 的文件夹的路径
//辅助数据库设置--->复制文件
//在上图中 击点 计划(E) … 则弹出如下图所示,设置从数据库还原日志的计划任务:
////辅助数据库设置--->还原事务日志
//在上图中 击点 计划(E) … 则弹出如下图所示,设置从数据库还原日志的计划任务:
//将配置信息导出到文件
//在下图中点击 确定 后,一目了然了!
三、验证SQL Server 2008 R2主从数据库是否同步
1. 我们去从服务器CXSlaveDB看看是否有Northwind数据库,由下图所示,可见成功了!
2. 现在我们去主数据库服务器CXMasterDB中Northwind数据库添加如下图所示的表:
//创建表名为 雇员通讯录
//刷新下,就可见到 dbo.雇员通讯录 ,如下图所示:
3. 现在我们去从数据库服务器CXSlaveDB的Northwind数据库是否有表dbo.雇员通讯录,如下图所示:
思考:
下面我们到主数据库服务器CXMasterDB的Northwind数据库中,删除表dbo.雇员通讯录
看看从数据库CXSlaveDB的Northwind数据库中的表dbo.雇员通讯录,是否也被删除了?
附:
1. 如何删除Northwind(备用 / 只读)数据库
//在数据库属性 –-> 选项 ---> 状态 --->数据库为只读 修改为 False即可!能删除吗???