Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

How to change the default change_stream_churning_interval? #190

Open
jwo-highnote opened this issue Oct 30, 2024 · 6 comments
Open

How to change the default change_stream_churning_interval? #190

jwo-highnote opened this issue Oct 30, 2024 · 6 comments

Comments

@jwo-highnote
Copy link

jwo-highnote commented Oct 30, 2024

Hi, is there a way to change the default change stream interval to say 1 sec? I would like to build regression test on a CDC module but the default is 20~40 secs which is too long for CI/CD. I saw there is a change_stream_churning_interval arg but not sure how to pass it to the docker image. Can someone provide an example of the docker run command?

@skuruppu
Copy link
Collaborator

skuruppu commented Nov 1, 2024

You're right that we have a flag for that on the C++ side of the code. But it isn't possible to set it when running the Docker image as that runs a Go binary that calls into C++ and the flag also needs to be available in the Go binary.

For example --overrideMaxDatabasesPerInstance is a flag that is defined is Go and is plumbed through to the C++ layer.

I will reach out and see if it's possible to make it configurable through Docker.

@jwo-highnote
Copy link
Author

Thanks for getting back to me! Also, I think if the default is set to a much smaller time (such as 500ms) is likely what most use case for emulator (testing), IMO. Is this something we can change?

@skuruppu
Copy link
Collaborator

skuruppu commented Nov 1, 2024

I will reach out to the team to see if the default can be lowered as you suggested. I'll get back to you as soon as I find out.

@skuruppu
Copy link
Collaborator

skuruppu commented Nov 4, 2024

The team said they chose the 20-40 seconds interval because Emulator is synchronous and will abort and retry any concurrent transactions. A separate thread is used to churn change streams in the background, and this change stream churn transactions will lock the whole database every time they run. So making it too frequent is not recommended (like the 500ms proposed).

Having said that, they said they will look into lowering the default by a few seconds and making it configurable.

We'll keep you posted.

@skuruppu
Copy link
Collaborator

skuruppu commented Nov 5, 2024

Just a quick update that we didn't lower the default but we have a change that will make the value configurable through Docker using an environment variable. The change will be in 1.5.26 release which will go out approximately towards the end of the month. Hope this helps.

@jwo-highnote
Copy link
Author

@skuruppu is there any instruction on how to pass in the parameters? Would like to try the new version as it seems out?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants