SQLServer权限配置
CDC(Change Data Capture),即数据变更抓取,通过为源端数据源开启CDC,作业可实现数据源的实时数据同步。 本章节主要介绍如何为SQLServer数据库开启CDC功能。
前提条件
SqlServer自2008版本开始支持CDC(变更数据捕获)功能,本文基于SqlServer 2017编写。
操作步骤
建议由数据库管理员对数据源配置进行操作
以下配置在windows 环境进行说明
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 = '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'
如显示上图状态,需要启动对应的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
参考阅读:启用和禁用“更改数据捕获”