[Pacemaker] hangs pending

Andrey Groshev greenx at yandex.ru
Mon Mar 3 23:08:17 CET 2014


Hi! 
I thought that all the bugs have already been caught. :)
But today(already tonight) build last git PCMK with add upstart.
And again catch hangs pending.
logs http://send2me.ru/pcmk-04-Mar-2014.tar.bz2

24.02.2014, 03:44, "Andrew Beekhof" <andrew at beekhof.net>:
> On 22 Feb 2014, at 7:07 pm, Andrey Groshev <greenx at yandex.ru> wrote:
>
>>  21.02.2014, 04:00, "Andrew Beekhof" <andrew at beekhof.net>:
>>>  On 20 Feb 2014, at 10:04 pm, Andrey Groshev <greenx at yandex.ru> wrote:
>>>>   20.02.2014, 13:57, "Andrew Beekhof" <andrew at beekhof.net>:
>>>>>   On 20 Feb 2014, at 5:33 pm, Andrey Groshev <greenx at yandex.ru> wrote:
>>>>>>    20.02.2014, 01:22, "Andrew Beekhof" <andrew at beekhof.net>:
>>>>>>>    On 20 Feb 2014, at 4:18 am, Andrey Groshev <greenx at yandex.ru> wrote:
>>>>>>>>     19.02.2014, 06:47, "Andrew Beekhof" <andrew at beekhof.net>:
>>>>>>>>>     On 18 Feb 2014, at 9:29 pm, Andrey Groshev <greenx at yandex.ru> wrote:
>>>>>>>>>>      Hi, ALL and Andrew!
>>>>>>>>>>
>>>>>>>>>>      Today is a good day - I killed a lot, and a lot of shooting at me.
>>>>>>>>>>      In general - I am happy (almost like an elephant)   :)
>>>>>>>>>>      Except resources on the node are important to me eight processes: corosync,pacemakerd,cib,stonithd,lrmd,attrd,pengine,crmd.
>>>>>>>>>>      I killed them with different signals (4,6,11 and even 9).
>>>>>>>>>>      Behavior does not depend of number signal - it's good.
>>>>>>>>>>      If STONITH send reboot to the node - it rebooted and rejoined the cluster - too it's good.
>>>>>>>>>>      But the behavior is different from killing various demons.
>>>>>>>>>>
>>>>>>>>>>      Turned four groups:
>>>>>>>>>>      1. corosync,cib - STONITH work 100%.
>>>>>>>>>>      Kill via any signals - call STONITH and reboot.
>>>>>>>>>     excellent
>>>>>>>>>>      3. stonithd,attrd,pengine - not need STONITH
>>>>>>>>>>      This daemons simple restart, resources - stay running.
>>>>>>>>>     right
>>>>>>>>>>      2. lrmd,crmd - strange behavior STONITH.
>>>>>>>>>>      Sometimes called STONITH - and the corresponding reaction.
>>>>>>>>>>      Sometimes restart daemon
>>>>>>>>>     The daemon will always try to restart, the only variable is how long it takes the peer to notice and initiate fencing.
>>>>>>>>>     If the failure happens just before a they're due to receive totem token, the failure will be very quickly detected and the node fenced.
>>>>>>>>>     If the failure happens just after, then detection will take longer - giving the node longer to recover and not be fenced.
>>>>>>>>>
>>>>>>>>>     So fence/not fence is normal and to be expected.
>>>>>>>>>>      and restart resources with large delay MS:pgsql.
>>>>>>>>>>      One time after restart crmd - pgsql don't restart.
>>>>>>>>>     I would not expect pgsql to ever restart - if the RA does its job properly anyway.
>>>>>>>>>     In the case the node is not fenced, the crmd will respawn and the the PE will request that it re-detect the state of all resources.
>>>>>>>>>
>>>>>>>>>     If the agent reports "all good", then there is nothing more to do.
>>>>>>>>>     If the agent is not reporting "all good", you should really be asking why.
>>>>>>>>>>      4. pacemakerd - nothing happens.
>>>>>>>>>     On non-systemd based machines, correct.
>>>>>>>>>
>>>>>>>>>     On a systemd based machine pacemakerd is respawned and reattaches to the existing daemons.
>>>>>>>>>     Any subsequent daemon failure will be detected and the daemon respawned.
>>>>>>>>     And! I almost forgot about IT!
>>>>>>>>     Exist another (NORMAL) the variants, the methods, the ideas?
>>>>>>>>     Without this  ... @$%#$%&$%^&$%^&##@#$$^$%& !!!!!
>>>>>>>>     Otherwise - it's a full epic fail ;)
>>>>>>>    -ENOPARSE
>>>>>>    OK, I remove my personal attitude to "systemd".
>>>>>>    Let me explain.
>>>>>>
>>>>>>    Somewhere in the beginning of this topic, I wrote:
>>>>>>    A.G.:Who knows who runs lrmd?
>>>>>>    A.B.:Pacemakerd.
>>>>>>    That's one!
>>>>>>
>>>>>>    Let's see the list of processes:
>>>>>>    #ps -axf
>>>>>>    .....
>>>>>>    6067 ?        Ssl    7:24 corosync
>>>>>>    6092 ?        S      0:25 pacemakerd
>>>>>>    6094 ?        Ss   116:13  \_ /usr/libexec/pacemaker/cib
>>>>>>    6095 ?        Ss     0:25  \_ /usr/libexec/pacemaker/stonithd
>>>>>>    6096 ?        Ss     1:27  \_ /usr/libexec/pacemaker/lrmd
>>>>>>    6097 ?        Ss     0:49  \_ /usr/libexec/pacemaker/attrd
>>>>>>    6098 ?        Ss     0:25  \_ /usr/libexec/pacemaker/pengine
>>>>>>    6099 ?        Ss     0:29  \_ /usr/libexec/pacemaker/crmd
>>>>>>    .....
>>>>>>    That's two!
>>>>>   Whats two?  I don't follow.
>>>>   In the sense that it creates other processes. But it does not matter.
>>>>>>    And more, more...
>>>>>>    Now you must understand - why I want this process to work always.
>>>>>>    Even I think, No need for anyone here to explain it!
>>>>>>
>>>>>>    And Now you say about "pacemakerd nice work, but only on systemd distros" !!!
>>>>>   No, I;m saying it works _better_ on systemd distros.
>>>>>   On non-systemd distros you still need quite a few unlikely-to-happen failures to trigger a situation in which the node still gets fenced and recovered (assuming no-one saw any of the error messages and didn't run "service pacemaker restart" prior to the additional failures).
>>>>   Can you show me the place where:
>>>>   "On a systemd based machine pacemakerd is respawned and reattaches to the existing daemons."?
>>>  The code for it is in mcp/pacemaker.c, look for find_and_track_existing_processes()
>>>
>>>  The ps tree will look different though
>>>
>>>   6094 ?        Ss   116:13  /usr/libexec/pacemaker/cib
>>>   6095 ?        Ss     0:25  /usr/libexec/pacemaker/stonithd
>>>   6096 ?        Ss     1:27  /usr/libexec/pacemaker/lrmd
>>>   6097 ?        Ss     0:49  /usr/libexec/pacemaker/attrd
>>>   6098 ?        Ss     0:25  /usr/libexec/pacemaker/pengine
>>>   6099 ?        Ss     0:29  /usr/libexec/pacemaker/crmd
>>>  ...
>>>   6666 ?        S      0:25 pacemakerd
>>>
>>>  but pacemakerd will be watching the old children and respawning them on failure.
>>>  at which point you might see:
>>>
>>>   6094 ?        Ss   116:13  /usr/libexec/pacemaker/cib
>>>   6096 ?        Ss     1:27  /usr/libexec/pacemaker/lrmd
>>>   6097 ?        Ss     0:49  /usr/libexec/pacemaker/attrd
>>>   6098 ?        Ss     0:25  /usr/libexec/pacemaker/pengine
>>>   6099 ?        Ss     0:29  /usr/libexec/pacemaker/crmd
>>>  ...
>>>   6666 ?        S      0:25 pacemakerd
>>>   6667 ?        Ss     0:25 \_ /usr/libexec/pacemaker/stonithd
>>>>   If I respawn via upstart process pacemakerd - "reattaches to the existing daemons" ?
>>>  If upstart is capable of detecting the pacemakerd failure and automagically respawning it, then yes - the same process will happen.
>>  Some people defend you, send me hate mail when I'm not restrained.
>
> You should see the mail I get off-list ;-)
>
>>  But You're also a beetle :)
>
> I'm not 100% sure what you mean there.
>
>>  Why you did not say anything about supporting upstart in spec?
>
> Mostly because I don't run it anywhere, so I have no idea what it does by default or can be configured to do.
> Its not malicious, the feature was simply written and tested in the context of systemd.
>
> Also, when I think upstart, I think debian based distros which don't use spec files ;-)
>
> ,
> _______________________________________________
> Pacemaker mailing list: Pacemaker at oss.clusterlabs.org
> http://oss.clusterlabs.org/mailman/listinfo/pacemaker
>
> Project Home: http://www.clusterlabs.org
> Getting started: http://www.clusterlabs.org/doc/Cluster_from_Scratch.pdf
> Bugs: http://bugs.clusterlabs.org



More information about the Pacemaker mailing list