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

Counts on pop_basis table take a long time. #207

Closed
1 task done
ClaytonNorthey92 opened this issue Aug 16, 2024 · 2 comments
Closed
1 task done

Counts on pop_basis table take a long time. #207

ClaytonNorthey92 opened this issue Aug 16, 2024 · 2 comments
Assignees
Labels
area: bfg This is a change to BFG (Bitcoin Finality Governor) status: triage This is awaiting review. Maintainers should this label once triaged type: bug This is a bug

Comments

@ClaytonNorthey92
Copy link
Contributor

Confirmation

  • I have checked for similar issues.

Describe the bug

The pop_basis table is our largest table, and counts on it take significantly longer than other tables. Luckily we do not use counts on this table in our application code. But we do with l2_keystones, so if l2_keystones ever got into a similar state then counts would take too long.

Find out why counts are taking so long on pop_basis is it size? etc.

Expected behaviour

Counts on pop_basis should seem instant.

Environment

Version:
Operating System:
Architecture:

Additional Information

Here are the query plans for one of our replicas

bfg=# explain select count(*) from pop_basis;
                                          QUERY PLAN                                           
-----------------------------------------------------------------------------------------------
 Finalize Aggregate  (cost=770916.44..770916.45 rows=1 width=8)
   ->  Gather  (cost=770916.22..770916.43 rows=2 width=8)
         Workers Planned: 2
         ->  Partial Aggregate  (cost=769916.22..769916.23 rows=1 width=8)
               ->  Parallel Seq Scan on pop_basis  (cost=0.00..764483.58 rows=2173058 width=0)
 JIT:
   Functions: 4
   Options: Inlining true, Optimization true, Expressions true, Deforming true
(8 rows)

bfg=# select count(*) from btc_blocks;
 count 
-------
 58786
(1 row)

bfg=# explain select count(*) from btc_blocks;
                              QUERY PLAN                               
-----------------------------------------------------------------------
 Aggregate  (cost=1964.94..1964.95 rows=1 width=8)
   ->  Seq Scan on btc_blocks  (cost=0.00..1820.15 rows=57915 width=0)
(2 rows)

bfg=# explain select count(*) from l2_keystones;
                               QUERY PLAN                               
------------------------------------------------------------------------
 Aggregate  (cost=829.31..829.32 rows=1 width=8)
   ->  Seq Scan on l2_keystones  (cost=0.00..779.85 rows=19785 width=0)
(2 rows)

this could be due to parallel aggregation https://www.postgresql.org/docs/current/parallel-plans.html#PARALLEL-AGGREGATION

@ClaytonNorthey92 ClaytonNorthey92 added type: bug This is a bug status: triage This is awaiting review. Maintainers should this label once triaged area: bfg This is a change to BFG (Bitcoin Finality Governor) labels Aug 16, 2024
@ClaytonNorthey92 ClaytonNorthey92 self-assigned this Aug 16, 2024
@ClaytonNorthey92
Copy link
Contributor Author

actually L2KeystonesCount isn't even used, probably safe to delete

@ClaytonNorthey92
Copy link
Contributor Author

we don't count pop_basis so we can delete, we're removing SQL soon so this will likely not be relevant

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area: bfg This is a change to BFG (Bitcoin Finality Governor) status: triage This is awaiting review. Maintainers should this label once triaged type: bug This is a bug
Projects
None yet
Development

No branches or pull requests

1 participant