Actions
Bug #14004
closedWasted disk space due to inefficient columns ordering
Status:
Rejected
Priority:
N/A
Assignee:
Category:
Performance and scalability
Target version:
Pull Request:
Severity:
UX impact:
User visibility:
Effort required:
Priority:
0
Name check:
Fix check:
Regression:
Description
According to https://blog.2ndquadrant.com/on-rocks-and-sand/ proper column ordering in Postgresql can save up to 10-20% of disk space
Given that Rudder uses quite a lot of free space, it would be relevant to benefit from this
Note that Postresql is so wonderful that it advertise which ordering is the best for a table:
rudder=> SELECT a.attname, t.typname, t.typalign, t.typlen rudder-> FROM pg_class c rudder-> JOIN pg_attribute a ON (a.attrelid = c.oid) rudder-> JOIN pg_type t ON (t.oid = a.atttypid) rudder-> WHERE c.relname = 'nodecompliancelevels' AND a.attnum >= 0 rudder-> ORDER BY t.typlen DESC; attname | typname | typalign | typlen --------------------+-------------+----------+-------- runtimestamp | timestamptz | d | 8 badpolicymode | int4 | i | 4 auditnotapplicable | int4 | i | 4 noncompliant | int4 | i | 4 auditerror | int4 | i | 4 pending | int4 | i | 4 success | int4 | i | 4 repaired | int4 | i | 4 error | int4 | i | 4 unexpected | int4 | i | 4 missing | int4 | i | 4 noanswer | int4 | i | 4 notapplicable | int4 | i | 4 reportsdisabled | int4 | i | 4 compliant | int4 | i | 4 ruleid | text | i | -1 directiveid | text | i | -1 nodeid | text | i | -1 (18 lignes)
this ticket will only update table creation and migration - we won't change existing tables
Updated by Nicolas CHARLES about 6 years ago
- Status changed from New to In progress
Updated by Nicolas CHARLES about 6 years ago
- Target version changed from 4.3.8 to 6.0.0~beta1
gain is not that obvious ...
oid | table_schema | table_name | row_estimate | total_bytes | index_bytes | toast_bytes | table_bytes | total | index | toast | table -------+--------------+-----------------------+--------------+-------------+-------------+-------------+-------------+--------+--------+------------+-------- 16524 | public | nodecompliancelevels | 1398 | 589824 | 368640 | 8192 | 212992 | 576 kB | 360 kB | 8192 bytes | 208 kB 25947 | public | nodecompliancelevels2 | 1398 | 589824 | 368640 | 8192 | 212992 | 576 kB | 360 kB | 8192 bytes | 208 kB
Updated by Nicolas CHARLES about 6 years ago
ok, with RudderSysEvents we do gain a bit (2%)
oid | table_schema | table_name | row_estimate | total_bytes | index_bytes | toast_bytes | table_bytes | total | index | toast | table -------+--------------+------------------+--------------+-------------+-------------+-------------+-------------+---------+---------+------------+--------- 16412 | public | ruddersysevents | 17258 | 7921664 | 3801088 | 8192 | 4112384 | 7736 kB | 3712 kB | 8192 bytes | 4016 kB 26008 | public | ruddersysevents2 | 17258 | 7790592 | 3768320 | 8192 | 4014080 | 7608 kB | 3680 kB | 8192 bytes | 3920 kB
Updated by Nicolas CHARLES about 6 years ago
- Status changed from In progress to Pending technical review
- Assignee changed from Nicolas CHARLES to François ARMAND
- Pull Request set to https://github.com/Normation/rudder/pull/2099
Updated by Nicolas CHARLES about 6 years ago
- Status changed from Pending technical review to Rejected
Actions