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

copr: add projection #10689

Merged
merged 6 commits into from
Mar 8, 2022
Merged

Conversation

ichn-hu
Copy link
Contributor

@ichn-hu ichn-hu commented Aug 9, 2021

What problem does this PR solve?

Issue Number: close #12114

Problem Summary:

What is changed and how it works?

PR on TiDB: pingcap/tidb#27029
Intergration test on copr-test: tikv/copr-test#145

What's Changed:

Related changes

  • N/A

Check List

Tests

  • Unit test

Side effects

  • N/A

Release note

Support projection on coprocessor

@ti-chi-bot
Copy link
Member

ti-chi-bot commented Aug 9, 2021

[REVIEW NOTIFICATION]

This pull request has been approved by:

  • Xuanwo
  • skyzh

To complete the pull request process, please ask the reviewers in the list to review by filling /cc @reviewer in the comment.
After your PR has acquired the required number of LGTMs, you can assign this pull request to the committer in the list by filling /assign @committer in the comment to help you merge this pull request.

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

Reviewer can indicate their review by submitting an approval review.
Reviewer can cancel approval by submitting a request changes review.

@ti-chi-bot ti-chi-bot added do-not-merge/work-in-progress Indicates that a PR should not merge because it is a work in progress. release-note Denotes a PR that will be considered when it comes time to generate release notes. contribution This PR is from a community contributor. size/XXL Denotes a PR that changes 1000+ lines, ignoring generated files. labels Aug 9, 2021
@ichn-hu ichn-hu force-pushed the add-projection-pushdown branch from 0393abc to 9a766b1 Compare August 11, 2021 10:01
@ichn-hu ichn-hu marked this pull request as ready for review August 11, 2021 10:13
@ti-chi-bot ti-chi-bot removed the do-not-merge/work-in-progress Indicates that a PR should not merge because it is a work in progress. label Aug 11, 2021
@ichn-hu ichn-hu force-pushed the add-projection-pushdown branch from 443533d to ec21275 Compare August 11, 2021 10:20
@ichn-hu
Copy link
Contributor Author

ichn-hu commented Aug 12, 2021

/cc @skyzh @Xuanwo

@ti-chi-bot ti-chi-bot requested review from skyzh and Xuanwo August 12, 2021 03:52
@Xuanwo
Copy link
Member

Xuanwo commented Aug 12, 2021

Hello, are there any design docs/proposals for these changes?

  • What's projection?
  • How to test it?
  • Have we added integration tests for it?

@skyzh
Copy link
Member

skyzh commented Aug 12, 2021

Is this finalized version of projection executor? I saw a lot of println! inside, which is not expected in production code.

Copy link
Member

@skyzh skyzh left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This PR looks good on the TiKV side currently, and I'll take more time to review the executor part when the code is finalized. By the way, do we have the corresponding PR on TiDB side, and do we have integration tests?

@ichn-hu
Copy link
Contributor Author

ichn-hu commented Aug 12, 2021

Hello, are there any design docs/proposals for these changes?

  • What's projection?
  • How to test it?
  • Have we added integration tests for it?

The design doc is currently internal, but it's just few words, I'll polish it a little bit and open to the community.

However, I can give short answers to your questions.

  1. see wikipedia and tidb's implemetation, it is basically calculate some expressions on each row, and replace the row with the calculation results, therefore it can eliminate some unwanted columns, add column as the result of functions on some existing columns.
  2. and 3. unit tests are included in this PR, intergration tests will be reflected on tests on PRs on TiDB's side and copr-test later.

@ichn-hu
Copy link
Contributor Author

ichn-hu commented Aug 12, 2021

This PR looks good on the TiKV side currently, and I'll take more time to review the executor part when the code is finalized. By the way, do we have the corresponding PR on TiDB side, and do we have integration tests?

corresponding PR on TiDB side: pingcap/tidb#27029

intergration tests will be in copr-test later.

@ichn-hu ichn-hu force-pushed the add-projection-pushdown branch from ec21275 to 8f3140b Compare August 13, 2021 07:52
@skyzh
Copy link
Member

skyzh commented Aug 16, 2021

Please ping me when this PR is ready. By the way, would you please make this PR pass test?

@Xuanwo
Copy link
Member

Xuanwo commented Aug 17, 2021

Please ping me when this PR is ready. By the way, would you please make this PR pass test?

Same here. ping me back while ready.

@ichn-hu
Copy link
Contributor Author

ichn-hu commented Aug 19, 2021

@Xuanwo @skyzh good to go~

Copy link
Member

@skyzh skyzh left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Rest LGTM.

@ichn-hu ichn-hu force-pushed the add-projection-pushdown branch 2 times, most recently from 1addf34 to 596f152 Compare August 24, 2021 09:51
@skyzh
Copy link
Member

skyzh commented Aug 24, 2021

/test

@skyzh
Copy link
Member

skyzh commented Aug 25, 2021

/test

Copy link
Member

@Xuanwo Xuanwo left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@ti-chi-bot ti-chi-bot added the status/LGT1 Indicates that a PR has LGTM 1. label Aug 25, 2021
@ichn-hu ichn-hu force-pushed the add-projection-pushdown branch from 596f152 to cb63c01 Compare February 17, 2022 08:42
add

use fn

fix clippy

pass empty check

update

add tests

use macro

Signed-off-by: ichn-hu <[email protected]>

Update components/tidb_query_executors/src/projection_executor.rs

Co-authored-by: Alex Chi <[email protected]>

address comment

Signed-off-by: ichn-hu <[email protected]>
@ichn-hu ichn-hu force-pushed the add-projection-pushdown branch from cb63c01 to dfaf95d Compare March 3, 2022 07:45
@ichn-hu
Copy link
Contributor Author

ichn-hu commented Mar 4, 2022

@skyzh PTAL again, sorry for the late update.

Copy link
Member

@skyzh skyzh left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM. Would you please update the PR body?

@ti-chi-bot ti-chi-bot added status/LGT2 Indicates that a PR has LGTM 2. and removed status/LGT1 Indicates that a PR has LGTM 1. labels Mar 7, 2022
@ichn-hu
Copy link
Contributor Author

ichn-hu commented Mar 7, 2022

/merge

@ti-chi-bot
Copy link
Member

@ichn-hu: It seems you want to merge this PR, I will help you trigger all the tests:

/run-all-tests

You only need to trigger /merge once, and if the CI test fails, you just re-trigger the test that failed and the bot will merge the PR for you after the CI passes.

If you have any questions about the PR merge process, please refer to pr process.

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 ti-community-infra/tichi repository.

@ti-chi-bot
Copy link
Member

@ichn-hu: /merge is only allowed for the committers, you can assign this pull request to the committer in list by filling /assign @committer in the comment to help merge this pull request.

In response to this:

/merge

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 ti-community-infra/tichi repository.

@skyzh
Copy link
Member

skyzh commented Mar 7, 2022

/merge

@ti-chi-bot
Copy link
Member

@skyzh: It seems you want to merge this PR, I will help you trigger all the tests:

/run-all-tests

You only need to trigger /merge once, and if the CI test fails, you just re-trigger the test that failed and the bot will merge the PR for you after the CI passes.

If you have any questions about the PR merge process, please refer to pr process.

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 ti-community-infra/tichi repository.

@ti-chi-bot
Copy link
Member

This pull request has been accepted and is ready to merge.

Commit hash: dfaf95d

@ti-chi-bot ti-chi-bot added the status/can-merge Indicates a PR has been approved by a committer. label Mar 7, 2022
@ti-chi-bot
Copy link
Member

@ichn-hu: Your PR was out of date, I have automatically updated it for you.

At the same time I will also trigger all tests for you:

/run-all-tests

If the CI test fails, you just re-trigger the test that failed and the bot will merge the PR for you after the CI passes.

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 ti-community-infra/tichi repository.

@ichn-hu
Copy link
Contributor Author

ichn-hu commented Mar 8, 2022

/run-test

