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

merge region reach limit while there is no any operator #8452

Open
lhy1024 opened this issue Jul 26, 2024 · 4 comments
Open

merge region reach limit while there is no any operator #8452

lhy1024 opened this issue Jul 26, 2024 · 4 comments

Comments

@lhy1024
Copy link
Contributor

lhy1024 commented Jul 26, 2024

Bug Report

What did you do?

merge empty region

What did you expect to see?

What did you see instead?

there has been no operator check, but it still reaches limit

image

image

What version of PD are you using (pd-server -V)?

@lhy1024 lhy1024 added the type/bug The issue is confirmed as a bug. label Jul 26, 2024
@lhy1024
Copy link
Contributor Author

lhy1024 commented Jul 26, 2024

I am not sure whether it is related to evict-slow-store-scheduler

I try to adjust merge-schedule-limit and remove evict-slow-store-scheduler, it works again.

@LykxSassinator
Copy link
Contributor

LykxSassinator commented Aug 12, 2024

any metrics on TIKV side can be checked and reviewed ?

@lhy1024
Copy link
Contributor Author

lhy1024 commented Aug 28, 2024

It occurs again, there is no any merge operator, but it shows schedulers reach limit until merge-scheduler-limit is set to 512

img_v3_02e6_38502603-0e43-4763-bb40-dc3dc273457g

I guess there maybe a statistic problem with the operator count. There are some retain operators in PD.

@ti-chi-bot ti-chi-bot bot added the affects-8.5 This bug affects the 8.5.x(LTS) versions. label Nov 1, 2024
@lhy1024 lhy1024 self-assigned this Nov 20, 2024
@lhy1024
Copy link
Contributor Author

lhy1024 commented Dec 3, 2024

Image
Image

I try add log, and found operator count is error

if c.mergeChecker != nil {
		allowed := opController.OperatorCount(operator.OpMerge) < c.conf.GetMergeScheduleLimit()
		if !allowed {
			log.Debug("merge check allowed", zap.Int("operators", len(opController.GetOperators())),
				zap.Uint64("count", opController.OperatorCount(operator.OpMerge)), zap.Uint64("limit", c.conf.GetMergeScheduleLimit()))
			operator.IncOperatorLimitCounter(c.mergeChecker.GetType(), operator.OpMerge)
		} else if ops := c.mergeChecker.Check(region); ops != nil {
			// It makes sure that two operators can be added successfully altogether.
			return ops
		}
	}

Image

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Status: Need Triage
Development

No branches or pull requests

3 participants