SqlServer Configuring CDC
Note: SqlServer has supported CDC (Change Data Capture) since version 2008, this article is based on SqlServer 2017.
1. Query SqlServer database version
SQL: SELECT @@VERSION
Result.
data:image/s3,"s3://crabby-images/b7eb4/b7eb4bf1ba1f8b8daf35dd2a7bfe38f29f09b197" alt=""
2. Query the current user permissions, must be a member of sysadmin fixed server role to allow the CDC (Change Data Capture) feature to be enabled on the database
SQL: exec sp_helpsrvrolemember 'sysadmin'
Result.
data:image/s3,"s3://crabby-images/7c2c7/7c2c7aaa1a436db385ff3bda8f967cb340716099" alt=""
3. Query whether the database has enabled CDC (Change Data Capture) function
SQL: select is_cdc_enabled, name from sys.databases where name = 'tudou'
Result.
data:image/s3,"s3://crabby-images/b66bf/b66bfcc356ef9988520d4b670c5a0d6c4f730154" alt=""
0: not enabled; 1: enabled
4. Enable CDC (Change Data Capture) for database databases
SQL.
USE
tudou
GO
EXEC sys.sp_cdc_enable_db
GO
Repeat step 3 to make sure the database is enabled for CDC (Change Data Capture).
data:image/s3,"s3://crabby-images/dfc24/dfc244f74e14605308d6bfd7c7936b3445d7f544" alt=""
5. Query whether the table has enabled CDC (Change Data Capture) function
SQL: select name,is_tracked_by_cdc from sys.tables where name = 'test';
Result.
data:image/s3,"s3://crabby-images/7e9be/7e9be8b81699f81ed089e0972b00849bb86f1251" alt=""
6. Enable CDC (Change Data Capture) for tables
SQL.
EXEC sys.sp_cdc_enable_table
@source_schema = 'dbo',
@source_name = 'test',
@role_name = NULL,
@supports_net_changes = 0;
source_schema: the name of the schema where the table is located source_name: the name of the table role_name: the name of the access control role, where null does not set access control supports_net_changes: whether to generate a net change function for the capture instance, 0: no; 1: yes
Repeat step 5 to confirm that the table has CDC (Change Data Capture) enabled.
data:image/s3,"s3://crabby-images/77992/779922058b9d49f508067a75b58c5fe13f3a7a8f" alt=""
At this point, the table test
starts the CDC (Change Data Capture) function configuration is complete.
7. Verify that the CDC agent is started properly
EXEC master.dbo.xp_servicecontrol N'QUERYSTATE', N'SQLSERVERAGENT'
data:image/s3,"s3://crabby-images/e34db/e34db85b5a388eb3e92bb6e14804b59499560ad4" alt=""
data:image/s3,"s3://crabby-images/e34db/e34db85b5a388eb3e92bb6e14804b59499560ad4" alt=""
Windows environment operation to enable CDC agent Click on the following location to enable the agent
data:image/s3,"s3://crabby-images/e15ac/e15ac567e7381cd7cea904c64d76d8b0e72830bc" alt=""
Restart the database
data:image/s3,"s3://crabby-images/c5d0e/c5d0e6755fb370f4994ae00e8de8999e41c159ee" alt=""
Check the agent status again to confirm the status change to running
data:image/s3,"s3://crabby-images/ea26e/ea26eb1b8c597708eb0f4aedef990a7f66efaefd" alt=""
At this point, the table test
starts the CDC (change data capture) function configuration is complete.
docker environment operation to turn on CDC agent
Enable agent service for mssql-server_
docker exec -it sqlserver bash
/opt/mssql/bin/mssql-conf set sqlagent.enabled true
docker stop sqlserver
docker start sqlserver
Reference reading: https://docs.microsoft.com/zh-cn/sql/relational-databases/track-changes/enable-and-disable-change-data-capture-sql-server?view=sql-server-2017