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

[enhancement](cloud) optimize block cache lock (#41818) #43401

Merged
merged 1 commit into from
Nov 7, 2024

Conversation

freemandealer
Copy link
Contributor

@freemandealer freemandealer commented Nov 7, 2024

pick #41818 from master

  1. async deletion when do stale rowsets reclycle
  2. minimize lock critical size
  3. add cache lock held & wait time info for debug

What problem does this PR solve?

Issue Number: close #xxx

Related PR: #xxx

Problem Summary:

Check List (For Author)

  • Test

    • Regression test
    • Unit Test
    • Manual test (add detailed scripts or steps below)
    • No need to test or manual test. Explain why:
      • This is a refactor/code format and no logic has been changed.
      • Previous test can cover this change.
      • No colde files have been changed.
      • Other reason
  • Behavior changed:

    • No.
    • Yes.
  • Does this need documentation?

    • No.
    • Yes.
  • Release note

    None

Check List (For Reviewer who merge this PR)

  • Confirm the release note
  • Confirm test cases
  • Confirm document
  • Add branch pick label

pick apache#41818 from master

1. async deletion when do stale rowsets reclycle
2. minimize lock critical size
3. add cache lock held & wait time info for debug
@doris-robot
Copy link

Thank you for your contribution to Apache Doris.
Don't know what should be done next? See How to process your PR

Since 2024-03-18, the Document has been moved to doris-website.
See Doris Document.

@freemandealer
Copy link
Contributor Author

run buildall

Copy link
Contributor

@github-actions github-actions bot left a comment

Choose a reason for hiding this comment

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

clang-tidy made some suggestions

@@ -19,6 +19,7 @@

#include <bvar/bvar.h>
Copy link
Contributor

Choose a reason for hiding this comment

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

warning: 'bvar/bvar.h' file not found [clang-diagnostic-error]

#include <bvar/bvar.h>
         ^

template <class Lock>
concept IsXLock = std::same_as<Lock, std::lock_guard<std::mutex>> ||
std::same_as<Lock, std::unique_lock<std::mutex>>;

class FSFileCacheStorage;

class LockScopedTimer {
public:
LockScopedTimer() : start_(std::chrono::steady_clock::now()) {}
Copy link
Contributor

Choose a reason for hiding this comment

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

warning: use '= default' to define a trivial default constructor [modernize-use-equals-default]

Suggested change
LockScopedTimer() : start_(std::chrono::steady_clock::now()) {}
LockScopedTimer() : start_(std::chrono::steady_clock::now()) = default;

@doris-robot
Copy link

TPC-H: Total hot run time: 40902 ms
machine: 'aliyun_ecs.c7a.8xlarge_32C64G'
scripts: https://github.com/apache/doris/tree/master/tools/tpch-tools
Tpch sf100 test result on commit 6fdb52cf74e6bbcf810329ba3bce58f5e2d0c114, data reload: false

------ Round 1 ----------------------------------
q1	17933	7515	7393	7393
q2	2058	176	196	176
q3	10583	1132	1129	1129
q4	10341	756	676	676
q5	7751	2856	2832	2832
q6	239	147	142	142
q7	993	604	603	603
q8	9377	1962	2010	1962
q9	6580	6450	6455	6450
q10	6945	2300	2294	2294
q11	460	261	267	261
q12	400	226	215	215
q13	17786	2987	2980	2980
q14	245	207	207	207
q15	561	523	516	516
q16	663	586	595	586
q17	973	568	529	529
q18	7426	6608	6627	6608
q19	2521	1048	1028	1028
q20	484	194	193	193
q21	4200	3126	3137	3126
q22	1093	996	1002	996
Total cold run time: 109612 ms
Total hot run time: 40902 ms

----- Round 2, with runtime_filter_mode=off -----
q1	7385	7274	7258	7258
q2	401	307	291	291
q3	2879	2751	2733	2733
q4	1917	1647	1653	1647
q5	5463	5427	5462	5427
q6	217	138	138	138
q7	2076	1645	1633	1633
q8	3260	3420	3436	3420
q9	8548	8520	8533	8520
q10	3464	3406	3388	3388
q11	584	492	490	490
q12	764	576	560	560
q13	16883	3000	2953	2953
q14	299	255	259	255
q15	584	540	542	540
q16	680	658	656	656
q17	1789	1589	1578	1578
q18	7639	7584	7333	7333
q19	1674	1509	1559	1509
q20	2001	1789	1790	1789
q21	5549	5046	4901	4901
q22	1103	1015	1019	1015
Total cold run time: 75159 ms
Total hot run time: 58034 ms

@doris-robot
Copy link

TPC-DS: Total hot run time: 190940 ms
machine: 'aliyun_ecs.c7a.8xlarge_32C64G'
scripts: https://github.com/apache/doris/tree/master/tools/tpcds-tools
TPC-DS sf100 test result on commit 6fdb52cf74e6bbcf810329ba3bce58f5e2d0c114, data reload: false

query1	980	379	360	360
query2	6527	2170	2118	2118
query3	6698	210	229	210
query4	34039	23269	23387	23269
query5	4394	454	450	450
query6	261	179	180	179
query7	4631	304	302	302
query8	280	250	233	233
query9	9552	2654	2624	2624
query10	472	264	251	251
query11	18142	15139	15118	15118
query12	163	100	97	97
query13	1665	429	402	402
query14	8668	7256	7103	7103
query15	240	168	172	168
query16	7982	509	474	474
query17	1636	562	559	559
query18	2365	604	559	559
query19	250	184	181	181
query20	116	108	108	108
query21	211	103	100	100
query22	4538	4184	4046	4046
query23	34576	33672	34107	33672
query24	12484	3382	3363	3363
query25	706	395	407	395
query26	1872	182	183	182
query27	2788	291	292	291
query28	8096	2463	2467	2463
query29	1097	436	445	436
query30	461	295	309	295
query31	1018	783	791	783
query32	103	57	59	57
query33	787	288	279	279
query34	961	501	507	501
query35	852	725	687	687
query36	1076	957	916	916
query37	264	73	74	73
query38	3990	3803	3812	3803
query39	1469	1387	1424	1387
query40	287	102	101	101
query41	54	50	53	50
query42	109	99	96	96
query43	535	503	480	480
query44	1341	794	799	794
query45	185	169	170	169
query46	1138	723	729	723
query47	1937	1839	1823	1823
query48	459	360	359	359
query49	1312	402	404	402
query50	791	414	403	403
query51	7164	7067	7083	7067
query52	105	89	91	89
query53	258	196	186	186
query54	1160	447	457	447
query55	78	76	74	74
query56	256	244	249	244
query57	1196	1109	1109	1109
query58	237	228	231	228
query59	3179	3048	2954	2954
query60	268	250	246	246
query61	110	108	108	108
query62	864	655	657	655
query63	213	185	178	178
query64	5420	667	633	633
query65	3275	3156	3183	3156
query66	1403	310	336	310
query67	16003	15377	15514	15377
query68	4992	572	585	572
query69	430	254	254	254
query70	1183	1126	1105	1105
query71	402	260	254	254
query72	6335	3919	3940	3919
query73	752	339	341	339
query74	10363	8949	8907	8907
query75	3531	2633	2575	2575
query76	2945	1078	936	936
query77	485	269	273	269
query78	10705	9599	9524	9524
query79	9149	574	587	574
query80	2075	417	413	413
query81	565	239	241	239
query82	1511	114	115	114
query83	271	159	161	159
query84	287	90	79	79
query85	2205	310	297	297
query86	495	306	292	292
query87	4388	4343	4235	4235
query88	5709	2399	2364	2364
query89	567	287	295	287
query90	2116	184	185	184
query91	174	146	142	142
query92	64	46	49	46
query93	6365	558	533	533
query94	932	296	291	291
query95	349	249	246	246
query96	621	278	276	276
query97	3319	3093	3158	3093
query98	217	205	194	194
query99	1827	1273	1300	1273
Total cold run time: 321076 ms
Total hot run time: 190940 ms

@dataroaring dataroaring merged commit ae9c957 into apache:branch-3.0 Nov 7, 2024
25 of 28 checks passed
eldenmoon pushed a commit to eldenmoon/incubator-doris that referenced this pull request Nov 12, 2024
…#43401)

pick apache#41818 from master

1. async deletion when do stale rowsets reclycle
2. minimize lock critical size
3. add cache lock held & wait time info for debug
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

Successfully merging this pull request may close these issues.

3 participants