Skip to main content

SqlServer配置CDC

注:SqlServer自2008版本开始支持CDC(变更数据捕获)功能,本文基于SqlServer 2017编写。

1、查询SqlServer数据库版本

SQL:SELECT @@VERSION 结果:

2、查询当前用户权限,必须为 sysadmin 固定服务器角色的成员才允许对数据库启用CDC(变更数据捕获)功能

SQL:exec sp_helpsrvrolemember 'sysadmin' 结果:

3、查询数据库是否已经启用CDC(变更数据捕获)功能

SQL:select is_cdc_enabled, name from sys.databases where name = 'tudou' 结果:


0:未启用;1:启用

4、对数据库数据库启用CDC(变更数据捕获)功能

SQL:

USE
tudou
GO
EXEC sys.sp_cdc_enable_db
GO

重复第三步操作,确认数据库已经启用CDC(变更数据捕获)功能。

5、查询表是否已经启用CDC(变更数据捕获)功能

SQL:select name,is_tracked_by_cdc from sys.tables where name = 'test'; 结果:

0:未启用;1:启用

6、对表启用CDC(变更数据捕获)功能    

SQL:

EXEC sys.sp_cdc_enable_table 
@source_schema = 'dbo',
@source_name = 'test',
@role_name = NULL,
@supports_net_changes = 0;

source_schema:表所在的schema名称 source_name:表名 role_name:访问控制角色名称,此处为null不设置访问控制 supports_net_changes:是否为捕获实例生成一个净更改函数,0:否;1:是

重复第五步操作,确认表已经启用CDC(变更数据捕获)功能。

至此,表test启动CDC(变更数据捕获)功能配置完成。

7、确认CDC agent 是否正常启动

EXEC master.dbo.xp_servicecontrol N'QUERYSTATE', N'SQLSERVERAGENT'
如显示上图状态,需要启动对应的agent.

Windows 环境操作开启 CDC agent 点击 下图位置代理开启

重新启动数据库

再次查询agent 状态,确认状态变更为running

至此,表test启动CDC(变更数据捕获)功能配置完成。

docker 环境操作开启 CDC agent

开启mssql-server的代理服务_

docker exec -it sqlserver bash
/opt/mssql/bin/mssql-conf set sqlagent.enabled true
docker stop sqlserver
docker start sqlserver

参考阅读:https://docs.microsoft.com/zh-cn/sql/relational-databases/track-changes/enable-and-disable-change-data-capture-sql-server?view=sql-server-2017