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';
结果:

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'

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