-
Notifications
You must be signed in to change notification settings - Fork 289
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
dm: add TCP connection IO traffic statistics to sync stage status in OpenAPI response #11742
Conversation
Hi @River2000i. Thanks for your PR. I'm waiting for a pingcap member to verify that this patch is reasonable to test. If it is, they should reply with Once the patch is verified, the new status will be reflected by the I understand the commands that are listed here. Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes/test-infra repository. |
dm/config/subtask.go
Outdated
@@ -182,13 +182,13 @@ type SubTaskConfig struct { | |||
// one go runtime. | |||
// IOTotalBytes is used build TCPConnWithIOCounter and UUID is used to as a | |||
// key to let MySQL driver to find the right TCPConnWithIOCounter. | |||
UUID string `toml:"-" json:"-"` | |||
IOTotalBytes *atomic.Uint64 `toml:"-" json:"-"` | |||
UUID string `toml:"uuid" json:"uuid"` |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I remember toml is used for passing task content, and json is used for logging. We don't need to log them?
Also please add unit tests to ensure atomic types has implemented these marshall functions without race
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I remember toml is used for passing task content, and json is used for logging. We don't need to log them?
Indeed, we don't need to add json tag for both uuid. json tag used for log and openapi response
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Also please add unit tests to ensure atomic types has implemented these marshall functions without race
nice catch! The atomic.Uint64
values can't be properly serialized to TOML format. How about we manually copy atomic
value like:b094cb4
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
since atomic.Uint64
is not support marshall functions for toml like https://github.com/pingcap/tiflow/blob/master/dm/master/scheduler/worker.go#L282
we need to avoid (nil pointer)/(zero value) after covert subtaskconfig
to toml... @lance6716 Any suggestion for that?🤔
/ok-to-test |
/retest |
/retest-required |
|
||
init_dump_data | ||
|
||
# start dump task success | ||
openapi_task_check "start_task_success" $task_name "" | ||
run_dm_ctl_with_retry $WORK_DIR "127.0.0.1:$MASTER_PORT" \ | ||
"query-status $task_name" \ | ||
"\"stage\": \"Running\"" 1 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
in some case, dump task will finished immediately so cannot get the Running
stage. Only validate task finished or not in test_dump_task()
. Need to validate dump data after we support load task.
/retest |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
rest lgtm
max_dump_io_total_bytes=sys.maxsize, | ||
min_io_total_bytes=0, | ||
max_io_total_bytes=sys.maxsize |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The value sys.maxsize, on the other hand, reports the platform's pointer size, and that limits the size of Python's data structures such as strings and lists.
maybe use a more restricted range, such as a few KiB or MiB
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Set max to 100 KiB. In openapi test, all sync task is less than 30KiB.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
what about the minimum? i guess we will at least send some rows for DM to sync. we want to check that the bytes
are in a reasonable range to meter correct
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For sure, for now the minimum is ~3KiB. I think we can set to 2KiB for stable test. And maximum set to 50KiB.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
rest lgtm
/hold please fix existing comments, you can unhold it youself |
/retest |
2 similar comments
/retest |
/retest |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
[APPROVALNOTIFIER] This PR is APPROVED This pull-request has been approved by: D3Hunter, GMHDBJD The full list of commands accepted by this bot can be found here. The pull request process is described here
Needs approval from an approver in each of these files:
Approvers can indicate their approval by writing |
/unhold |
What problem does this PR solve?
Issue Number: close #11741 #11746
What is changed and how it works?
dm/proto/dmworker.proto
and regenerate bymake generate-protobuf
make dm_generate_openapi
Check List
Tests
Questions
Will it cause performance regression or break compatibility?
Do you need to update user documentation, design documentation or monitoring documentation?
Release note