Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On Thu, Sep 14, 2017 at 11:00 PM, Craig Ringer wrote: > On 14 September 2017 at 19:57, Ashutosh Sharma > wrote: > >> >> >> Are you planning to work on the review comments from Robert, Moon >> Insung and supply the new patch. I just had a quick glance into this >> mail thread (after a long time) and could understand Robert's concern >> till some extent. I think, he is trying to say that if a tuple is >> frozen (committed|invalid) then it shouldn't be shown as COMMITTED and >> INVALID together in fact it should just be displayed as FROZEN tuple. > > > Yes, I'd like to, and should have time for it in this CF. > > My plan is to emit raw flags by default, so FROZEN would't be shown at all, > only COMMITTED|INVALID. If the bool to decode combined flags is set, then > it'll show things like FROZEN, and hide COMMITTED|INVALID. Similar for other > combos. > FWIW, I agree with this direction. ISTM the showing the raw flags by default and having an option to show combined flags would be a right way. I sometimes wanted to have the same mechanism for lp_flags but maybe it should be discussed on a separated thread. Regards, -- Masahiko Sawada NIPPON TELEGRAPH AND TELEPHONE CORPORATION NTT Open Source Software Center -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On Sat, Oct 14, 2017 at 2:47 PM, Peter Geoghegan wrote: > I am working on an experimental version of pg_filedump, customized to > output XML that can be interpreted by an open source hex editor. The > XML makes the hex editor produce color coded, commented > tags/annotations for any given heap or B-Tree relation. This includes > tooltips with literal values for all status bits (including > t_infomask/t_infomask2 bits, IndexTuple bits, B-Tree meta page status > bits, PD_* page-level bits, ItemId bits, and others). This is now available from: https://github.com/petergeoghegan/pg_hexedit -- Peter Geoghegan -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On 10/14/2017 11:47 PM, Peter Geoghegan wrote: > On Sat, Oct 14, 2017 at 10:58 AM, Robert Haas wrote: >> I think it's perfectly sensible to view those 2 bits as making up a >> 2-bit field with 4 states rather than displaying each bit >> individually, but you obviously disagree. Fair enough.> > I guess it is that simple. FWIW, my opinion falls in line with Robert's. Also, whichever way it goes, this is a patch I've been wanting for a long time. -- Vik Fearing +33 6 46 75 15 36 http://2ndQuadrant.fr PostgreSQL : Expertise, Formation et Support -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On Sat, Oct 14, 2017 at 10:58 AM, Robert Haas wrote: > I think it's perfectly sensible to view those 2 bits as making up a > 2-bit field with 4 states rather than displaying each bit > individually, but you obviously disagree. Fair enough. I guess it is that simple. > I can think of two possible explanations for that. Number one, the > tool was written before HEAP_XMIN_FROZEN was invented and hasn't been > updated for those changes. Have we invented our last t_infomask/t_infomask2 (logical) status already? > Number two, the author of the tool agrees > with your position rather than mine. I am working on an experimental version of pg_filedump, customized to output XML that can be interpreted by an open source hex editor. The XML makes the hex editor produce color coded, commented tags/annotations for any given heap or B-Tree relation. This includes tooltips with literal values for all status bits (including t_infomask/t_infomask2 bits, IndexTuple bits, B-Tree meta page status bits, PD_* page-level bits, ItemId bits, and others). I tweeted about this several months ago, when it was just a tool I wrote for myself, and received a surprisingly positive response. It seems like I'm on to something, and should release the tool to the community. I mention this project because it very much informs my perspective here. Having spent quite a while deliberately corrupting test data in novel ways, just to see what happens, the "work backwards from the storage format" perspective feels very natural to me. I do think that I understand where you're coming from too, though. -- Peter Geoghegan -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On Fri, Oct 13, 2017 at 4:36 PM, Peter Geoghegan wrote: > No, I'm arguing that they're just bits. Show the bits, rather than > interpreting what is displayed. Document that there are other logical > states that are represented as composites of contradictory/mutually > exclusive states. /me shrugs. I think it's perfectly sensible to view those 2 bits as making up a 2-bit field with 4 states rather than displaying each bit individually, but you obviously disagree. Fair enough. >> I guess it ends wherever we decide to stop. > > You can take what you're saying much further. What about > HEAP_XMAX_SHR_LOCK, and HEAP_MOVED? Code like HEAP_LOCKED_UPGRADED() > pretty strongly undermines the idea that these composite values are > abstractions. HEAP_MOVED is obviously a different kind of thing. The combination of both bits has no meaning distinct from the meaning of the individual bits; in fact, I think it's a shouldn't-happen state. Not sure about HEAP_XMAX_SHR_LOCK. > pg_filedump doesn't display HEAP_XMIN_FROZEN, either. (Nor does it > ever display any of the other composite t_infomask/t_infomask2 > values.) I can think of two possible explanations for that. Number one, the tool was written before HEAP_XMIN_FROZEN was invented and hasn't been updated for those changes. Number two, the author of the tool agrees with your position rather than mine. -- Robert Haas EnterpriseDB: http://www.enterprisedb.com The Enterprise PostgreSQL Company -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On Fri, Oct 13, 2017 at 1:02 PM, Robert Haas wrote: >> I don't think it's our place to "interpret" the bits. Are we *also* >> going to show HEAP_XMIN_FROZEN when xmin is physically set to >> FrozenTransactionId? > > No, of course not. We're talking about how to display the 256 and 512 > bits of t_infomask. Those have four states: nothing, committed, > invalid, frozen. You're arguing that frozen isn't a real state, that > it's somehow just a combination of committed and invalid, but I think > that's the wrong way of thinking about it. No, I'm arguing that they're just bits. Show the bits, rather than interpreting what is displayed. Document that there are other logical states that are represented as composites of contradictory/mutually exclusive states. Anyone who hopes to interpret these values has to be an expert anyway, or willing to become something of an expert. There is a good chance that they've taken an interest because something is already wrong. > Before HEAP_XMIN_FROZEN existed, it would have been right to display > the state where both bits are set as committed|invalid, because that > would clearly show you that two things had been set that should never > both be set at the same time. But now that's a valid state with a > well-defined meaning and I think we should display the actual meaning > of that state. > >> Where does it end? > > I guess it ends wherever we decide to stop. You can take what you're saying much further. What about HEAP_XMAX_SHR_LOCK, and HEAP_MOVED? Code like HEAP_LOCKED_UPGRADED() pretty strongly undermines the idea that these composite values are abstractions. >> I think that we should prominently document that HEAP_XMIN_COMMITTED >> |HEAP_XMIN_ABORTED == HEAP_XMIN_FROZEN, rather than trying to hide >> complexity that we have no business hiding in a tool like pageinspect. > > I respect that opinion, but I don't think I'm trying to hide anything. > I think I'm proposing that we display the information in what I > believed to be the clearest and most accurate way. pg_filedump doesn't display HEAP_XMIN_FROZEN, either. (Nor does it ever display any of the other composite t_infomask/t_infomask2 values.) -- Peter Geoghegan -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On Thu, Oct 12, 2017 at 7:35 PM, Peter Geoghegan wrote: > On Tue, Aug 15, 2017 at 10:54 AM, Robert Haas wrote: >>> Or at least make the filtering optional. >> >> I don't think "filtering" is the right way to think about it. It's >> just labeling each combination of bits with the meaning appropriate to >> that combination of bits. > > I do. -1 to not just showing what's on the page -- if the > HEAP_XMIN_COMMITTED and HEAP_XMIN_ABORTED bits are set, then I think > we should show them. Yeah, I accept that there is a real danger of > confusing people with that. Unfortunately, I think that displaying > HEAP_XMIN_FROZEN will cause even more confusion. I don't think that > HEAP_XMIN_FROZEN is an abstraction at all. It's a notational > convenience. Well, *I* think that HEAP_XMIN_FROZEN is an abstraction. That's why we have #define -- to help us create abstractions. > I don't think it's our place to "interpret" the bits. Are we *also* > going to show HEAP_XMIN_FROZEN when xmin is physically set to > FrozenTransactionId? No, of course not. We're talking about how to display the 256 and 512 bits of t_infomask. Those have four states: nothing, committed, invalid, frozen. You're arguing that frozen isn't a real state, that it's somehow just a combination of committed and invalid, but I think that's the wrong way of thinking about it. When the 256-bit is clear, the 512-bit tells you whether the xmin is known invalid, but when the 256-bit is set, the 512-bit tells you whether the tuple is also frozen. Before HEAP_XMIN_FROZEN existed, it would have been right to display the state where both bits are set as committed|invalid, because that would clearly show you that two things had been set that should never both be set at the same time. But now that's a valid state with a well-defined meaning and I think we should display the actual meaning of that state. > Where does it end? I guess it ends wherever we decide to stop. This isn't some kind of crazy slippery slope we're talking about here, where one day we're labeling informask bits and the next day it's global thermonuclear war. > I think that we should prominently document that HEAP_XMIN_COMMITTED > |HEAP_XMIN_ABORTED == HEAP_XMIN_FROZEN, rather than trying to hide > complexity that we have no business hiding in a tool like pageinspect. I respect that opinion, but I don't think I'm trying to hide anything. I think I'm proposing that we display the information in what I believed to be the clearest and most accurate way. -- Robert Haas EnterpriseDB: http://www.enterprisedb.com The Enterprise PostgreSQL Company -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On Tue, Aug 15, 2017 at 10:54 AM, Robert Haas wrote: >> Or at least make the filtering optional. > > I don't think "filtering" is the right way to think about it. It's > just labeling each combination of bits with the meaning appropriate to > that combination of bits. I do. -1 to not just showing what's on the page -- if the HEAP_XMIN_COMMITTED and HEAP_XMIN_ABORTED bits are set, then I think we should show them. Yeah, I accept that there is a real danger of confusing people with that. Unfortunately, I think that displaying HEAP_XMIN_FROZEN will cause even more confusion. I don't think that HEAP_XMIN_FROZEN is an abstraction at all. It's a notational convenience. I don't think it's our place to "interpret" the bits. Are we *also* going to show HEAP_XMIN_FROZEN when xmin is physically set to FrozenTransactionId? Where does it end? I think that we should prominently document that HEAP_XMIN_COMMITTED |HEAP_XMIN_ABORTED == HEAP_XMIN_FROZEN, rather than trying to hide complexity that we have no business hiding in a tool like pageinspect. -- Peter Geoghegan -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On 14 September 2017 at 19:57, Ashutosh Sharma wrote: > > Are you planning to work on the review comments from Robert, Moon > Insung and supply the new patch. I just had a quick glance into this > mail thread (after a long time) and could understand Robert's concern > till some extent. I think, he is trying to say that if a tuple is > frozen (committed|invalid) then it shouldn't be shown as COMMITTED and > INVALID together in fact it should just be displayed as FROZEN tuple. Yes, I'd like to, and should have time for it in this CF. My plan is to emit raw flags by default, so FROZEN would't be shown at all, only COMMITTED|INVALID. If the bool to decode combined flags is set, then it'll show things like FROZEN, and hide COMMITTED|INVALID. Similar for other combos. -- Craig Ringer http://www.2ndQuadrant.com/ PostgreSQL Development, 24x7 Support, Training & Services
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
Hi Craig, On Thu, Aug 17, 2017 at 5:50 AM, Craig Ringer wrote: > On 16 August 2017 at 23:14, Robert Haas wrote: >> >> On Tue, Aug 15, 2017 at 4:36 PM, Tomas Vondra >> wrote: >> > You might say that people investigating issues in this area of code >> > should >> > be aware of how HEAP_XMIN_FROZEN is defined, and perhaps you're right >> > ... >> >> Yes, I think that's what I would say. I mean, if you happen to NOT >> know that committed|invalid == frozen, but you DO know what committed >> means and what invalid means, then you're going to be *really* >> confused when you see committed and invalid set on the same tuple. >> Showing you frozen has got to be clearer. >> >> Now, I agree with you that a test like (enumval_tup->t_data & >> HEAP_XMIN_COMMITTED) could be confusing to someone who doesn't realize >> that HEAP_XMIN_FROZEN & HEAP_XMIN_COMMITTED == HEAP_XMIN_COMMITTED, >> but I think that's just one of those things that unfortunately is >> going to require adequate knowledge for people investigating issues. >> If there's an action item there, it might be to try to come up with a >> way to make the source code clearer. >> > > For other multi-purpose flags we have macros, and I think it'd make sense to > use them here too. > > Eschew direct use of HEAP_XMIN_COMMITTED, HEAP_XMIN_INVALID and > HEAP_XMIN_FROZEN in tests. Instead, consistently use HeapXminIsFrozen(), > HeapXminIsCommitted(), and HeapXminIsInvalid() or something like that. > > -- Are you planning to work on the review comments from Robert, Moon Insung and supply the new patch. I just had a quick glance into this mail thread (after a long time) and could understand Robert's concern till some extent. I think, he is trying to say that if a tuple is frozen (committed|invalid) then it shouldn't be shown as COMMITTED and INVALID together in fact it should just be displayed as FROZEN tuple. -- With Regards, Ashutosh Sharma EnterpriseDB:http://www.enterprisedb.com -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On 16 August 2017 at 23:14, Robert Haas wrote: > On Tue, Aug 15, 2017 at 4:36 PM, Tomas Vondra > wrote: > > You might say that people investigating issues in this area of code > should > > be aware of how HEAP_XMIN_FROZEN is defined, and perhaps you're right ... > > Yes, I think that's what I would say. I mean, if you happen to NOT > know that committed|invalid == frozen, but you DO know what committed > means and what invalid means, then you're going to be *really* > confused when you see committed and invalid set on the same tuple. > Showing you frozen has got to be clearer. > > Now, I agree with you that a test like (enumval_tup->t_data & > HEAP_XMIN_COMMITTED) could be confusing to someone who doesn't realize > that HEAP_XMIN_FROZEN & HEAP_XMIN_COMMITTED == HEAP_XMIN_COMMITTED, > but I think that's just one of those things that unfortunately is > going to require adequate knowledge for people investigating issues. > If there's an action item there, it might be to try to come up with a > way to make the source code clearer. > > For other multi-purpose flags we have macros, and I think it'd make sense to use them here too. Eschew direct use of HEAP_XMIN_COMMITTED, HEAP_XMIN_INVALID and HEAP_XMIN_FROZEN in tests. Instead, consistently use HeapXminIsFrozen(), HeapXminIsCommitted(), and HeapXminIsInvalid() or something like that. -- Craig Ringer http://www.2ndQuadrant.com/ PostgreSQL Development, 24x7 Support, Training & Services
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On Tue, Aug 15, 2017 at 4:36 PM, Tomas Vondra wrote: > You might say that people investigating issues in this area of code should > be aware of how HEAP_XMIN_FROZEN is defined, and perhaps you're right ... Yes, I think that's what I would say. I mean, if you happen to NOT know that committed|invalid == frozen, but you DO know what committed means and what invalid means, then you're going to be *really* confused when you see committed and invalid set on the same tuple. Showing you frozen has got to be clearer. Now, I agree with you that a test like (enumval_tup->t_data & HEAP_XMIN_COMMITTED) could be confusing to someone who doesn't realize that HEAP_XMIN_FROZEN & HEAP_XMIN_COMMITTED == HEAP_XMIN_COMMITTED, but I think that's just one of those things that unfortunately is going to require adequate knowledge for people investigating issues. If there's an action item there, it might be to try to come up with a way to make the source code clearer. -- Robert Haas EnterpriseDB: http://www.enterprisedb.com The Enterprise PostgreSQL Company -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On 16 August 2017 at 03:42, Tomas Vondra wrote: > > > On 08/15/2017 07:54 PM, Robert Haas wrote: > >> On Tue, Aug 15, 2017 at 9:59 AM, Tomas Vondra >> wrote: >> >>> I don't think so -- the "committed" and "invalid" meanings are effectively canceled when the "frozen" mask is present. I mean, "committed" and "invalid" contradict each other... >>> >>> FWIW I agree with Craig - the functions should output the masks raw, >>> without >>> any filtering. The reason is that when you're investigating data >>> corruption >>> or unexpected behavior, all this is very useful when reasoning about what >>> might (not) have happened. >>> >>> Or at least make the filtering optional. >>> >> >> I don't think "filtering" is the right way to think about it. It's >> just labeling each combination of bits with the meaning appropriate to >> that combination of bits. >> >> I mean, if you were displaying the contents of a CLOG entry, would you >> want the value 3 to be displayed as COMMITTED ABORTED SUBCOMMITTED >> because TRANSACTION_STATUS_COMMITTED|TRANSACTION_STATUS_ABORTED == >> TRANSACTION_STATUS_SUB_COMMITTED? >> >> I realize that you may be used to thinking of the HEAP_XMIN_COMMITTED >> and HEAP_XMAX_COMMITTED bits as two separate bits, but that's not >> really true any more. They're a 2-bit field that can have one of four >> values: committed, aborted, frozen, or none of the above. >> >> > All I'm saying is that having the complete information (knowing which bits > are actually set in the bitmask) is valuable when reasoning about how you > might have gotten to the current state. Which I think is what Craig is > after. > > What I think we should not do is interpret the bitmasks (omitting some of > the information) assuming all the bits were set correctly. I agree, and the patch already does half of this: it can output just the raw bit flags, or it can interpret them to show HEAP_XMIN_FROZEN etc. So the required change, which seems to have broad agreement, is to have the "interpret the bits" mode show only HEAP_XMIN_FROZEN when it sees HEAP_XMIN_COMMITTED|HEAP_XMIN_INVALID, etc. We can retain raw-flags output as-is for when seriously bogus state is suspected. Any takers? -- Craig Ringer http://www.2ndQuadrant.com/ PostgreSQL Development, 24x7 Support, Training & Services
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
I checked for code related to infomask. (add flag state -- HEAP_XMIN_COMMITTED, HEAP_XMIN_INVALID, HEAP_XMIN_FROZEN) first i'm still beginner level about postgresql, so my opinion may be wrong. if the "HEAP_XMIN_COMMITTED" flag is added, check the function of "HeapTupleHeaderXminInvalid" if the "HEAP_XMIN_INVALID" flag is added, check the function of "HeapTupleHeaderXminCommitted" if the "HEAP_XMIN_FROZEN" flag is added, use the "HeapTupleHeaderSetXminFrozen" function or use the code as -- xid = HeapTupleHeaderGetXmin(tuple); if (TransactionIdIsNormal(xid)) { if (TransactionIdPrecedes(xid, cutoff_xid)) { frz->t_infomask |= HEAP_XMIN_FROZEN; changed = true; } else totally_frozen = false; } -- to add the flag. so as a result, HEAP_XMIN_INVALID and HEAP_XMIN_COMMITTED is cannot coexist. unfortunately, i don't know if HEAP_XMIN_COMMITTED and HEAP_XMIN_FROZEN flags can coexist. so i think it's also a good idea to output the raw masks, without any filtering. however, i think the information that is presented to the user should inform us which flags was entered. Regards. Moon > -Original Message- > From: pgsql-hackers-ow...@postgresql.org > [mailto:pgsql-hackers-ow...@postgresql.org] On Behalf Of Tomas Vondra > Sent: Wednesday, August 16, 2017 5:36 AM > To: Robert Haas > Cc: pgsql-hackers@postgresql.org > Subject: Re: [HACKERS] [PATCH] pageinspect function to decode infomasks > > > > On 08/15/2017 09:55 PM, Robert Haas wrote: > > On Tue, Aug 15, 2017 at 3:42 PM, Tomas Vondra > > wrote: > >> What I think we should not do is interpret the bitmasks (omitting > >> some of the information) assuming all the bits were set correctly. > > > > I'm still confused. HEAP_XMIN_COMMITTED|HEAP_XMIN_ABORTED == > > HEAP_XMIN_FROZEN. Nobody is proposing to omit anything; to the > > contrary, what's being proposed is not to display the same thing twice > > (and in a misleading fashion, to boot). > > > > I understand your point. Assume you're looking at this bit of code: > > if (HeapTupleHeaderXminCommitted(enumval_tup->t_data)) > return; > > which is essentially > > if (enumval_tup->t_data & HEAP_XMIN_COMMITTED) > return; > > If the function only gives you HEAP_XMIN_FROZEN, how likely is it you miss > this actually evaluates as true? > > You might say that people investigating issues in this area of code should > be aware of how HEAP_XMIN_FROZEN is defined, and perhaps you're right ... > > regards > > -- > Tomas Vondra http://www.2ndQuadrant.com > PostgreSQL Development, 24x7 Support, Remote DBA, Training & Services > > > -- > Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make > changes to your subscription: > http://www.postgresql.org/mailpref/pgsql-hackers -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On 08/15/2017 09:55 PM, Robert Haas wrote: On Tue, Aug 15, 2017 at 3:42 PM, Tomas Vondra wrote: What I think we should not do is interpret the bitmasks (omitting some of the information) assuming all the bits were set correctly. I'm still confused. HEAP_XMIN_COMMITTED|HEAP_XMIN_ABORTED == HEAP_XMIN_FROZEN. Nobody is proposing to omit anything; to the contrary, what's being proposed is not to display the same thing twice (and in a misleading fashion, to boot). I understand your point. Assume you're looking at this bit of code: if (HeapTupleHeaderXminCommitted(enumval_tup->t_data)) return; which is essentially if (enumval_tup->t_data & HEAP_XMIN_COMMITTED) return; If the function only gives you HEAP_XMIN_FROZEN, how likely is it you miss this actually evaluates as true? You might say that people investigating issues in this area of code should be aware of how HEAP_XMIN_FROZEN is defined, and perhaps you're right ... regards -- Tomas Vondra http://www.2ndQuadrant.com PostgreSQL Development, 24x7 Support, Remote DBA, Training & Services -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On Tue, Aug 15, 2017 at 3:42 PM, Tomas Vondra wrote: > What I think we should not do is interpret the bitmasks (omitting some of > the information) assuming all the bits were set correctly. I'm still confused. HEAP_XMIN_COMMITTED|HEAP_XMIN_ABORTED == HEAP_XMIN_FROZEN. Nobody is proposing to omit anything; to the contrary, what's being proposed is not to display the same thing twice (and in a misleading fashion, to boot). -- Robert Haas EnterpriseDB: http://www.enterprisedb.com The Enterprise PostgreSQL Company -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On 08/15/2017 07:54 PM, Robert Haas wrote: On Tue, Aug 15, 2017 at 9:59 AM, Tomas Vondra wrote: I don't think so -- the "committed" and "invalid" meanings are effectively canceled when the "frozen" mask is present. I mean, "committed" and "invalid" contradict each other... FWIW I agree with Craig - the functions should output the masks raw, without any filtering. The reason is that when you're investigating data corruption or unexpected behavior, all this is very useful when reasoning about what might (not) have happened. Or at least make the filtering optional. I don't think "filtering" is the right way to think about it. It's just labeling each combination of bits with the meaning appropriate to that combination of bits. I mean, if you were displaying the contents of a CLOG entry, would you want the value 3 to be displayed as COMMITTED ABORTED SUBCOMMITTED because TRANSACTION_STATUS_COMMITTED|TRANSACTION_STATUS_ABORTED == TRANSACTION_STATUS_SUB_COMMITTED? I realize that you may be used to thinking of the HEAP_XMIN_COMMITTED and HEAP_XMAX_COMMITTED bits as two separate bits, but that's not really true any more. They're a 2-bit field that can have one of four values: committed, aborted, frozen, or none of the above. All I'm saying is that having the complete information (knowing which bits are actually set in the bitmask) is valuable when reasoning about how you might have gotten to the current state. Which I think is what Craig is after. What I think we should not do is interpret the bitmasks (omitting some of the information) assuming all the bits were set correctly. regards -- Tomas Vondra http://www.2ndQuadrant.com PostgreSQL Development, 24x7 Support, Remote DBA, Training & Services -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On Tue, Aug 15, 2017 at 9:59 AM, Tomas Vondra wrote: >> I don't think so -- the "committed" and "invalid" meanings are >> effectively canceled when the "frozen" mask is present. >> >> I mean, "committed" and "invalid" contradict each other... > > FWIW I agree with Craig - the functions should output the masks raw, without > any filtering. The reason is that when you're investigating data corruption > or unexpected behavior, all this is very useful when reasoning about what > might (not) have happened. > > Or at least make the filtering optional. I don't think "filtering" is the right way to think about it. It's just labeling each combination of bits with the meaning appropriate to that combination of bits. I mean, if you were displaying the contents of a CLOG entry, would you want the value 3 to be displayed as COMMITTED ABORTED SUBCOMMITTED because TRANSACTION_STATUS_COMMITTED|TRANSACTION_STATUS_ABORTED == TRANSACTION_STATUS_SUB_COMMITTED? I realize that you may be used to thinking of the HEAP_XMIN_COMMITTED and HEAP_XMAX_COMMITTED bits as two separate bits, but that's not really true any more. They're a 2-bit field that can have one of four values: committed, aborted, frozen, or none of the above. -- Robert Haas EnterpriseDB: http://www.enterprisedb.com The Enterprise PostgreSQL Company -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On Tue, Aug 15, 2017 at 10:59 PM, Tomas Vondra wrote: > > > On 08/15/2017 03:24 PM, Robert Haas wrote: >> >> On Mon, Aug 14, 2017 at 9:59 PM, Craig Ringer >> wrote: >>> >>> The bits are set, those macros just test to exclude the special meaning >>> of >>> both bits being set at once to mean "frozen". >>> >>> I was reluctant to filter out HEAP_XMIN_COMMITTED and HEAP_XMIN_INVALID >>> when we detect that it's frozen, because that could well be misleading >>> when >>> debugging. >> >> >> I don't think so -- the "committed" and "invalid" meanings are >> effectively canceled when the "frozen" mask is present. >> >> I mean, "committed" and "invalid" contradict each other... >> > > FWIW I agree with Craig - the functions should output the masks raw, without > any filtering. The reason is that when you're investigating data corruption > or unexpected behavior, all this is very useful when reasoning about what > might (not) have happened. > > Or at least make the filtering optional. > I'd vote for having both and making one optional (perhaps filtering?). Both are useful to me for the debugging and study purpose. Regards, -- Masahiko Sawada NIPPON TELEGRAPH AND TELEPHONE CORPORATION NTT Open Source Software Center -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On 08/15/2017 03:24 PM, Robert Haas wrote: On Mon, Aug 14, 2017 at 9:59 PM, Craig Ringer wrote: The bits are set, those macros just test to exclude the special meaning of both bits being set at once to mean "frozen". I was reluctant to filter out HEAP_XMIN_COMMITTED and HEAP_XMIN_INVALID when we detect that it's frozen, because that could well be misleading when debugging. I don't think so -- the "committed" and "invalid" meanings are effectively canceled when the "frozen" mask is present. I mean, "committed" and "invalid" contradict each other... FWIW I agree with Craig - the functions should output the masks raw, without any filtering. The reason is that when you're investigating data corruption or unexpected behavior, all this is very useful when reasoning about what might (not) have happened. Or at least make the filtering optional. regards -- Tomas Vondra http://www.2ndQuadrant.com PostgreSQL Development, 24x7 Support, Remote DBA, Training & Services -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On Mon, Aug 14, 2017 at 9:59 PM, Craig Ringer wrote: > The bits are set, those macros just test to exclude the special meaning of > both bits being set at once to mean "frozen". > > I was reluctant to filter out HEAP_XMIN_COMMITTED and HEAP_XMIN_INVALID > when we detect that it's frozen, because that could well be misleading when > debugging. I don't think so -- the "committed" and "invalid" meanings are effectively canceled when the "frozen" mask is present. I mean, "committed" and "invalid" contradict each other... -- Robert Haas EnterpriseDB: http://www.enterprisedb.com The Enterprise PostgreSQL Company -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On 15 August 2017 at 09:11, Moon Insung wrote: > Dear Craig Ringer > > > > Frist, thank you for implementing the necessary function. > > > > but, i have some question. > > > > question 1) vacuum freeze hint bits > > If run a vacuum freeze, bits in the infomask will be 0x0300. > > in this case, if output the value of informsk in the run to you modified, > > HEAP_XMIN_COMMITTED(0x0100), HEAP_XMIN_INVALID(0x0200), > HEAP_XMIN_FROZEN(0x0300) > > all outputs to hint bits. > > > > is it normal to output values? > > > > if look at htup_details.h code, > > > > #define HeapTupleHeaderXminInvalid(tup) \ > > ( \ > > ((tup)->t_infomask & (HEAP_XMIN_COMMITTED|HEAP_XMIN_INVALID)) > == \ > > HEAP_XMIN_INVALID \ > > ) > > #define HeapTupleHeaderSetXminCommitted(tup) \ > > ( \ > > AssertMacro(!HeapTupleHeaderXminInvalid(tup)), \ > > ((tup)->t_infomask |= HEAP_XMIN_COMMITTED) \ > > ) > > > > HEAP_XMIN_INVALID and HEAP_XMIN_COMMITTED can not be write simultaneously. > The bits are set, those macros just test to exclude the special meaning of both bits being set at once to mean "frozen". I was reluctant to filter out HEAP_XMIN_COMMITTED and HEAP_XMIN_INVALID when we detect that it's frozen, because that could well be misleading when debugging. If you think that is useful, then I suggest you add an option so that when it's outputting the interpreted mask not the raw mask, it suppresses output of HEAP_XMIN_COMMITTED and HEAP_XMIN_INVALID if HEAP_XMIN_FROZEN. question 2) xmax lock hint bits > > similar to the vacuum freezeze question.. > > Assume that the infomask has a bit of 0x0050 > > > > In this case, if run on the code that you modified, > > HEAP_XMAX_KEYSHR_LOCK(0x0010), HEAP_XMAX_EXCL_LOCK(0x0040), > HEAP_XMAX_IS_LOCKED_ONLY > > three hint bits are the output. > > > > if look at htup_details.h code, > > > > #define HEAP_XMAX_IS_SHR_LOCKED(infomask) \ > > (((infomask) & HEAP_LOCK_MASK) == HEAP_XMAX_SHR_LOCK) > > #define HEAP_XMAX_IS_EXCL_LOCKED(infomask) \ > > (((infomask) & HEAP_LOCK_MASK) == HEAP_XMAX_EXCL_LOCK) > > #define HEAP_XMAX_IS_KEYSHR_LOCKED(infomask) \ > > (((infomask) & HEAP_LOCK_MASK) == HEAP_XMAX_KEYSHR_LOCK) > > > > It is divided into to hint bits. > > so I think this part needs to fix. > It's the same issue as above, with the same answer IMO. If we're showing the raw mask bits we should show the raw mask bits only. But if we're showing combined bits and masks too, I guess we should filter out the raw bits when matched by some mask. I'm not entirely convinced by that, since I think hiding information could create more confusion than it fixes. I welcome others' views here. -- Craig Ringer http://www.2ndQuadrant.com/ PostgreSQL Development, 24x7 Support, Training & Services
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
Dear Craig Ringer Frist, thank you for implementing the necessary function. but, i have some question. question 1) vacuum freeze hint bits If run a vacuum freeze, bits in the infomask will be 0x0300. in this case, if output the value of informsk in the run to you modified, HEAP_XMIN_COMMITTED(0x0100), HEAP_XMIN_INVALID(0x0200), HEAP_XMIN_FROZEN(0x0300) all outputs to hint bits. is it normal to output values? if look at htup_details.h code, #define HeapTupleHeaderXminInvalid(tup) \ ( \ ((tup)->t_infomask & (HEAP_XMIN_COMMITTED|HEAP_XMIN_INVALID)) == \ HEAP_XMIN_INVALID \ ) #define HeapTupleHeaderSetXminCommitted(tup) \ ( \ AssertMacro(!HeapTupleHeaderXminInvalid(tup)), \ ((tup)->t_infomask |= HEAP_XMIN_COMMITTED) \ ) HEAP_XMIN_INVALID and HEAP_XMIN_COMMITTED can not be write simultaneously. So I think the value of 0x0300 is to HEAP_XMIN_COMMITTED, HEAP_XMIN_FROZEN Only output needs to be values. question 2) xmax lock hint bits similar to the vacuum freezeze question.. Assume that the infomask has a bit of 0x0050 In this case, if run on the code that you modified, HEAP_XMAX_KEYSHR_LOCK(0x0010), HEAP_XMAX_EXCL_LOCK(0x0040), HEAP_XMAX_IS_LOCKED_ONLY three hint bits are the output. if look at htup_details.h code, #define HEAP_XMAX_IS_SHR_LOCKED(infomask) \ (((infomask) & HEAP_LOCK_MASK) == HEAP_XMAX_SHR_LOCK) #define HEAP_XMAX_IS_EXCL_LOCKED(infomask) \ (((infomask) & HEAP_LOCK_MASK) == HEAP_XMAX_EXCL_LOCK) #define HEAP_XMAX_IS_KEYSHR_LOCKED(infomask) \ (((infomask) & HEAP_LOCK_MASK) == HEAP_XMAX_KEYSHR_LOCK) It is divided into to hint bits. so I think this part needs to fix. If my opinion may be wrong. So plz check one more time. Regards. Moon From: pgsql-hackers-ow...@postgresql.org [mailto:pgsql-hackers-ow...@postgresql.org] On Behalf Of Craig Ringer Sent: Thursday, July 20, 2017 8:53 PM To: Ashutosh Sharma Cc: PostgreSQL Hackers; Julien Rouhaud; Pavan Deolasee; Álvaro Herrera; Peter Eisentraut; Masahiko Sawada; abhijit Menon-Sen; Peter Geoghegan Subject: Re: [HACKERS] [PATCH] pageinspect function to decode infomasks On 20 Jul. 2017 19:09, "Ashutosh Sharma" mailto:ashu.coe...@gmail.com> > wrote: I had a quick look into this patch and also tested it and following are my observations. Thanks very much. I'll expand the tests to cover various normal and nonsensical masks and combinations and fix the identified issues. This was a quick morning's work in amongst other things so not surprised I missed a few details. The check is appreciated.
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On 20 July 2017 at 19:09, Ashutosh Sharma wrote: > I had a quick look into this patch and also tested it and following > are my observations. > > 1) I am seeing a server crash when passing any non meaningful value > for t_infomask2 to heap_infomask_flags(). > > postgres=# SELECT heap_infomask_flags(2816, 3); > server closed the connection unexpectedly > This probably means the server terminated abnormally > before or while processing the request. > The connection to the server was lost. Attempting reset: Failed. > !> \q > > Following is the backtrace, > > (gdb) bt > #0 0x00d9c55b in pg_detoast_datum (datum=0x0) at fmgr.c:1833 > #1 0x00b87374 in construct_md_array (elems=0x2ad74c0, > nulls=0x0, ndims=1, dims=0x7ffc0b0bbcd0, lbs=0x7ffc0b0bbcc0, > elmtype=25, elmlen=-1, > elmbyval=0 '\000', elmalign=105 'i') at arrayfuncs.c:3382 > #2 0x00b8709f in construct_array (elems=0x2ad74c0, nelems=10, > elmtype=25, elmlen=-1, elmbyval=0 '\000', elmalign=105 'i') at > arrayfuncs.c:3316 > #3 0x7fb8001603a5 in heap_infomask_flags (fcinfo=0x2ad3b88) at > heapfuncs.c:597 > Fixed. > 2) I can see the documentation for heap_infomask(). But, I do not see > it being defined or used anywhere in the patch. > > + > + The heap_infomask function can be used to > unpack the > + recognised bits of the infomasks of heap tuples. > + > Fixed. Renamed the function, missed a spot. > 3) If show_combined flag is set to it's default value and a tuple is > frozen then may i know the reason for not showing it as frozen tuple > when t_infomask2 > is passed as zero. It was a consequence of (1). Fixed. > 4) I think, it would be better to use the same argument name for the > newly added function i.e heap_infomask_flags() in both documentation > and sql file. I am basically refering to 'include_combined' argument. > IF you see the function definition, the argument name used is > 'include_combined' whereas in documentation you have mentioned > 'show_combined'. > Fixed, thanks. I want to find time to expand the tests on this some more and look more closely, but here it is for now. -- Craig Ringer http://www.2ndQuadrant.com/ PostgreSQL Development, 24x7 Support, Training & Services From a25c1e50e3b3ff493a018ab594a71dc3d64832ee Mon Sep 17 00:00:00 2001 From: Craig Ringer Date: Thu, 20 Jul 2017 11:20:21 +0800 Subject: [PATCH v2] Introduce heap_infomask_flags to decode infomask and infomask2 --- contrib/pageinspect/Makefile | 3 +- contrib/pageinspect/expected/page.out | 85 ++ contrib/pageinspect/heapfuncs.c | 120 ++ contrib/pageinspect/pageinspect--1.6--1.7.sql | 9 ++ contrib/pageinspect/pageinspect.control | 2 +- contrib/pageinspect/sql/page.sql | 24 ++ doc/src/sgml/pageinspect.sgml | 32 +++ 7 files changed, 273 insertions(+), 2 deletions(-) create mode 100644 contrib/pageinspect/pageinspect--1.6--1.7.sql diff --git a/contrib/pageinspect/Makefile b/contrib/pageinspect/Makefile index 0a3cbee..de114c7 100644 --- a/contrib/pageinspect/Makefile +++ b/contrib/pageinspect/Makefile @@ -5,7 +5,8 @@ OBJS = rawpage.o heapfuncs.o btreefuncs.o fsmfuncs.o \ brinfuncs.o ginfuncs.o hashfuncs.o $(WIN32RES) EXTENSION = pageinspect -DATA = pageinspect--1.5.sql pageinspect--1.5--1.6.sql \ +DATA = pageinspect--1.6--1.7.sql \ + pageinspect--1.5.sql pageinspect--1.5--1.6.sql \ pageinspect--1.4--1.5.sql pageinspect--1.3--1.4.sql \ pageinspect--1.2--1.3.sql pageinspect--1.1--1.2.sql \ pageinspect--1.0--1.1.sql pageinspect--unpackaged--1.0.sql diff --git a/contrib/pageinspect/expected/page.out b/contrib/pageinspect/expected/page.out index 8e15947..b335265 100644 --- a/contrib/pageinspect/expected/page.out +++ b/contrib/pageinspect/expected/page.out @@ -82,6 +82,91 @@ SELECT * FROM fsm_page_contents(get_raw_page('test1', 'fsm', 0)); (1 row) +-- If we freeze the only tuple on test1, the infomask should +-- always be the same in all test runs. +VACUUM FREEZE test1; +SELECT t_infomask, t_infomask2, flags +FROM heap_page_items(get_raw_page('test1', 0)), + LATERAL heap_infomask_flags(t_infomask, t_infomask2, true) m(flags); + t_infomask | t_infomask2 | flags ++-+ + 2816 | 2 | {HEAP_XMIN_COMMITTED,HEAP_XMIN_INVALID,HEAP_XMAX_INVALID,HEAP_XMIN_FROZEN} +(1 row) + +SELECT t_infomask, t_infomask2, flags +FROM heap_page_items(get_raw_page('test1', 0)), + LATERAL heap_infomask_flags(t_infomask, t_infomask2, false) m(flags); + t_infomask | t_infomask2 | flags ++-+--- + 2816 | 2 | {HEAP_XMIN_COMMI
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On 20 Jul. 2017 19:09, "Ashutosh Sharma" wrote: I had a quick look into this patch and also tested it and following are my observations. Thanks very much. I'll expand the tests to cover various normal and nonsensical masks and combinations and fix the identified issues. This was a quick morning's work in amongst other things so not surprised I missed a few details. The check is appreciated.
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
I had a quick look into this patch and also tested it and following are my observations. 1) I am seeing a server crash when passing any non meaningful value for t_infomask2 to heap_infomask_flags(). postgres=# SELECT heap_infomask_flags(2816, 3); server closed the connection unexpectedly This probably means the server terminated abnormally before or while processing the request. The connection to the server was lost. Attempting reset: Failed. !> \q Following is the backtrace, (gdb) bt #0 0x00d9c55b in pg_detoast_datum (datum=0x0) at fmgr.c:1833 #1 0x00b87374 in construct_md_array (elems=0x2ad74c0, nulls=0x0, ndims=1, dims=0x7ffc0b0bbcd0, lbs=0x7ffc0b0bbcc0, elmtype=25, elmlen=-1, elmbyval=0 '\000', elmalign=105 'i') at arrayfuncs.c:3382 #2 0x00b8709f in construct_array (elems=0x2ad74c0, nelems=10, elmtype=25, elmlen=-1, elmbyval=0 '\000', elmalign=105 'i') at arrayfuncs.c:3316 #3 0x7fb8001603a5 in heap_infomask_flags (fcinfo=0x2ad3b88) at heapfuncs.c:597 #4 0x0082f4cd in ExecInterpExpr (state=0x2ad3aa0, econtext=0x2ad3750, isnull=0x7ffc0b0bbf67 "") at execExprInterp.c:672 #5 0x0088b832 in ExecEvalExprSwitchContext (state=0x2ad3aa0, econtext=0x2ad3750, isNull=0x7ffc0b0bbf67 "") at ../../../src/include/executor/executor.h:290 #6 0x0088b8e3 in ExecProject (projInfo=0x2ad3a98) at ../../../src/include/executor/executor.h:324 #7 0x0088bb89 in ExecResult (node=0x2ad36b8) at nodeResult.c:132 #8 0x008494fe in ExecProcNode (node=0x2ad36b8) at execProcnode.c:416 #9 0x0084125d in ExecutePlan (estate=0x2ad34a0, planstate=0x2ad36b8, use_parallel_mode=0 '\000', operation=CMD_SELECT, sendTuples=1 '\001', numberTuples=0, direction=ForwardScanDirection, dest=0x2ac0ae0, execute_once=1 '\001') at execMain.c:1693 #10 0x0083d54b in standard_ExecutorRun (queryDesc=0x2a42880, direction=ForwardScanDirection, count=0, execute_once=1 '\001') at execMain.c:362 #11 0x0083d253 in ExecutorRun (queryDesc=0x2a42880, direction=ForwardScanDirection, count=0, execute_once=1 '\001') at execMain.c:305 #12 0x00b3dd8f in PortalRunSelect (portal=0x2ad1490, forward=1 '\001', count=0, dest=0x2ac0ae0) at pquery.c:932 #13 0x00b3d7e7 in PortalRun (portal=0x2ad1490, count=9223372036854775807, isTopLevel=1 '\001', run_once=1 '\001', dest=0x2ac0ae0, altdest=0x2ac0ae0, completionTag=0x7ffc0b0bc2c0 "") at pquery.c:773 #14 0x00b31fe4 in exec_simple_query (query_string=0x2a9d9a0 "SELECT heap_infomask_flags(11008, , true);") at postgres.c:1099 #15 0x00b3a727 in PostgresMain (argc=1, argv=0x2a49eb0, dbname=0x2a1d480 "postgres", username=0x2a49d18 "ashu") at postgres.c:4090 #16 0x00a2cb3f in BackendRun (port=0x2a3e700) at postmaster.c:4357 #17 0x00a2bc63 in BackendStartup (port=0x2a3e700) at postmaster.c:4029 #18 0x00a248ab in ServerLoop () at postmaster.c:1753 #19 0x00a236a9 in PostmasterMain (argc=3, argv=0x2a1b2b0) at postmaster.c:1361 #20 0x008d8054 in main (argc=3, argv=0x2a1b2b0) at main.c:228 2) I can see the documentation for heap_infomask(). But, I do not see it being defined or used anywhere in the patch. + + The heap_infomask function can be used to unpack the + recognised bits of the infomasks of heap tuples. + 3) If show_combined flag is set to it's default value and a tuple is frozen then may i know the reason for not showing it as frozen tuple when t_infomask2 is passed as zero. postgres=# SELECT heap_infomask_flags(2816, 0); heap_infomask_flags --- {HEAP_XMIN_COMMITTED,HEAP_XMIN_INVALID,HEAP_XMAX_INVALID} (1 row) postgres=# SELECT heap_infomask_flags(2816, 1); heap_infomask_flags {HEAP_XMIN_COMMITTED,HEAP_XMIN_INVALID,HEAP_XMAX_INVALID,HEAP_XMIN_FROZEN} (1 row) 4) I think, it would be better to use the same argument name for the newly added function i.e heap_infomask_flags() in both documentation and sql file. I am basically refering to 'include_combined' argument. IF you see the function definition, the argument name used is 'include_combined' whereas in documentation you have mentioned 'show_combined'. -- With Regards, Ashutosh Sharma EnterpriseDB:http://www.enterprisedb.com On Thu, Jul 20, 2017 at 11:56 AM, Masahiko Sawada wrote: > On Thu, Jul 20, 2017 at 3:13 PM, Julien Rouhaud wrote: >> On Thu, Jul 20, 2017 at 5:44 AM, Peter Geoghegan wrote: >>> On Wed, Jul 19, 2017 at 8:33 PM, Craig Ringer wrote: That's silly, so here's a patch to teach pageinspect how to decode infomasks to a human readable array of flag names. Example: SELECT t_infomask, t_infomask2, flags FROM heap_page_items(get_raw_page('test1', 0)), LATERAL heap_infomask_flags(t_infomask, t_infomask2, true) m(flags); >>
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On Thu, Jul 20, 2017 at 3:13 PM, Julien Rouhaud wrote: > On Thu, Jul 20, 2017 at 5:44 AM, Peter Geoghegan wrote: >> On Wed, Jul 19, 2017 at 8:33 PM, Craig Ringer wrote: >>> That's silly, so here's a patch to teach pageinspect how to decode infomasks >>> to a human readable array of flag names. >>> >>> Example: >>> >>> SELECT t_infomask, t_infomask2, flags >>> FROM heap_page_items(get_raw_page('test1', 0)), >>> LATERAL heap_infomask_flags(t_infomask, t_infomask2, true) m(flags); >>> t_infomask | t_infomask2 | flags >>> +-+ >>>2816 | 2 | >>> {HEAP_XMIN_COMMITTED,HEAP_XMIN_INVALID,HEAP_XMAX_INVALID,HEAP_XMIN_FROZEN} >>> (1 row) >> >> Seems like a good idea to me. >> > > +1, it'll be really helpful. > +1. When I investigated data corruption incident I also wrote a plpgsql function for the same purpose, and it was very useful. I think we can have the similar thing for lp_flags as well. Regards, -- Masahiko Sawada NIPPON TELEGRAPH AND TELEPHONE CORPORATION NTT Open Source Software Center -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On Thu, Jul 20, 2017 at 5:44 AM, Peter Geoghegan wrote: > On Wed, Jul 19, 2017 at 8:33 PM, Craig Ringer wrote: >> That's silly, so here's a patch to teach pageinspect how to decode infomasks >> to a human readable array of flag names. >> >> Example: >> >> SELECT t_infomask, t_infomask2, flags >> FROM heap_page_items(get_raw_page('test1', 0)), >> LATERAL heap_infomask_flags(t_infomask, t_infomask2, true) m(flags); >> t_infomask | t_infomask2 | flags >> +-+ >>2816 | 2 | >> {HEAP_XMIN_COMMITTED,HEAP_XMIN_INVALID,HEAP_XMAX_INVALID,HEAP_XMIN_FROZEN} >> (1 row) > > Seems like a good idea to me. > +1, it'll be really helpful. -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On Wed, Jul 19, 2017 at 8:33 PM, Craig Ringer wrote: > That's silly, so here's a patch to teach pageinspect how to decode infomasks > to a human readable array of flag names. > > Example: > > SELECT t_infomask, t_infomask2, flags > FROM heap_page_items(get_raw_page('test1', 0)), > LATERAL heap_infomask_flags(t_infomask, t_infomask2, true) m(flags); > t_infomask | t_infomask2 | flags > +-+ >2816 | 2 | > {HEAP_XMIN_COMMITTED,HEAP_XMIN_INVALID,HEAP_XMAX_INVALID,HEAP_XMIN_FROZEN} > (1 row) Seems like a good idea to me. -- Peter Geoghegan -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Re: [HACKERS] [PATCH] pageinspect function to decode infomasks
On 20 July 2017 at 11:33, Craig Ringer wrote: > Hi > > Whenever I'm debugging some kind of corruption incident, possible > visibility bug, etc, I always land up staring at integer infomasks or using > a SQL helper function to decode them. > > That's silly, so here's a patch to teach pageinspect how to decode > infomasks to a human readable array of flag names. > > Example: > > SELECT t_infomask, t_infomask2, flags > FROM heap_page_items(get_raw_page('test1', 0)), > LATERAL heap_infomask_flags(t_infomask, t_infomask2, true) m(flags); > t_infomask | t_infomask2 | flags > > +-+- > --- >2816 | 2 | {HEAP_XMIN_COMMITTED,HEAP_ > XMIN_INVALID,HEAP_XMAX_INVALID,HEAP_XMIN_FROZEN} > (1 row) > > > To decode individual mask integers you can just call it directly. It's > strict, so pass 0 for the other mask if you don't have both, e.g. > > SELECT heap_infomask_flags(2816, 0); > > The patch backports easily to older pageinspect versions for when you're > debugging something old. > > BTW, I used text[] not enums. That costs a fair bit of memory, but it > doesn't seem worth worrying too much about in this context. > > For convenience it also tests and reports HEAP_LOCKED_UPGRADED and > HEAP_XMAX_IS_LOCKED_ONLY as pseudo-flags. > > I decided not to filter out > HEAP_XMIN_COMMITTED,HEAP_XMIN_INVALID,HEAP_XMAX_INVALID > when HEAP_XMIN_FROZEN is set > Er, decided not to filter out HEAP_XMIN_COMMITTED,HEAP_XMIN_INVALID. Obviously wouldn't filter out HEAP_XMAX_INVALID, that was a copy-paste'o. I wonder if it's worth dropping the HEAP_ prefix. Meh, anyway, usable as-is. -- Craig Ringer http://www.2ndQuadrant.com/ PostgreSQL Development, 24x7 Support, Training & Services
[HACKERS] [PATCH] pageinspect function to decode infomasks
Hi Whenever I'm debugging some kind of corruption incident, possible visibility bug, etc, I always land up staring at integer infomasks or using a SQL helper function to decode them. That's silly, so here's a patch to teach pageinspect how to decode infomasks to a human readable array of flag names. Example: SELECT t_infomask, t_infomask2, flags FROM heap_page_items(get_raw_page('test1', 0)), LATERAL heap_infomask_flags(t_infomask, t_infomask2, true) m(flags); t_infomask | t_infomask2 | flags +-+ 2816 | 2 | {HEAP_XMIN_COMMITTED,HEAP_XMIN_INVALID,HEAP_XMAX_INVALID,HEAP_XMIN_FROZEN} (1 row) To decode individual mask integers you can just call it directly. It's strict, so pass 0 for the other mask if you don't have both, e.g. SELECT heap_infomask_flags(2816, 0); The patch backports easily to older pageinspect versions for when you're debugging something old. BTW, I used text[] not enums. That costs a fair bit of memory, but it doesn't seem worth worrying too much about in this context. For convenience it also tests and reports HEAP_LOCKED_UPGRADED and HEAP_XMAX_IS_LOCKED_ONLY as pseudo-flags. I decided not to filter out HEAP_XMIN_COMMITTED,HEAP_XMIN_INVALID,HEAP_XMAX_INVALID when HEAP_XMIN_FROZEN is set; that doesn't make sense when we examine HEAP_XMAX_IS_LOCKED_ONLY or HEAP_LOCKED_UPGRADED, and filtering them out could be just as confusing as leaving them in. The infomask2 natts mask is ignored. You can bitwise-and it out in SQL pretty easily if needed. I could output it here as a constructed text datum, but it seems mostly pointless. -- Craig Ringer http://www.2ndQuadrant.com/ PostgreSQL Development, 24x7 Support, Training & Services From 488a1f69b8082258d508ba681a4f4a5f6fce2267 Mon Sep 17 00:00:00 2001 From: Craig Ringer Date: Thu, 20 Jul 2017 11:20:21 +0800 Subject: [PATCH v1] Introduce heap_infomask_flags to decode infomask and infomask2 --- contrib/pageinspect/Makefile | 3 +- contrib/pageinspect/expected/page.out | 25 ++ contrib/pageinspect/heapfuncs.c | 120 ++ contrib/pageinspect/pageinspect--1.6--1.7.sql | 9 ++ contrib/pageinspect/pageinspect.control | 2 +- contrib/pageinspect/sql/page.sql | 14 +++ doc/src/sgml/pageinspect.sgml | 32 +++ 7 files changed, 203 insertions(+), 2 deletions(-) create mode 100644 contrib/pageinspect/pageinspect--1.6--1.7.sql diff --git a/contrib/pageinspect/Makefile b/contrib/pageinspect/Makefile index 0a3cbee..de114c7 100644 --- a/contrib/pageinspect/Makefile +++ b/contrib/pageinspect/Makefile @@ -5,7 +5,8 @@ OBJS = rawpage.o heapfuncs.o btreefuncs.o fsmfuncs.o \ brinfuncs.o ginfuncs.o hashfuncs.o $(WIN32RES) EXTENSION = pageinspect -DATA = pageinspect--1.5.sql pageinspect--1.5--1.6.sql \ +DATA = pageinspect--1.6--1.7.sql \ + pageinspect--1.5.sql pageinspect--1.5--1.6.sql \ pageinspect--1.4--1.5.sql pageinspect--1.3--1.4.sql \ pageinspect--1.2--1.3.sql pageinspect--1.1--1.2.sql \ pageinspect--1.0--1.1.sql pageinspect--unpackaged--1.0.sql diff --git a/contrib/pageinspect/expected/page.out b/contrib/pageinspect/expected/page.out index 8e15947..054c69d 100644 --- a/contrib/pageinspect/expected/page.out +++ b/contrib/pageinspect/expected/page.out @@ -82,6 +82,31 @@ SELECT * FROM fsm_page_contents(get_raw_page('test1', 'fsm', 0)); (1 row) +-- If we freeze the only tuple on test1, the infomask should +-- always be the same in all test runs. +VACUUM FREEZE test1; +SELECT t_infomask, t_infomask2, flags +FROM heap_page_items(get_raw_page('test1', 0)), + LATERAL heap_infomask_flags(t_infomask, t_infomask2, true) m(flags); + t_infomask | t_infomask2 | flags ++-+ + 2816 | 2 | {HEAP_XMIN_COMMITTED,HEAP_XMIN_INVALID,HEAP_XMAX_INVALID,HEAP_XMIN_FROZEN} +(1 row) + +SELECT t_infomask, t_infomask2, flags +FROM heap_page_items(get_raw_page('test1', 0)), + LATERAL heap_infomask_flags(t_infomask, t_infomask2, false) m(flags); + t_infomask | t_infomask2 | flags ++-+--- + 2816 | 2 | {HEAP_XMIN_COMMITTED,HEAP_XMIN_INVALID,HEAP_XMAX_INVALID} +(1 row) + +SELECT heap_infomask_flags(2816, 0); +heap_infomask_flags +--- + {HEAP_XMIN_COMMITTED,HEAP_XMIN_INVALID,HEAP_XMAX_INVALID} +(1 row) + DROP TABLE test1; -- check that using any of these functions with a partitioned table would fail create table test_partitioned (a int) partition by