[Pacemaker] Can't failover Master/Slave with group(primitive x3) setting
Andrew Beekhof
andrew at beekhof.net
Thu Oct 6 23:50:43 EDT 2011
On Fri, Oct 7, 2011 at 2:21 PM, Andrew Beekhof <andrew at beekhof.net> wrote:
> On Fri, Oct 7, 2011 at 11:39 AM, Andrew Beekhof <andrew at beekhof.net> wrote:
>> On Fri, Sep 30, 2011 at 3:44 PM, Junko IKEDA <tsukishima.ha at gmail.com> wrote:
>>> Hi,
>>>
>>> sorry for the confusion.
>>>
>>> Pacemaker 1.0.10 OK(group resource can failover)
>>> Pacemaker 1.0.11 NG(gruop resource just stop, can not failover)
>>> Pacemaker 1.1 <- the latest hg (gruop resource just stop, can not failover)
>>
>> We've actually moved over 1.1 to git:
>> http://www.clusterlabs.org/wiki/Contributing_Patches
>>
>> I should mark that somehow in the HG tree.
>>
>>>
>>> By the way, your simulation showed dummy01 restart on bl460g1n13 again,
>>> but dummy01 failed on bl460g1n13, so dummy01 should move to bl460g1n14.
>>
>> Hmmm. True. I'll take another look.
>
> Getting this and coloc-clone-stays-active to behave at the same time
> is proving a challenge :-(
>
I'm not 100% sure I like this patch but could you see how it behaves
in your testing?
diff --git a/pengine/native.c b/pengine/native.c
index 52f6f0f..8718abb 100644
--- a/pengine/native.c
+++ b/pengine/native.c
@@ -26,6 +26,7 @@
#include <utils.h>
#define DELETE_THEN_REFRESH 1 /* The crmd will remove the resource
from the CIB itself, making this redundant */
+#define INFINITY_HACK (INFINITY * -100)
#define VARIANT_NATIVE 1
#include <lib/pengine/variant.h>
@@ -287,8 +288,12 @@ node_hash_update(GHashTable * list1, GHashTable *
list2, const char *attr, int f
crm_trace("%s: Filtering %d + %d*%d (factor * score)",
node->details->uname, node->weight, factor, score);
+ } else if (node->weight == INFINITY_HACK) {
+ crm_trace("%s: Filtering %d + %d*%d (node < 0)",
+ node->details->uname, node->weight, factor, score);
+
} else if (only_positive && new_score < 0 && node->weight > 0) {
- node->weight = 1;
+ node->weight = INFINITY_HACK;
crm_trace("%s: Filtering %d + %d*%d (score > 0)",
node->details->uname, node->weight, factor, score);
@@ -300,7 +305,6 @@ node_hash_update(GHashTable * list1, GHashTable *
list2, const char *attr, int f
crm_trace("%s: %d + %d*%d", node->details->uname,
node->weight, factor, score);
node->weight = new_score;
}
-
}
}
@@ -405,6 +409,17 @@ rsc_merge_weights(resource_t * rsc, const char
*rhs, GHashTable * nodes, const c
}
+ if(is_set(flags, pe_weights_positive)) {
+ node_t *node = NULL;
+ GHashTableIter iter;
+ g_hash_table_iter_init(&iter, work);
+ while (g_hash_table_iter_next(&iter, NULL, (void **)&node)) {
+ if (node->weight == INFINITY_HACK) {
+ node->weight = 1;
+ }
+ }
+ }
+
if (nodes) {
g_hash_table_destroy(nodes);
}
More information about the Pacemaker
mailing list