> On Aug 27, 2020, at 10:07 PM, Andrey M. Borodin <x4...@yandex-team.ru> wrote:
> 
> 
> 
>> 25 авг. 2020 г., в 19:36, Mark Dilger <mark.dil...@enterprisedb.com> 
>> написал(а):
> 
> Hi Mark!
> 
> Thanks for working on this important feature.
> 
> I was experimenting a bit with our internal heapcheck and found out that it's 
> not helping with truncated CLOG anyhow.
> Will your module be able to gather tid's of similar corruptions?
> 
> server/db M # select * from heap_check('pg_toast.pg_toast_4848601');
> ERROR:  58P01: could not access status of transaction 636558742
> DETAIL:  Could not open file "pg_xact/025F": No such file or directory.
> LOCATION:  SlruReportIOError, slru.c:913
> Time: 3439.915 ms (00:03.440)

The design principle for verify_heapam.c is, if the rest of the system is not 
corrupt, corruption in the table being checked should not cause a crash during 
the table check. This is a very limited principle.  Even corruption in the 
associated toast table or toast index could cause a crash.  That is why 
checking against the toast table is optional, and false by default.

Perhaps a more extensive effort could be made later.  I think it is out of 
scope for this release cycle.  It is a very interesting area for further 
research, though.

—
Mark Dilger
EnterpriseDB: http://www.enterprisedb.com
The Enterprise PostgreSQL Company





Reply via email to