Docker image for testing RDI with Microsoft SQL Server 2022
- Clone the repo locally and cd into directory
rdi-quickstart-sqlserver
-
docker build -t sqlserver sqlserver-image
- Copy file
env.sqlserver
to.env
- Adjust the passwords to your requirements
- Change permissions on directories:
chmod 777 data log
-
docker run --name sqlserver --env-file .env -v $PWD/data:/var/opt/mssql/data -v $PWD/log:/var/opt/mssql/log -p 1433:1433 -d sqlserver
Use a standard database client, such as DBeaver:
data:image/s3,"s3://crabby-images/17c18/17c189bd1d30372b6ffbe9d779402656b06d8e03" alt="image"
- Host =
localhost
(or the FQDN of your machine) - Port =
1433
- Database =
Chinook
- Username =
sa
- Password = <value of
MSSQL_SA_PASSWORD
in file.env
>
You should see 11 tables in schema dbo
of database Chinook
, as well as 11 corresponding tables in schema cdc
:
data:image/s3,"s3://crabby-images/ce525/ce525c4a275faf0c0e5969bdc96bf78aec4821fc" alt="image"
You can also use the command line interface sqlcmd
to execute queries directly in the container, for example:
docker exec -it sqlserver /opt/mssql-tools18/bin/sqlcmd -No -S localhost -U sa -P CompLex#987 -d Chinook -Q "select table_name from information_schema.tables where table_schema='dbo'"
Expected result:
table_name
--------------------------------------------------------------------------------------------------------------------------------
Album
Artist
Customer
Employee
Genre
Invoice
InvoiceLine
MediaType
Playlist
PlaylistTrack
Track
systranschemas
(12 rows affected)
The source
section in file config.yaml
needs to look like this:
sources:
mssql:
type: cdc
logging:
level: info
connection:
type: sqlserver
host: <DB_HOST>
port: 1433
database: Chinook
user: ${SOURCE_DB_USERNAME}
password: ${SOURCE_DB_PASSWORD}
- <DB_HOST> = <FQDN of your machine (or
localhost
when running locally)> - ${SOURCE_DB_USERNAME} = <value of
DBZUSER
in file.env
> - ${SOURCE_DB_PASSWORD} = <value of
DBZUSER_PASSWORD
in file.env
>
Changing the username or password for the Debezium user requires rebuilding the database. Follow these steps:
- Stop and remove the container
- Delete the contents of directory
data
- Start the container