CDC(Change Data Capture),即数据变更抓取,通过为源端数据源开启CDC,作业可实现数据源的实时数据同步。 本章节主要介绍如何为SQLServer数据库开启CDC功能。

前提条件


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

操作步骤


建议由数据库管理员对数据源配置进行操作

以下配置在windows 环境进行说明

1、查询SqlServer数据库版本

SQL:SELECT @@VERSION
结果:
SQLServer权限配置 - 图1

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

SQL:exec sp_helpsrvrolemember 'sysadmin'
结果:
SQLServer权限配置 - 图2

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

SQL:select is_cdc_enabled, name from sys.databases where name = 'CDC_DB '

0:未启用;1:启用

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

USE  CDC_DB
GO  
EXEC sys.sp_cdc_enable_db  
GO

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

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

select name,is_tracked_by_cdc from sys.tables where name = 'test';
0:未启用;1:启用

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

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'

SQLServer权限配置 - 图3
如显示上图状态,需要启动对应的agent.

Windows 环境操作开启 CDC agent
单击 下图位置代理开启
SQLServer权限配置 - 图4

重新启动数据库
SQLServer权限配置 - 图5

再次查询agent 状态,确认状态变更为running
SQLServer权限配置 - 图6

至此,表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

参考阅读:启用和禁用“更改数据捕获”