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

ddl puller(ticdc): Fix a potential OOM in ddlPullerImpl's PopFrontDDL method #11794

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

wlwilliamx
Copy link
Contributor

What problem does this PR solve?

Issue Number: close #11793

What is changed and how it works?

Problem

In the PopFrontDDL method of ddlPullerImpl, the operation h.pendingDDLJobs = h.pendingDDLJobs[1:] creates a new slice by slicing the existing one. However, this leaves the first element (pendingDDLJobs[0]) still referenced in the underlying array, potentially causing memory retention issues.

If the removed element (a Job object) occupies significant memory and is no longer needed, this could lead to increased memory usage since it cannot be garbage collected.

Solution

The fix ensures that the reference to the removed element is explicitly set to nil before updating the slice. This helps the garbage collector to reclaim memory associated with the removed element.

Code Changes
  • Explicitly set h.pendingDDLJobs[0] = nil before updating the slice in PopFrontDDL.

Updated code snippet:

func (h *ddlPullerImpl) PopFrontDDL() (uint64, *timodel.Job) {
    h.mu.Lock()
    defer h.mu.Unlock()
    if len(h.pendingDDLJobs) == 0 {
        return atomic.LoadUint64(&h.resolvedTS), nil
    }
    job := h.pendingDDLJobs[0]
    h.pendingDDLJobs[0] = nil // Explicitly clear reference to allow GC
    h.pendingDDLJobs = h.pendingDDLJobs[1:]
    return job.BinlogInfo.FinishedTS, job
}

Check List

Tests

  • Unit test
  • Integration test

Questions

Will it cause performance regression or break compatibility?

No.

Do you need to update user documentation, design documentation or monitoring documentation?

No.

Release note

Fix a memory retention issue in TiCDC’s DDL job processing to enhance memory efficiency in long-running tasks.

@ti-chi-bot ti-chi-bot bot added release-note Denotes a PR that will be considered when it comes time to generate release notes. do-not-merge/needs-triage-completed labels Nov 25, 2024
Copy link
Contributor

ti-chi-bot bot commented Nov 25, 2024

[APPROVALNOTIFIER] This PR is NOT APPROVED

This pull-request has been approved by:
Once this PR has been reviewed and has the lgtm label, please assign gmhdbjd for approval. For more information see the Code Review Process.

The full list of commands accepted by this bot can be found here.

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@ti-chi-bot ti-chi-bot bot added the size/XS Denotes a PR that changes 0-9 lines, ignoring generated files. label Nov 25, 2024
@wlwilliamx
Copy link
Contributor Author

/test cdc-integration-kafka-test

1 similar comment
@wlwilliamx
Copy link
Contributor Author

/test cdc-integration-kafka-test

@wlwilliamx
Copy link
Contributor Author

/test cdc-integration-pulsar-test

@wlwilliamx
Copy link
Contributor Author

CC @CharlesCheung96 @asddongmen

@wlwilliamx
Copy link
Contributor Author

/cc @CharlesCheung96 @asddongmen

@wlwilliamx wlwilliamx changed the title ddl puller(ticdc): Fix memory retention issue in ddlPullerImpl's PopFrontDDL method ddl puller(ticdc): Fix a potential OOM in ddlPullerImpl's PopFrontDDL method Dec 15, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
release-note Denotes a PR that will be considered when it comes time to generate release notes. size/XS Denotes a PR that changes 0-9 lines, ignoring generated files.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Potential OOM in PopFrontDDL Method of ddlPullerImpl
1 participant