| From: | Joel Jacobson <joel(at)gluefinance(dot)com> | 
|---|---|
| To: | Takahiro Itagaki <itagaki(dot)takahiro(at)oss(dot)ntt(dot)co(dot)jp> | 
| Cc: | pgsql-hackers(at)postgresql(dot)org | 
| Subject: | Re: pg_stat_transaction patch | 
| Date: | 2010-06-08 11:18:44 | 
| Message-ID: | AANLkTikSYdRwATGAP5U6O6zwIO4b_WNJXIbUd2y2tI01@mail.gmail.com | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-hackers | 
Hi Takahiro,
Here is an updated version of the patch.
Thanks Magnus H for the help :)
1.4: Ported to head. Updated tests. Removed pg_stat_report.
2010/5/25 Takahiro Itagaki <itagaki(dot)takahiro(at)oss(dot)ntt(dot)co(dot)jp>
>
> Joel Jacobson <joel(at)gluefinance(dot)com> wrote:
>
> > I applied all the changes on 9.0beta manually and then it compiled
> without
> > any assertion failures.
> >
> > I also changed the oids to a different unused range, since the ones I
> used
> > before had been taken in 9.0beta1.
>
> Thanks, but you still need to test your patch:
>
>  - You need to check your patch with "make check", because it requires
>   adjustments in "rule" test; Your pg_stat_transaction_function is the
>   longest name in the system catalog.
>
>  - You need to configure postgres with --enable-cassert to enable internal
>   varidations. The attached test case failed with the following TRAP.
> TRAP: FailedAssertion("!(entry->trans == ((void *)0))", File: "pgstat.c",
> Line: 715)
> TRAP: FailedAssertion("!(tabstat->trans == trans)", File: "pgstat.c", Line:
> 1758)
>
> > I suspect it is because get_tabstat_entry for some reason returns NULL,
> in
> > for example pg_stat_get_transaction_tuples_inserted(PG_FUNCTION_ARGS).
> >
> > Does the function look valid? If you can find the error in it, the other
> > functions probably have the same problem.
>
> For the above trap, we can see the comment:
>    /* Shouldn't have any pending transaction-dependent counts */
> We don't expect to read stats entries during transactions. I'm not sure
> whether accessing transitional stats during transaction is safe or not.
>
> We might need to go other directions, for example:
>  - Use "session stats" instead "transaction stats". You can see the same
>    information in difference of counters between before and after the
>    transaction.
>  - Export pgBufferUsage instead of relation counters. They are
>    buffer counters for all relations, but we can obviously export
>    them because they are just plain variables.
>
> Regards,
> ---
> Takahiro Itagaki
> NTT Open Source Software Center
>
>
>
-- 
Best regards,
Joel Jacobson
Glue Finance
E: jj(at)gluefinance(dot)com
T: +46 70 360 38 01
Postal address:
Glue Finance AB
Box  549
114 11  Stockholm
Sweden
Visiting address:
Glue Finance AB
Birger Jarlsgatan 14
114 34 Stockholm
Sweden
| Attachment | Content-Type | Size | 
|---|---|---|
| pg_stat_transaction-1.4.tar.gz | application/x-gzip | 14.0 KB | 
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Robert Haas | 2010-06-08 11:40:04 | Re: Parameters of GiST indexes | 
| Previous Message | P. Caillaud | 2010-06-08 10:12:43 | LLVM / clang |