@ti-chi-bot ti-chi-bot merged commit 22fcf70 into tikv:master Mar 8, 2022
CalvinNeo added a commit to pingcap/tidb-engine-ext that referenced this pull request May 30, 2022
* storage: Add API V2 check for RawKV and TxnKV requests (txn part) (#11216)

* wip

Signed-off-by: pingyu <[email protected]>

* wip

Signed-off-by: pingyu <[email protected]>

* ref #10974: Add API V2 check for RawKV and TxnKV requests (txn)

Signed-off-by: pingyu <[email protected]>

* ref #10974: Add API V2 check for RawKV and TxnKV requests (txn)

Signed-off-by: pingyu <[email protected]>

* ref #10974: Add API V2 check for RawKV and TxnKV requests (txn)

Signed-off-by: pingyu <[email protected]>

* ref #10974: Add API V2 check for RawKV and TxnKV requests (txn)

Signed-off-by: pingyu <[email protected]>

* ref #10974: Add API V2 check for RawKV and TxnKV requests (txn)

Signed-off-by: pingyu <[email protected]>

* ref #10974: Add API V2 check for RawKV and TxnKV requests (txn)

Signed-off-by: pingyu <[email protected]>

* fix enable_ttl

Signed-off-by: andylokandy <[email protected]>

* simplify test

Signed-off-by: andylokandy <[email protected]>

* ref #10974: Add API V2 check for RawKV and TxnKV requests (txn)

Signed-off-by: pingyu <[email protected]>

Co-authored-by: andylokandy <[email protected]>
Co-authored-by: Ti Chi Robot <[email protected]>

* cdc: load uninlined value more effectively (#11615)

Signed-off-by: qupeng <[email protected]>

* cdc: load old value with prefix seek if possible (#11643)

* close #11642

Signed-off-by: qupeng <[email protected]>

* a more comment

Signed-off-by: qupeng <[email protected]>

* ctl: split into multiple modules (#11658)

* ctl: split into multiple modules

ref #10938

Signed-off-by: andylokandy <[email protected]>

* refactor if let to match

Signed-off-by: andylokandy <[email protected]>

* address comment

Signed-off-by: andylokandy <[email protected]>

* address comment

Signed-off-by: andylokandy <[email protected]>

* address comment

Signed-off-by: andylokandy <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* Fix build issues on non-linux platforms (#11671)

* close #11676

Signed-off-by: devillove084 <[email protected]>

* all: Migrate from std:: types to primitives. (#11677)

* Deprecation is planned for MIN,MAX,EPSLION,INFINITY,NEG_INFINITY of
  the (i|u|f)(8|16|32|64) types in standard.

ref #11678

```release-note
NONE
```

Signed-off-by: Harold Dost <[email protected]>

* metrics alert: fix apply cpu alert (#11672)

Signed-off-by: zhangjinpeng1987 <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* resrc_mtr: introduce scanned keys statistics (#11085)

close #11690

Signed-off-by: mornyx <[email protected]>

* file_system: support collect the io flow by proc (#11667)

* file_system: support collect the read flow by proc

Signed-off-by: MuZhou233 <[email protected]>

* fix lint

Signed-off-by: MuZhou233 <[email protected]>

* fix clippy

Signed-off-by: MuZhou233 <[email protected]>

* Delete unused content & Adjust copyright text

Signed-off-by: MuZhou233 <[email protected]>

* Add bench_fetch_io_bytes

Signed-off-by: MuZhou233 <[email protected]>

* fix lint

Signed-off-by: MuZhou233 <[email protected]>

* Integrate thread_io

Signed-off-by: MuZhou233 <[email protected]>

* record bytes in request

Signed-off-by: MuZhou233 <[email protected]>

* fix logical bug

Signed-off-by: MuZhou233 <[email protected]>

* Update test write_bytes

Signed-off-by: MuZhou233 <[email protected]>

* Delete unused & Rename func

Signed-off-by: MuZhou233 <[email protected]>

* Add test for read & Update test for write

Signed-off-by: MuZhou233 <[email protected]>

* Add buffered thread io

Signed-off-by: MuZhou233 <[email protected]>

* Replace DashMap with ThreadLocal

Signed-off-by: MuZhou233 <[email protected]>

* Rename variables and function & Remove unused call

Signed-off-by: MuZhou233 <[email protected]>

* Change fetch logic. close #10867

Signed-off-by: MuZhou233 <[email protected]>

* Add AtomicIOBytes

Signed-off-by: MuZhou233 <[email protected]>

* Split ThreadIOSentinel

Signed-off-by: MuZhou233 <[email protected]>

* add THREAD_IO_TOTAL for metrics bytes fetcher

Signed-off-by: MuZhou233 <[email protected]>

* Adjust code style & fix

Signed-off-by: MuZhou233 <[email protected]>

* improve write_bytes test

Signed-off-by: MuZhou233 <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* *: check epoch and validness of lock table when writing pessimistic locks (#11591)

ref #11452

Signed-off-by: Yilin Chen <[email protected]>

* rsmeter: introduce datasink (#11688)

* add datasink trait

Signed-off-by: Zhenchi <[email protected]>

* RAII removes on_reporter_closing

Signed-off-by: Zhenchi <[email protected]>

* fmt

Signed-off-by: Zhenchi <[email protected]>

* fix build

ref #11691

Signed-off-by: Zhenchi <[email protected]>

* datasink -> data_sink

Signed-off-by: Zhenchi <[email protected]>

* fmt

Signed-off-by: Zhenchi <[email protected]>

* fix build

Signed-off-by: Zhenchi <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* clippy: Fixing up clippy errors. (#11193)

* clippy: Fixing up clippy errors.

* Fix crate references
* Fix anonymous lifetimes references.

ref #4301
Signed-off-by: Harold Dost <[email protected]>

* Test Revert of Iterations

ref #4301

Signed-off-by: Harold Dost <[email protected]>

* clippy: Enable check for rust-2018-idioms

ref #4301

Signed-off-by: Harold Dost <[email protected]>

* rsmeter: add centralized place to construct protobuf data (#11696)

ref #11691

Signed-off-by: Zhenchi <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* tikv_util: update procfs to 0.12.0 (#11703)

Signed-off-by: linning <[email protected]>

* Use generic for api version to reduce runtime branching (#11687)

* Use generic for api version to reduce runtime branching

ref #10938

Signed-off-by: andylokandy <[email protected]>

* fix test

Signed-off-by: andylokandy <[email protected]>

* add test

Signed-off-by: andylokandy <[email protected]>

* fix clippy

Signed-off-by: andylokandy <[email protected]>

* address comment

Signed-off-by: andylokandy <[email protected]>

* fmt

Signed-off-by: andylokandy <[email protected]>

* address comment

Signed-off-by: andylokandy <[email protected]>

* address comment

Signed-off-by: andylokandy <[email protected]>

* rename vars

Signed-off-by: andylokandy <[email protected]>

* improve vars

Signed-off-by: andylokandy <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* sst_importer: check api version when importing (#11664)

* sst_importer: check api version when importing

ref #10938

Signed-off-by: Peng Guanwen <[email protected]>

* Fix bugs

Signed-off-by: Peng Guanwen <[email protected]>

* fix bug of Iterator::{scan,scan_cf}

Signed-off-by: Peng Guanwen <[email protected]>

* remove redundant log

Signed-off-by: Peng Guanwen <[email protected]>

* Show the entire key

Signed-off-by: Peng Guanwen <[email protected]>

* Fix lint issue

Signed-off-by: Peng Guanwen <[email protected]>

* resolve conflict

Signed-off-by: andylokandy <[email protected]>

Co-authored-by: Andy Lok <[email protected]>

* backup: pipeline scan and save step (#11528)

* br: sperate io and scan threads

Signed-off-by: Yu Juncen <[email protected]>

* br/stream: make clippy happy

Signed-off-by: yujuncen <[email protected]>

* br/stream: fix tests

Signed-off-by: Yu Juncen <[email protected]>

* backup: fix a dummy bug

Signed-off-by: Yu Juncen <[email protected]>

* backup: add config of io-threads

Signed-off-by: yujuncen <[email protected]>

* backup: ref #11350: some minior change

Signed-off-by: yujuncen <[email protected]>

* backup: added some metrics

Signed-off-by: yujuncen <[email protected]>

* backup: better tuning concurrency, and added a metric

Signed-off-by: yujuncen <[email protected]>

* backup: added some slow log and metrics

Signed-off-by: yujuncen <[email protected]>

* backup: address comments

Signed-off-by: yujuncen <[email protected]>

* backup: fix build

Signed-off-by: yujuncen <[email protected]>

* Revert "backup: fix build"

This reverts commit 74537be56c410d0f91af2f48b7e65356ab53720e.

Signed-off-by: yujuncen <[email protected]>

* Revert "backup: address comments"

This reverts commit 77d75756028bea3496f878f0ad8bbc562f5d00aa.

Signed-off-by: yujuncen <[email protected]>

* backup: address comments

Signed-off-by: yujuncen <[email protected]>

* backup: always set IO type to Export

Signed-off-by: yujuncen <[email protected]>

* backup:make clippy happy

Signed-off-by: yujuncen <[email protected]>

* backup: address comments

Signed-off-by: yujuncen <[email protected]>

* metrics: fix the metrics cannot be displayed (#11710)

ref #11662

Signed-off-by: Ryan Leung <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* backup: return api-version to BR when backup (#11704)

* Update kvproto

Signed-off-by: Peng Guanwen <[email protected]>

* Return api-version for br

ref #10938

Signed-off-by: Peng Guanwen <[email protected]>

* Reformat code

Signed-off-by: Peng Guanwen <[email protected]>

* Update components/external_storage/export/src/export.rs

Signed-off-by: Peng Guanwen <[email protected]>

Co-authored-by: Andy Lok <[email protected]>

* format code

Signed-off-by: Peng Guanwen <[email protected]>

Co-authored-by: Andy Lok <[email protected]>

* file_system: limit thread_io target os (#11715)

* limit thread_io target os

Signed-off-by: MuZhou233 <[email protected]>

* limit thread_io target os. typo. close #11698

Signed-off-by: MuZhou233 <[email protected]>

Co-authored-by: Yilin Chen <[email protected]>

* file_system: bypass file allocate implementation in fs2 (#11700)

Close #10688

Patch fs2 to https://github.com/tabokie/fs2-rs/tree/tikv. In which, `posix_fallocate` is replaced with `fallocate` (https://github.com/danburkert/fs2-rs/pull/42).

* bypass file allocate implementation in fs2

Signed-off-by: tabokie <[email protected]>

* metrics: remove min legend of some Grafana panels (#11487)

Minimum legend isn't very useful, and it occupied valuable visual real estate.

Remove some min legends from Grafana metrics, except for the following:
- Level 0 chance
- Number files at each level
- File Count
- Entry Count
- Allocator Stats
- Encrypted files
- Encryption meta files size

Ref #11119

Signed-off-by: tabokie <[email protected]>

* coprocessor: not return rows when there is no input for simple aggregation (#11708)

* not return rows when there is no input for simple aggregation

Signed-off-by: xufei <[email protected]>

* close #11735, and address comments

Signed-off-by: xufei <[email protected]>

* backup: reduce the default thread pool size of backup, enable auto tune by default (#11699)

* backup: clamp auto tune values

Signed-off-by: yujuncen <[email protected]>

* ref #11000: change the default backup threads.

Signed-off-by: yujuncen <[email protected]>

* backup: run tasks in background

Signed-off-by: yujuncen <[email protected]>

* backup: run rustfmt

Signed-off-by: yujuncen <[email protected]>

* backup: set remain threads to 20% of vcpu

Signed-off-by: yujuncen <[email protected]>

* br-stream: fix build

Signed-off-by: yujuncen <[email protected]>

* Backup: add S3 metrics && add s3_multi_part_size config  (#11666)

* s3: add request metrics for s3 storage

Signed-off-by: 3pointer <[email protected]>

* s3: add grafana json

Signed-off-by: 3pointer <[email protected]>

* br: add config for s3 multi part upload

Signed-off-by: 3pointer <[email protected]>

* update comment

Signed-off-by: 3pointer <[email protected]>

* update comment

Signed-off-by: 3pointer <[email protected]>

* address comment

Signed-off-by: 3pointer <[email protected]>

* hidden the new config

Signed-off-by: 3pointer <[email protected]>

* only hidden config in config-template.toml

Signed-off-by: 3pointer <[email protected]>

* address comment

Signed-off-by: 3pointer <[email protected]>

* close #11727 && format

Signed-off-by: 3pointer <[email protected]>

* fix

Signed-off-by: 3pointer <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* rsmeter: support multiple datasinks (#11707)

* rsmeter: support multiple datasinks

Signed-off-by: Zhenchi <[email protected]>

* wrap config notifier

Signed-off-by: Zhenchi <[email protected]>

* add unit tests

Signed-off-by: Zhenchi <[email protected]>

* polish
ref #11691

Signed-off-by: Zhenchi <[email protected]>

* address comments

Signed-off-by: Zhenchi <[email protected]>

* fix test

Signed-off-by: Zhenchi <[email protected]>

* fix outdated comments

Signed-off-by: Zhenchi <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* engine: properly estimate store size (#11728)

* properly estimate store size, ref #11119

Signed-off-by: tabokie <[email protected]>

* address comments

Signed-off-by: tabokie <[email protected]>

* implement global config client for tikv (#11685)

* implement global config client

close #11686

Signed-off-by: lemonhx <[email protected]>

* implement unit test for global config in pd client

Signed-off-by: lemonhx <[email protected]>

* resolved formatting issues

Signed-off-by: lemonhx <[email protected]>

* impl pd client asyncly

Signed-off-by: lemonhx <[email protected]>

* according to reviewer's opinion
removing store method implementation

Signed-off-by: lemonhx <[email protected]>

* Merge branch 'master' of https://github.com/tikv/tikv into global_conf

Signed-off-by: lemonhx <[email protected]>

* write test case for watch global config when
grpc server is closed.

Signed-off-by: lemonhx <[email protected]>

* resove issues

Signed-off-by: lemonhx <[email protected]>

* clippy

Signed-off-by: lemonhx <[email protected]>

* watch global config rentry future in test deadlock just removed

Signed-off-by: lemonhx <[email protected]>

Co-authored-by: Zhenchi <[email protected]>

* storage: skip scanning lock when using rc (#11701)

* skip scanning lock when using rc, ref #11485

Signed-off-by: you06 <[email protected]>

* format code

Signed-off-by: you06 <[email protected]>

* add test

Signed-off-by: you06 <[email protected]>

* address comment

Signed-off-by: you06 <[email protected]>

* add an integration test

Signed-off-by: you06 <[email protected]>

* format code

Signed-off-by: you06 <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* copr: pushdown substring to tikv (#11494)

* corp: pushdown substring to tikv

Signed-off-by: guo-shaoge <[email protected]>

* fix case. close #11495

Signed-off-by: guo-shaoge <[email protected]>

* fix comment

Signed-off-by: guo-shaoge <[email protected]>

* rsmeter: distinguish between collectors and observers within recorder  (#11712)

* rsmeter: support multiple datasinks

Signed-off-by: Zhenchi <[email protected]>

* wrap config notifier

Signed-off-by: Zhenchi <[email protected]>

* add unit tests

Signed-off-by: Zhenchi <[email protected]>

* polish
ref #11691

Signed-off-by: Zhenchi <[email protected]>

* rsmeter: distinguish between collectors and observers within recorder

Signed-off-by: Zhenchi <[email protected]>

* fmt & try to resolve #11689

Signed-off-by: Zhenchi <[email protected]>

* add unit tests
ref #11691

Signed-off-by: Zhenchi <[email protected]>

* retrigger test

Signed-off-by: Zhenchi <[email protected]>

* address comments

Signed-off-by: Zhenchi <[email protected]>

* fix test

Signed-off-by: Zhenchi <[email protected]>

* fix outdated comments

Signed-off-by: Zhenchi <[email protected]>

* Update components/resource_metering/src/recorder/sub_recorder/mod.rs

Signed-off-by: Zhenchi <[email protected]>

Co-authored-by: Yexiang Zhang <[email protected]>

* address comment

Signed-off-by: Zhenchi <[email protected]>

* remove enabled

Signed-off-by: Zhenchi <[email protected]>

* fix

Signed-off-by: Zhenchi <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>
Co-authored-by: Wenxuan <[email protected]>
Co-authored-by: Yexiang Zhang <[email protected]>

* config: validate online configurable thread pools (tikv#11159) (#11714)

ref #11159

Signed-off-by: Wenbo Zhang <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* res_meter: upgrade kvproto (#11749)

* Upgrade kvproto

close #11748

Signed-off-by: mornyx <[email protected]>

* Fix test compilation

Signed-off-by: mornyx <[email protected]>

* Fix test compilation

Signed-off-by: mornyx <[email protected]>

* Fix test compilation

Signed-off-by: mornyx <[email protected]>

* Use master kvproto

Signed-off-by: mornyx <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* rsmeter: add pubsub datasink  (#11719)

* rsmeter: add pubsub datasink
close #11691

Signed-off-by: Zhenchi <[email protected]>

* fix build

Signed-off-by: Zhenchi <[email protected]>

* Update components/resource_metering/src/reporter/pubsub.rs

Signed-off-by: Zhenchi <[email protected]>

Co-authored-by: Wenxuan <[email protected]>

* fix build

Signed-off-by: Zhenchi <[email protected]>

Co-authored-by: Wenxuan <[email protected]>

* status_server: Support online config update for configuration hosting platform (#11693)

close #11692

Signed-off-by: Wenbo Zhang <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* res_meter: optimize top k (#11753)

* Keep top k on recorder

Signed-off-by: mornyx <[email protected]>

* Modify comments

Signed-off-by: mornyx <[email protected]>

* Fix pd.rs

Signed-off-by: mornyx <[email protected]>

* Refactor

Signed-off-by: mornyx <[email protected]>

* Remove import

Signed-off-by: mornyx <[email protected]>

* max_resource_groups 200 -> 100

Signed-off-by: mornyx <[email protected]>

* Fix ut

Signed-off-by: mornyx <[email protected]>

* Use iterator to avoid clone

Signed-off-by: mornyx <[email protected]>

* Optimize

close #11754

Signed-off-by: mornyx <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* raftclient: delay flush (#11705)

* raftclient: delay flush

Signed-off-by: Jay Lee <[email protected]>

* remove raftstore wait

Signed-off-by: Jay Lee <[email protected]>

* Ref #11309.

tikv#11310 introduces delay in raftstore thread to reduce the flush rate.
It can only reduce flush rate from one thread. If there are many
raftstore threads or IO threads, messages can still be flush frequently.
This PR reduces the flush rate by introducing delay in raft client. So
delay will work at connection level and achieve the maximun batch
affect.

Signed-off-by: Jay Lee <[email protected]>

* remove useless field

Signed-off-by: Jay Lee <[email protected]>

* address comment

Signed-off-by: Jay Lee <[email protected]>

* fix unstable raw get case

Signed-off-by: Jay Lee <[email protected]>

Co-authored-by: Liqi Geng <[email protected]>
Co-authored-by: Ti Chi Robot <[email protected]>

* cloud: support azure blob storage as external storage backend (#11732)

* support azure storage blob for external storage

Signed-off-by: Leavrth <[email protected]>

* modify the priority of the azure login methods

Signed-off-by: Leavrth <[email protected]>

* fix feature match branch

Signed-off-by: Leavrth <[email protected]>

* implement token update retriable

Signed-off-by: Leavrth <[email protected]>

* fix some problems

Signed-off-by: Leavrth <[email protected]>

* close #11731

Signed-off-by: Leavrth <[email protected]>

* rustfmt

Signed-off-by: Leavrth <[email protected]>

* make clippy success

Signed-off-by: Leavrth <[email protected]>

* simplify uploader

Signed-off-by: Leavrth <[email protected]>

* commit some suggestions

Signed-off-by: Leavrth <[email protected]>

* coprocesser: update encoding lib (#11506)

Signed-off-by: xiongjiwei <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* coprocesser: implement upper and lower function on GBK charset (#11756)

Signed-off-by: xiongjiwei <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* logger: support archiving and rotation (#11651) (#11657)

* logger: support archiving and rotation (#11651)

close #11651

Signed-off-by: Wenbo Zhang <[email protected]>

* logger: add testcases to test dt_from_file_name (#11651)

ref #11651

Signed-off-by: Wenbo Zhang <[email protected]>

* logger: simplify DateTime format (#11651)

ref #11651

Signed-off-by: Wenbo Zhang <[email protected]>

* logger: do a little refactoring (#11651)

ref #11651

Signed-off-by: Wenbo Zhang <[email protected]>

* logger: do a little refactoring (#11651)

ref #11651

Signed-off-by: Wenbo Zhang <[email protected]>

* logger: do a little refactoring (#11651)

ref #11651

Signed-off-by: Wenbo Zhang <[email protected]>

* logger: do a little refactoring (#11651)

ref #11651

Signed-off-by: Wenbo Zhang <[email protected]>

* logger: do a little refactoring (#11651)

ref #11651

Signed-off-by: Wenbo Zhang <[email protected]>

* diagnostics: refactor  (#11651)

ref #11651

Signed-off-by: Wenbo Zhang <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* *: run clippy for integration tests (#11768)

* run clippy --fix with nightly-2021-12-17

Signed-off-by: tabokie <[email protected]>

* manual clippy

Signed-off-by: tabokie <[email protected]>

* format and clippy

Signed-off-by: tabokie <[email protected]>

* enable default features when running clippy, ref #11119

Signed-off-by: tabokie <[email protected]>

* fix build

Signed-off-by: tabokie <[email protected]>

* revert box_collection lint

Signed-off-by: tabokie <[email protected]>

* Update tests/integrations/raftstore/test_bootstrap.rs

Signed-off-by: Xinye Tao <[email protected]>

Co-authored-by: Lei Zhao <[email protected]>

Co-authored-by: Lei Zhao <[email protected]>

* logger: fix config-template's log unit (#11651) (#11777)

ref #11651

Signed-off-by: Wenbo Zhang <[email protected]>

* logger: improve testcase (#11651) (#11778)

ref #11651

Signed-off-by: Wenbo Zhang <[email protected]>

* raftstore: propose in-memory pessimistic locks before leader transfer (#11577)

* *: check epoch and validness of lock table when writing pessimistic locks

ref #11452

Signed-off-by: Yilin Chen <[email protected]>

* raftstore: propose in-memory pessimistic locks before leader transfer

ref #11452

Signed-off-by: Yilin Chen <[email protected]>

* mark delete in scheduler and delete after apply

Signed-off-by: Yilin Chen <[email protected]>

* Add tests for two different orders between proposing locks and write command

Signed-off-by: Yilin Chen <[email protected]>

* do not clear pessimistic locks before transfer leader

Signed-off-by: Yilin Chen <[email protected]>

* delete memory locks in the apply thread and add more term and version check

Signed-off-by: Yilin Chen <[email protected]>

* remove potentially incorrect assert

Signed-off-by: Yilin Chen <[email protected]>

* check term and version when reading the lock table

Signed-off-by: Yilin Chen <[email protected]>

* revert a log change

Signed-off-by: Yilin Chen <[email protected]>

* change term when becoming follower

Signed-off-by: Yilin Chen <[email protected]>

* fix lint

Signed-off-by: Yilin Chen <[email protected]>

* do not check version when reading locks (temporarily)

Signed-off-by: Yilin Chen <[email protected]>

* fix another test

Signed-off-by: Yilin Chen <[email protected]>

* only treat MsgTransferLeader with context with valid msg

Signed-off-by: Yilin Chen <[email protected]>

* fix a tiny comment error

Signed-off-by: Yilin Chen <[email protected]>

* make clippy happy

Signed-off-by: Yilin Chen <[email protected]>

* res_meter: ignore the read keys test temporarily (#11779)

ref #11765

Signed-off-by: mornyx <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* logger: change critical to fatal (#11651) (#11780)

* logger: change critical to fatal (#11651)

ref #11651

Signed-off-by: Wenbo Zhang <[email protected]>

* logger: fix test_parse_log_level (#11651)

ref #11651

Signed-off-by: Wenbo Zhang <[email protected]>

* update CHANGELOG.md (#11790)

* update from tikv-server v5.0.1(20210423)

from https://github.com/tikv/tikv/releases

Signed-off-by: xiejiandong <[email protected]>

* update CHANGELOG.md close #11167

Signed-off-by: xiejiandong <[email protected]>

* config: relax the bounds of online configurable worker number (#11651) (#11798)

close #11776

Signed-off-by: Wenbo Zhang <[email protected]>

* logger: invoke logger_compatible_adjust before run_tikv (#11651) (#11792)

close #11789

Signed-off-by: Wenbo Zhang <[email protected]>

Co-authored-by: Xinye Tao <[email protected]>
Co-authored-by: Ti Chi Robot <[email protected]>

* *: unify thread related native APIs (#11785)

* *: unify thread related native APIs

Now there are duplicated codes calling syscalls to fetch thread
informations. This PR provides unified APIs and remove duplicated codes.

Close #11784.

Signed-off-by: Jay Lee <[email protected]>

* address comment

Signed-off-by: Jay Lee <[email protected]>

* declare platform compatability

Signed-off-by: Jay Lee <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* Fix method on_tick will not update metric when enable_auto_tune is false (#11791)

* Fix method on_tick will not update metric when enable_auto_tune is false
ref #11787
Signed-off-by: yuqi1129 <[email protected]>

* resolve format problem in discussion

Signed-off-by: yuqi1129 <[email protected]>

* resolve format problem in discussion again

Signed-off-by: yuqi1129 <[email protected]>

Co-authored-by: Xinye Tao <[email protected]>
Co-authored-by: Ti Chi Robot <[email protected]>

* raftstore: add a new tick to renew lease in advance (#6427)

* renew lease in raft tick

Signed-off-by: 5kbpers <[email protected]>

* check lease before sending read index

Signed-off-by: 5kbpers <[email protected]>

* renew lease on raft tick to cover lease till next tick

Signed-off-by: linning <[email protected]>

* refactor

Signed-off-by: linning <[email protected]>

* don't use inspect_lease

Signed-off-by: linning <[email protected]>

* fix ci

Signed-off-by: linning <[email protected]>

* add test

Signed-off-by: linning <[email protected]>

* remove unneed comment

Signed-off-by: linning <[email protected]>

* close #5388

Signed-off-by: 5kbpers <[email protected]>

* check pending_read_count before hibernating

Signed-off-by: 5kbpers <[email protected]>

* increase the range to check lease expired

Signed-off-by: 5kbpers <[email protected]>

* renew leader lease after not hibernate

Signed-off-by: 5kbpers <[email protected]>

* fix hibernate states metrics

Signed-off-by: 5kbpers <[email protected]>

* check writes and pre_read_index before proposing read index

Signed-off-by: 5kbpers <[email protected]>

* fix test

Signed-off-by: 5kbpers <[email protected]>

* use a individual tick to renewing lease

Signed-off-by: 5kbpers <[email protected]>

* fix condition

Signed-off-by: 5kbpers <[email protected]>

* stablize test_node_renew_lease

Signed-off-by: 5kbpers <[email protected]>

* cleanup unused changes

Signed-off-by: 5kbpers <[email protected]>

* add config item for interval of tick

Signed-off-by: 5kbpers <[email protected]>

* rename tick

Signed-off-by: 5kbpers <[email protected]>

* disable the tick for test_inconsistent_configuration

Signed-off-by: 5kbpers <[email protected]>

* change deafault value of check_leader_lease_interval

Signed-off-by: 5kbpers <[email protected]>

* address comments

Signed-off-by: 5kbpers <[email protected]>

* disable the tick for test_read_hibernated_region

Signed-off-by: 5kbpers <[email protected]>

* address comments

Signed-off-by: 5kbpers <[email protected]>

* count renew lease read index into raft metrics

Signed-off-by: 5kbpers <[email protected]>

* address comments

Signed-off-by: 5kbpers <[email protected]>

* disable the tick for test_renew_lease

Signed-off-by: 5kbpers <[email protected]>

* address comments

Signed-off-by: 5kbpers <[email protected]>

* address comments

Signed-off-by: 5kbpers <[email protected]>

* fix lint error

Signed-off-by: 5kbpers <[email protected]>

* add a 100ms buffer for renew_bound

Signed-off-by: 5kbpers <[email protected]>

* address comments

Signed-off-by: 5kbpers <[email protected]>

* address comments

Signed-off-by: 5kbpers <[email protected]>

* make clippy happy

Signed-off-by: 5kbpers <[email protected]>

Co-authored-by: linning <[email protected]>
Co-authored-by: Ti Chi Robot <[email protected]>

* cloud: Add retry for azure blob server busy error (#11813)

* add retry for azure blob server busy error

Signed-off-by: Leavrth <[email protected]>

* close#11812

Signed-off-by: Leavrth <[email protected]>

* use to_string

Signed-off-by: Leavrth <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* tikv_util: make cgroup parsing more robust (#11786)

* make cgroup parsing more robust

Signed-off-by: tabokie <[email protected]>

* fix error message

Signed-off-by: tabokie <[email protected]>

* parse cpu quota in floats

Signed-off-by: tabokie <[email protected]>

* *: make it compile on macos (#11825)

* *: make it compile on macos

close #11823

Signed-off-by: Jay Lee <[email protected]>

* remove extra comment

Signed-off-by: Jay Lee <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* resolved_ts: add more metrics (#11809)

* add metrics

Signed-off-by: 5kbpers <[email protected]>

* add slow log

Signed-off-by: 5kbpers <[email protected]>

* remove duplicate metric

Signed-off-by: 5kbpers <[email protected]>

* add resolved ts metrics for leader peers

Signed-off-by: 5kbpers <[email protected]>

* close #11767

Signed-off-by: 5kbpers <[email protected]>

* init endpoint with store meta

Signed-off-by: 5kbpers <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* rsmeter: fix perf regression caused by arc swap  (#11833)

* rsmeter: fix perf regression caused by arc swap

Signed-off-by: Zhenchi <[email protected]>

* use atomic cell instead

Signed-off-by: Zhenchi <[email protected]>

* debug assert

Signed-off-by: Zhenchi <[email protected]>

Co-authored-by: Wenxuan <[email protected]>

* load base split: more accurate sample for large key ranges batch (#11039)

* more accurate sample for large key ranges

Signed-off-by: lhy1024 <[email protected]>

* update

Signed-off-by: lhy1024 <[email protected]>

* ref #11521

Signed-off-by: lhy1024 <[email protected]>

* address comment

Signed-off-by: lhy1024 <[email protected]>

* fix test

Signed-off-by: lhy1024 <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* raftclient: enable delay only in high load (#11772)

and improve CPU efficiency under high load. But it turns out
this can lead to significant regression in normal load. So
this PR adds CPU stats and only enabling delay in high load.

This is also the same strategy used in v4.x.

Close #11769.

Signed-off-by: Jay Lee <[email protected]>

* tikv-ctl: fix tikv-ctl's output is incomplete on calling process::exit (#11231)

Signed-off-by: Yao Zongyou <[email protected]>

Co-authored-by: Xinye Tao <[email protected]>
Co-authored-by: Connor <[email protected]>
Co-authored-by: Ti Chi Robot <[email protected]>

* raftstore: skip deleting snapshot files in peer pending_remove is true (#11782)

* raftstore: skip deleting snapshot files in peer when the peer is pending removal and the snapshot is being applied and canceled -- close #11746

This is to avoid the potential panic when the snapshot files are deleted, but the peer's status (Tombstone) is not persisted in disk due to tikv crash.

Signed-off-by: tonyxuqqi <[email protected]>

* address code review feedback  -- close #11746

Signed-off-by: qi.xu <[email protected]>

* address code review feedback 2  -- close #11746

Signed-off-by: qi.xu <[email protected]>

* address code review feedback 2  -- close #11746

Signed-off-by: qi.xu <[email protected]>

* address code review feedback 2  -- close #11746

Signed-off-by: qi.xu <[email protected]>

* address code review feedback 2  -- close #11746

Signed-off-by: qi.xu <[email protected]>

Co-authored-by: qi.xu <[email protected]>

* load_statis: fix compilation on macos (#11851)

close #11772

Signed-off-by: Jay Lee <[email protected]>

* config: override rocksdb config when flow control enabled (#11840)

Signed-off-by: Connor1996 <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* rocksdb: consider env sharing when configuring background threads (#11760)

#9649 increased the default setting of kvdb background flushes (3 for 8c and 4 for 16c).

This PR takes another approach: use smaller concurrency for individual dbs, but configure the global thread pool size with the sum of kvdb and raftdb concurrency. This way we won't over-configure flush workers when raft-engine is enabled.

* consider env sharing when configuring background threads

ref #11119

Signed-off-by: tabokie <[email protected]>

* server/config: keep compatible using option (#11862)

* server/config: keep compatible using option

Using `Option` for `heavy_load_wait_duration` to keep compatible with
versions prior to v5.3.

Close #11861.

Signed-off-by: Jay Lee <[email protected]>

* fix format

Signed-off-by: Jay Lee <[email protected]>

* fix clippy

Signed-off-by: Jay Lee <[email protected]>

Co-authored-by: zhouqiang <[email protected]>

* raftstore: fix missing workers' stop on shutdown (#11864)

ref #11159

Signed-off-by: Wenbo Zhang <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* raftstore: move in-memory pessimistic locks to split regions (#11655)

ref #11452

Signed-off-by: Yilin Chen <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* *: Remove the entrance of enabling io snooper. (#11394)

* *: Remove the entrance of enabling io snooper. close #10867

Signed-off-by: MuZhou233 <[email protected]>

* fix

Signed-off-by: MuZhou233 <[email protected]>

* fix test

Signed-off-by: MuZhou233 <[email protected]>

* fix test

Signed-off-by: MuZhou233 <[email protected]>

Co-authored-by: Xinye Tao <[email protected]>
Co-authored-by: Ti Chi Robot <[email protected]>

* raftstore: change PeerTicks to enum (#11849)

* raftstore: change PeerTicks to enum

close #11848

Signed-off-by: Yilin Chen <[email protected]>

* use bool array for registry

Signed-off-by: Yilin Chen <[email protected]>

* rename PeerTicks to PeerTick

Signed-off-by: Yilin Chen <[email protected]>

* add associated const for number of PeerTick types

Signed-off-by: Yilin Chen <[email protected]>

* change naming

Signed-off-by: Yilin Chen <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* *: check memory limit when inserting in-memory pessimistic locks (#11841)

* *: check memory limit when inserting in-memory pessimistic locks

ref #11452

Signed-off-by: Yilin Chen <[email protected]>

* fix merged upstream

Signed-off-by: Yilin Chen <[email protected]>

* fix test

Signed-off-by: Yilin Chen <[email protected]>

* fix typo

Signed-off-by: Yilin Chen <[email protected]>

* *: fix invalid failpoint caused by typo (#11709)

* fix invalid failpoint caused by typo

close #11734

Signed-off-by: Ryan Leung <[email protected]>

* address the comment

Signed-off-by: Ryan Leung <[email protected]>

* address the comment

Signed-off-by: Ryan Leung <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* raftstore: Extract significant router (#11750)

* ref#11409 add significant router

Signed-off-by: Connor1996 <[email protected]>

* make format

Signed-off-by: Connor1996 <[email protected]>

* address comment

Signed-off-by: Connor1996 <[email protected]>

* raftstore: move scan delete to raft log gc worker (#11853)

* raftstore: move scan delete to raft log gc worker

When clearing raft metas, raftstore will scan raft logs and delete them
one by one. Seeking can be slow if there are a lot of tombstone keys.
This PR moves the operation to raft log gc worker to reduce the impact.

The final solution should be also moving remaining IO operations to
async write IO threads.

Close #10210.

Signed-off-by: Jay Lee <[email protected]>

* address comment

Signed-off-by: Jay Lee <[email protected]>

* speed up destroy

Signed-off-by: Jay Lee <[email protected]>

* fix compile

Signed-off-by: Jay Lee <[email protected]>

* further speed up

Signed-off-by: Jay Lee <[email protected]>

* revert test case configuration

Signed-off-by: Jay Lee <[email protected]>

* address comment

Signed-off-by: Jay Lee <[email protected]>

* address comment

Signed-off-by: Jay Lee <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* doc: update new rules for linking issue and commit message (#11832)

close #11097, close #11831

Signed-off-by: zhangyangyu <[email protected]>

Co-authored-by: Mini256 <[email protected]>

Co-authored-by: Mini256 <[email protected]>
Co-authored-by: Xiaoguang Sun <[email protected]>

* *: update rust toolchain to 2022-01-07 (#11875)

* update rust toolchain to 2022-01-17

Signed-off-by: tabokie <[email protected]>

* address comment: clean up unnecessary `as_ref()`

Signed-off-by: tabokie <[email protected]>

* try fixing the underflow

Signed-off-by: tabokie <[email protected]>

* mute underflow warning for raft metrics

Signed-off-by: tabokie <[email protected]>

* clean up unused data members

Signed-off-by: tabokie <[email protected]>

* format

Signed-off-by: tabokie <[email protected]>

* step back to 2022-01-07

Signed-off-by: tabokie <[email protected]>

* readme: change images based on github theme (#11795)

Signed-off-by: sloorush <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* raftstore: don't remove other peer's read delegate (#11882)

* don't remove read delegate besides peer_destroy

Signed-off-by: linning <[email protected]>

* add test case

Signed-off-by: linning <[email protected]>

* make clippy happy

Signed-off-by: linning <[email protected]>

* address comment

Signed-off-by: linning <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* logger: use eprintln! if the logger is not initialized (#11869)

ref #11651

Signed-off-by: Wenbo Zhang <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* copr: fix the calculation of total column size in analyze (#11884)

Signed-off-by: xuyifan <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* engine: update raft-engine for data consistency fix (#11885)

Fix https://github.com/tikv/raft-engine/issues/142.

When encountering this bug, TiKV will panic with message "applied index > max(commit index, recorded commit index)" after restart.

* update raft-engine

Signed-off-by: tabokie <[email protected]>

* update one more commit

Signed-off-by: tabokie <[email protected]>

* check docker build during clippy, ref #11312 (#11819)

Signed-off-by: tabokie <[email protected]>

* gc_worker: fix incorrect scheduled_tasks counting (#11904)

* gc_worker: fix incorrect scheduled_tasks counting

close #11903

Signed-off-by: Yilin Chen <[email protected]>

* remove check_is_busy totally

Signed-off-by: Yilin Chen <[email protected]>

* do not use wildcard match in error handling

Signed-off-by: Yilin Chen <[email protected]>

* raftstore: Introduce raft log fetcher (#11900)

* ref#11409 introduce raft log fetcher

Signed-off-by: Connor1996 <[email protected]>

* update kvproto

Signed-off-by: Connor1996 <[email protected]>

* address comment

Signed-off-by: Connor1996 <[email protected]>

* fix test build

Signed-off-by: Connor1996 <[email protected]>

* fix clippy

Signed-off-by: Connor1996 <[email protected]>

* limit capacity

Signed-off-by: Connor1996 <[email protected]>

* update kvproto

Signed-off-by: Connor1996 <[email protected]>

* call stop on worker

Signed-off-by: Connor1996 <[email protected]>

* rename worker

Signed-off-by: Connor1996 <[email protected]>

* status_server: add pprof flamegraph response header (#10951)

* tweak(status_server): add pprof flamegraph response header

Signed-off-by: Suhaha <[email protected]>

* test(status_server): add Content-Type asset to test_pprof_profile_service

Signed-off-by: Suhaha <[email protected]>

* tweak(status_server): add pprof flamegraph response header

Signed-off-by: Suhaha <[email protected]>

* tweak(status_server): add pprof flamegraph response header close #11917

Signed-off-by: Suhaha <[email protected]>

* close #11917

Signed-off-by: Suhaha <[email protected]>

Co-authored-by: goroutine <[email protected]>
Co-authored-by: Connor <[email protected]>

* raftstore: renew leader lease in advance when handle read request (#9307)

* renew lease advance

Signed-off-by: linning <[email protected]>

* add log

Signed-off-by: linning <[email protected]>

* make clippy happy

Signed-off-by: linning <[email protected]>

* ref #11579

Signed-off-by: 5kbpers <[email protected]>

* reset raft tick

Signed-off-by: 5kbpers <[email protected]>

* set has ready

Signed-off-by: 5kbpers <[email protected]>

* address comments

Signed-off-by: 5kbpers <[email protected]>

* address comment

Signed-off-by: 5kbpers <[email protected]>

* address comment

Signed-off-by: 5kbpers <[email protected]>

* address comment

Signed-off-by: 5kbpers <[email protected]>

* add renew_leader_lease_advance_duration config

Signed-off-by: 5kbpers <[email protected]>

* address comment

Signed-off-by: 5kbpers <[email protected]>

* fix panic

Signed-off-by: 5kbpers <[email protected]>

* address comment

Signed-off-by: 5kbpers <[email protected]>

* address comment

Signed-off-by: 5kbpers <[email protected]>

* disable renewing for test_lease_unsafe_during_leader_transfers

Signed-off-by: 5kbpers <[email protected]>

Co-authored-by: 5kbpers <[email protected]>

* pprof: ignore cpu profiling on non-x86 arch (#11925)

* Disable cpu profiling on non-x86_64 arch

Signed-off-by: mornyx <[email protected]>

* Fix warns

Signed-off-by: mornyx <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* github: add new pr requirement for linking issue and commit message (#11887)

Signed-off-by: zhangyangyu <[email protected]>

Co-authored-by: Xiaoguang Sun <[email protected]>

* engine: enable raft engine by default (#11928)

* enable raft engine by default and synchronize docs

Signed-off-by: tabokie <[email protected]>

* update raft engine

Signed-off-by: tabokie <[email protected]>

* update raft-engine and fix tests

Signed-off-by: tabokie <[email protected]>

* gc_worker: Limit the key range to scan for GcKeys tasks (#11922)

close tikv/tikv#11752, close tikv/tikv#11902

Signed-off-by: MyonKeminta <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* raftstore: TransferLeader support multiple target peers (#11063)

ref tikv/tikv#822, ref tikv/tikv#4214, close tikv/tikv#10602

Signed-off-by: MrCroxx <[email protected]>

* raftstore: remove the leaders field of `StoreMeta` (#11934)

close tikv/tikv#11933

Remove `StoreMeta.leaders`
```

### Related changes

### Check List <!--REMOVE the items that are not applicable-->

Tests <!-- At least one of them must be included. -->

- Manual test (add detailed scripts or steps below)
`cargo check`

### Release note <!-- bugfixes or new feature need a release note -->

```release-note
None

Signed-off-by: linning <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* raftstore: Fetch raft log in async manner (#11409)

close tikv/tikv#10408, close tikv/tikv#11320

Signed-off-by: Connor1996 <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* copr: add quarter function (#11935)

ref tikv/tikv#5751

Signed-off-by: zhongyong jin <[email protected]>

* Enable full debug info for dev and test (#11949)

ref tikv/tikv#5049, ref tikv/tikv#5572, close tikv/tikv#5572

```

### Related changes

- PR to update `pingcap/docs`/`pingcap/docs-cn`:
- PR to update `pingcap/tidb-ansible`:
- Need to cherry-pick to the release branch
-->

### Check List <!--REMOVE the items that are not applicable-->

Tests <!-- At least one of them must be included. -->

- Manual test (add detailed scripts or steps below)
- No code

Manual test:
Linux box with 8 cores (3:50 -> 4:00):
```
# Before this PR:
$ make clean
cargo clean
rm -rf bin dist
$ time make build
cargo build --no-default-features --features "jemalloc mem-profiling portable sse test-engines-rocksdb cloud-aws cloud-gcp cloud-azure"
   Compiling libc v0.2.106
...
   Compiling server v0.0.1 (tikv/components/server)
    Finished dev [unoptimized + debuginfo] target(s) in 3m 50s

real	3m50,487s
user	38m11,859s
sys	3m9,540s

# After this PR:
$ git diff
diff --git a/Cargo.toml b/Cargo.toml
index 71f5329d3..67cb9d183 100644
--- a/Cargo.toml
+++ b/Cargo.toml
@@ -267,7 +267,7 @@ default-members = ["cmd/tikv-server", "cmd/tikv-ctl"]
 
 [profile.dev]
 opt-level = 0
-debug = 1 # required for line numbers in tests, see tikv #5049
+debug = true
 codegen-units = 4
 lto = false
 incremental = true
@@ -293,7 +293,7 @@ codegen-units = 4
 
 [profile.test]
 opt-level = 0
-debug = 1 # enable line numbers by default for easy test debugging
+debug = true
 codegen-units = 16
 lto = false
 incremental = true
mattias@msig:~/repos/tikv$ time make clean
cargo clean
rm -rf bin dist

real	0m0,975s
user	0m0,148s
sys	0m0,828s
mattias@msig:~/repos/tikv$ time make build
cargo build --no-default-features --features "jemalloc mem-profiling portable sse test-engines-rocksdb cloud-aws cloud-gcp cloud-azure"
   Compiling libc v0.2.106
...
   Compiling server v0.0.1 (tikv/components/server)
    Finished dev [unoptimized + debuginfo] target(s) in 4m 00s

real	4m0,201s
user	39m45,037s
sys	3m16,397s
```

Macbook Air M1:
```
# Before:
% time make build
cargo build --no-default-features --features " jemalloc test-engines-rocksdb cloud-aws cloud-gcp cloud-azure"
   Compiling libc v0.2.106
....
   Compiling server v0.0.1 (tikv/components/server)
    Finished dev [unoptimized + debuginfo] target(s) in 4m 01s
make build  1107.42s user 116.20s system 506% cpu 4:01.46 total

# After:
% time make build
cargo build --no-default-features --features " jemalloc test-engines-rocksdb cloud-aws cloud-gcp cloud-azure"
   Compiling libc v0.2.106
....
   Compiling server v0.0.1 (tikv/components/server)
    Finished dev [unoptimized + debuginfo] target(s) in 4m 10s
make build  1179.39s user 120.74s system 518% cpu 4:10.98 total
```

Side effects

- Performance regression, Only when building, to the benefit of full debug info by default.


### Release note <!-- bugfixes or new feature need a release note -->

```release-note
None

Signed-off-by: Mattias Jonsson <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* correct a metric about compaction filter (#11938)

 

correct a metric about compaction filter

Signed-off-by: qupeng <[email protected]>

* raft: Fix possible panic on entries fetched callback (#11961)

close tikv/tikv#11951

Signed-off-by: Connor1996 <[email protected]>

* split_controller: refine the sample function and add some comments (#11952)

 

Signed-off-by: JmPotato <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* metrics: fix grid position in TiKV Details (#11936)

ref tikv/tikv#11119

Fix grid positions in TiKV Details dashboard.

Signed-off-by: tabokie <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* cdc: capture old value from txn layer dynamically (#11896)

close tikv/tikv#10091

Signed-off-by: hi-rustin <[email protected]>
Signed-off-by: qupeng <[email protected]>

Co-authored-by: hi-rustin <[email protected]>

* split_controller: reorganize the structs and add more comments (#11967)

 

Reorganize the structs and add more comments.

Signed-off-by: JmPotato <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* copr: support Bit column push downBit column (#11968)

close tikv/tikv#11893, ref tikv/tikv#11893, ref pingcap/tidb#31884

Signed-off-by: xiejiandong <[email protected]>

* copr: support push down mod, sysdate to TiKV (#11970)

close tikv/tikv#11916, ref tikv/tikv#11916

Signed-off-by: xiejiandong <[email protected]>

* raftstore: propose in-memory pessimistic locks before prepare merge (#11758)

ref tikv/tikv#11452

Signed-off-by: Yilin Chen <[email protected]>

* stats_monitor: reformat stats_monitor tick (#11972)

 

Signed-off-by: lhy1024 <[email protected]>

* copr: support extract scalar value from bit (#11980)

close tikv/tikv#11893

Signed-off-by: yisaer <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* diagnosis: support get cpu time of threads for macOS (#11978)

close tikv/tikv#11977

Add the variant for macOS into `components/tikv_util/src/sys/thread.rs`

Signed-off-by: Zhenchi <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>
Co-authored-by: Jay <[email protected]>

* rust: update toolchain to fix missing rls (#11954)

close tikv/tikv#11953

Signed-off-by: Connor1996 <[email protected]>
Signed-off-by: Yilin Chen <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>
Co-authored-by: Yilin Chen <[email protected]>

* cdc: separate resolved region outliers (#11991)

Separate broadcasing outlier regions and normal regions,
so 1) downstreams know where they should send resolve lock requests,
and 2) resolved ts of normal regions does not fallback.

close pingcap/tiflow#4516
close pingcap/tiflow#4311
ref pingcap/tiflow#4146

Signed-off-by: Neil Shen <[email protected]>

* *: collect key ranges for the read request in ResourceMeteringTag (#11995)

close tikv/tikv#11988

*: collect key ranges for the read request in ResourceMeteringTag

Signed-off-by: JmPotato <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* split_controller: move sample_threshold check out of the split_key iteration (#11986)

 

split_controller: move sample_threshold check out of the split_key iteration

Signed-off-by: JmPotato <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* copr: support insertutf8 and lowerutf8 (#11987)

ref tikv/tikv#5751

Signed-off-by: yisaer <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* copr: support rest greatest/least functions (#12003)

ref tikv/tikv#5751

Signed-off-by: yisaer <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* raftstore: force compact with gentleness (#12006)

* force compact with gentleness

Signed-off-by: tabokie <[email protected]>

* address comment

Signed-off-by: tabokie <[email protected]>

* split_controller: refine the LOAD_BASE_SPLIT_EVENT metrics label definitions (#12010)

 

split_controller: refine the LOAD_BASE_SPLIT_EVENT metrics label definitions

Signed-off-by: JmPotato <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* split_controller: fix the incorrect sampled key ranges number check (#12013)

close tikv/tikv#12012

split_controller: fix the incorrect sampled key ranges number check

Signed-off-by: JmPotato <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* raftstore: Support adjusting max_inflight_msgs dynamically (#11866)

close tikv/tikv#11865

Signed-off-by: Wenbo Zhang <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* copr: fix missing flag solvement for bit column in decoding (#12016)

ref tikv/tikv#7, close pingcap/tidb#32506

Signed-off-by: yisaer <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* file_system: overhaul proc-based io tracing utilities (#11873)

ref tikv/tikv#10867, fix tikv/tikv#11775

Signed-off-by: tabokie <[email protected]>

* raftstore: Wait for the apply index equals to the commit index (#11716)

ref tikv/tikv#10483

Signed-off-by: v01dstar <[email protected]>

* copr: revert 11968/11980/12016 (#12030)

ref tikv/tikv#11968, ref tikv/tikv#11980, ref tikv/tikv#12016, ref pingcap/tidb#32506

Signed-off-by: yisaer <[email protected]>

* build: fix a Mac build issue (#12027)

ref tikv/tikv#10867, ref tikv/tikv#11873

Signed-off-by: tabokie <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* copr: Extra physical table id column (#11931)

close tikv/tikv#11888

Added EXTRA_PHYSICAL_TABLE_ID_COL_ID support, to support TiDB's table partition dynamic prune mode, where a single request includes multiple partitions, but when Pessimistic lock (like `SELECT FOR UPDATE`) or ongoing transaction (having something in the tidb session local transaction buffer) each row needs its partition id / physical table ID to either lock that row or to check against the transaction buffer.

Signed-off-by: Mattias Jonsson <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* *: hotfix panic from tokio-timer (#12004)

close tikv/tikv#11940, ref tikv/tikv#11940

*: hotfix panic from tokio-timer by enlarging the length of the level vector

Signed-off-by: you06 <[email protected]>

* build: add arm64 check on SSE in makefile (#12035)

close tikv/tikv#12034

Signed-off-by: Jin Dong <[email protected]>

Co-authored-by: Yilin Chen <[email protected]>
Co-authored-by: Ti Chi Robot <[email protected]>

* replication mode: sync state to pd (#11751)

 

Signed-off-by: disksing <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* raftstore: revert pessimistic locks status when failing to propose PrepareMerge (#11985)

ref tikv/tikv#11452

Signed-off-by: Yilin Chen <[email protected]>

* copr: support push bit column down (#12037)

ref pingcap/tidb#30738

Signed-off-by: yisaer <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* split_controller: add more sample function test cases (#12058)

 

split_controller: add more sample function test cases

Signed-off-by: JmPotato <[email protected]>

* copr: fix greatest/least time/date args type (#12056)

 

Signed-off-by: yisaer <[email protected]>

* cdc: advancing resolved ts correctly for clusters with tiflash (#12050)

close pingcap/tiflow#4461

cdc: advancing resolved ts correctly for clusters with tiflash

Signed-off-by: qupeng <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* *: bump master branch version to v6.0.0-alpha (#12077)

close tikv/tikv#12075

Signed-off-by: Yilin Chen <[email protected]>

* raftstore: check uninitialized destroy for merge (#12055)

close tikv/tikv#12048

When a peer is destroyed without being initialized, it will store
itself to peer list and the region epoch is missing. In merge if
such state is detected, it should abort merging instead of panicking.

Signed-off-by: Jay Lee <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* *: Add TruncateManager and TruncateWorker (#11553)

ref tikv/rfcs#81

Signed-off-by: longfangsong <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* TiKV supports buckets (#11763)

ref tikv/tikv#11759

Signed-off-by: qi.xu <[email protected]>

Co-authored-by: qi.xu <[email protected]>
Co-authored-by: Ti Chi Robot <[email protected]>

* api_version: Codec for RawKV key (#12036)

ref tikv/tikv#11965

Key of RawKV is encoded as `user-key + memcomparable-padding + timestamp` in API v2.

Signed-off-by: pingyu <[email protected]>

Co-authored-by: Andy Lok <[email protected]>
Co-authored-by: Ti Chi Robot <[email protected]>

* *: fix some typos (#12066)

 

Signed-off-by: cuishuang <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* raftstore: fix stale message cause panic (#12054)

close tikv/tikv#12023

raftstore: fix stale message cause panic

Signed-off-by: linning <[email protected]>

* raftstore: ignore async fetch result when the peer is pending removed (#12038)

close tikv/tikv#11973, close tikv/tikv#12026

Signed-off-by: Connor1996 <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* *: remove part about wechat in doc (#12101)

close tikv/tikv#12100

Signed-off-by: jackwener <[email protected]>

* engine: upgrade raft engine (#12095)

ref tikv/tikv#165, ref tikv/raft-engine#165, ref tikv/tikv#11119

Signed-off-by: Randy <[email protected]>

Co-authored-by: Xinye Tao <[email protected]>

* *: Fix possible undefined behavior for transmuting vec (#12096)

close tikv/tikv#12070

Signed-off-by: Connor1996 <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* github: Remove the pingcap/tidb-ansible from the PR template (#12102)

close tikv/tikv#12103

Signed-off-by: hi-rustin <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* copr: extract reschedule to inject a fail point (#12108)

 

Signed-off-by: Zhenchi <[email protected]>

* raftstore: reactivate in-memory pessimistic locking when leader transfer fails (#11883)

ref tikv/tikv#11452

Signed-off-by: Yilin Chen <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* *: check memory locks for replica read only on the leader (#12115)

close tikv/tikv#12109

Consider a reader sends read index to the leader it supposed to be, but when
the leader receives the read index message, it has stepped down to a
follower. Without this commit, a peer will check the locks and re-fill the
read index context with the result no matter what role it is. So, when the
read index request is redirected to the new leader again, it no longer carries
the context of lock checking.

This commmit changes to only do the check when the peer is a leader. Then, the
read index request will remain unchanged before being redirected to the leader.

If the lease of the leader expires, it is still safe to check on the
uncertained leader. If the heartbeat check passes and no new leader is elected,
then the check works fine. If there is a new leader, when the old leader
becomes a follower, it will clear its pending read index. Then, the reader has
to resend the read index again to the correct leader. So, generally it is safe
as long as we guarantee the check only happens on the leader.

Signed-off-by: Yilin Chen <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* apiv2 rawkv: logical deletion flag (#12090)

ref tikv/tikv#11965

Signed-off-by: haojinming <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* copr: add projection (#10689)

close tikv/tikv#12114

Signed-off-by: ichn-hu <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>
Co-authored-by: Alex Chi <[email protected]>

* raftstore: adjust raft max msg size dynamically (#12018)

close tikv/tikv#12017

Signed-off-by: glorv <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* *: update deps (#12098)

- Upgrade grpcio to 0.10
- Upgrade openssl to 1.1.1m
- Remove dependency on prost

Signed-off-by: Jay Lee <[email protected]>

* tests: make raftstore tests about transactions more stable (#12122)

close tikv/tikv#12120

A new fail point "after_propose" is added to insert callback from the test.
Then we can ensure we release other key fail points after they take effect.

The other change is to retry request automatically to avoid stale command
errors.

Signed-off-by: Yilin Chen <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* metrics: support multi k8s in grafana dashboards (#12008)

close tikv/tikv#12104

Signed-off-by: just1900 <[email protected]>

* storage: set in-memory pessimistic lock feature gate to 6.0.0 (#12078)

ref tikv/tikv#11452

The in-memory pessimistic lock feature should be only enabled after
all TiKV instances have been upgraded to the new version. Otherwise,
transferring leader may be blocked because of the new protocol and
procedure when in-memory pessimistic locks exist.

So, we need to use a feature gate to make sure this feature is only
enabled after all TiKVs have been upgraded to the new version.

Signed-off-by: Yilin Chen <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* raftstore,cdc: pass leader transferee to cdc observer (#12124)

Signed-off-by: qupeng <[email protected]>

Co-authored-by: Ti Chi Robot <[email protected]>

* config: simplify handling of nullable configurations (#12133)

Support deriving `O…
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
contribution This PR is from a community contributor. release-note Denotes a PR that will be considered when it comes time to generate release notes. size/XXL Denotes a PR that changes 1000+ lines, ignoring generated files. status/can-merge Indicates a PR has been approved by a committer. status/LGT2 Indicates that a PR has LGTM 2.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

support projection on tikv's coprocessor
4 participants