[Pacemaker] Issue with clusterlab mysql ocf script
Raoul Bhatia [IPAX]
r.bhatia at ipax.at
Wed Oct 19 09:43:46 EDT 2011
we might need marek on this one because i did not implement
the master/slave logic and am not using it for multiple slaves.
marek, can you please comment on this?
thanks,
raoul
On 2011-08-29 23:08, Michael Szilagyi wrote:
> Did some more testing and figured I would add that even Slave resources
> rejoin the cluster as a Master role briefly before switching back to
> Slave. Of course, since the mysql RA uses event notification this still
> has the effect of unsetting all masters whenever a new node joins.
> Since a master role is possibly configured already, the pre-premote
> notification event doesn't get fired again and replication remains
> broken. It seems likely that I must be doing something wrong since this
> would be a pretty normal use case and completely breaks the mysql
> replication cluster.
>
> Thoughts anyone?
>
>
> On Fri, Aug 26, 2011 at 10:19 AM, Michael Szilagyi <mszilagyi at gmail.com
> <mailto:mszilagyi at gmail.com>> wrote:
>
> I'm having a problem with master/slave promotion using the most
> recent version of the mysql ocf script hosted off the
> clusterLabs/resource-agents github repo.
>
> The script works well failing over to a slave if a master looses
> connection with the cluster. However, when the master rejoins the
> cluster the script is doing some undesirable things. Basically, if
> the master looses connection (say I pull the network cable) then a
> new slave is promoted and the old master is just orphaned (which is
> fine, I don't have STONITH setup yet or anything). If i plug that
> machine's cable back in then the node rejoins the cluster and
> initially there are now two masters (the old, orphaned one and the
> newly promoted one). Pacemaker properly sees this and demotes the
> old master to a slave.
>
> After some time debugging the ocf I think what is happening is that
> the script sees the old master join and fires off a post-demote
> notification event for the returning master which causes a
> unset_master command to be executed. This causes all the slaves to
> remove their master connection info. However, since the other
> master server has already been promoted and is (to its mind) already
> replicating to the other slaves in the cluster, a new pre-promote is
> never fired which means that the slaves do not get a new CHANGE
> MASTER TO issued so I wind up with a broken replication setup.
>
> I'm not sure if I'm missing something in how this is supposed to be
> working or if this is a limitation of the script. It seems like
> there must be either a bug or something I've got setup wrong,
> however, since it's not all that unlikely that such a scenario could
> occur. If anyone has any ideas or suggestions on how the script is
> supposed to work (or what I may be doing wrong) I'd appreciate some
> ideas.
>
> I'll include the output of my crm configure show in case it'll be
> useful:
>
> node $id="a1a3266d-24e2-4d1b-bfd7-de3bac929661" seven \
> attributes 172.17.0.130-log-file-p_mysql="mysql-bin.000005"
> 172.17.0.130-log-pos-p_mysql="865"
> 172.17.0.131-log-file-p_mysql="mysql-bin.000038"
> 172.17.0.131-log-pos-p_mysql="607"
> four-log-file-p_mysql="mysql-bin.000040" four-log-pos-p_mysql="2150"
> node $id="cc0227a2-a7bc-4a0d-ba1b-f6ecb7e7d845" four \
> attributes 172.17.0.130-log-file-p_mysql="mysql-bin.000005"
> 172.17.0.130-log-pos-p_mysql="865"
> three-log-file-p_mysql="mysql-bin.000022" three-log-pos-p_mysql="106"
> node $id="d9d3c6cb-bf60-4468-926f-d9716e56fb0f" three \
> attributes 172.17.0.131-log-file-p_mysql="mysql-bin.000038"
> 172.17.0.131-log-pos-p_mysql="607" three-log-pos-p_mysql="4"
> primitive p_mysql ocf:heartbeat:mysql \
> params binary="/usr/sbin/mysqld" config="/etc/mysql/my.cnf" \
> params pid="/var/lib/mysql/mySQL.pid"
> socket="/var/run/mysqld/mysqld.sock" \
> params replication_user="sqlSlave" replication_passwd="slave" \
> params additional_parameters="--skip-slave-start" \
> op start interval="0" timeout="120" \
> op stop interval="0" timeout="120" \
> op promote interval="0" timeout="120" \
> op demote interval="0" timeout="120" \
> op monitor interval="5" role="Master" timeout="30" \
> op monitor interval="10" role="Slave" timeout="30"
> ms ms_mysql p_mysql \
> meta master-max="1" clone-max="3" target-role="Started"
> is-managed="true" notify="true" \
> meta target-role="Started"
> property $id="cib-bootstrap-options" \
> dc-version="1.0.9-da7075976b5ff0bee71074385f8fd02f296ec8a3" \
> cluster-infrastructure="Heartbeat" \
> stonith-enabled="false" \
> last-lrm-refresh="1314307995"
>
> Thanks!
>
>
>
>
> _______________________________________________
> 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://developerbugs.linux-foundation.org/enter_bug.cgi?product=Pacemaker
--
____________________________________________________________________
DI (FH) Raoul Bhatia M.Sc. email. r.bhatia at ipax.at
Technischer Leiter
IPAX - Aloy Bhatia Hava OEG web. http://www.ipax.at
Barawitzkagasse 10/2/2/11 email. office at ipax.at
1190 Wien tel. +43 1 3670030
FN 277995t HG Wien fax. +43 1 3670030 15
____________________________________________________________________
More information about the Pacemaker
mailing list