[ClusterLabs] Added optional parameter "name" to "crm corosync add-node"

Andrei Maruha Andrei_Maruha at epam.com
Wed Jan 27 12:45:52 UTC 2016


Hi,
Attached patch contains functionality to add parameter "name" to "crm 
corosync add-node".
May be it will be useful for someone else, because Pacemaker tries to 
get "name" parameter in case if "ring0_addr" contains ip address 
(https://github.com/ClusterLabs/pacemaker/blob/master/lib/cluster/corosync.c).

Best Regards,
Andrei Maruha

/__/
-------------- next part --------------
commit 097f26cbbc41fe61e5fff8fece243ed4337ac75d
Author: Andrei Maruha <Andrei_Maruha at epam.com>
Date:   Wed Jan 27 13:53:22 2016 +0300

    added optional parameter [name] to "corosync add-node" function
    
    Parameter "name" in section "nodelist" of corosync.conf is used by
    Pacemaker if parameter "ring0_addr" contains ip address instead of
    hostname.

diff --git a/doc/crm.8.adoc b/doc/crm.8.adoc
index f874cc2..3d8b35d 100644
--- a/doc/crm.8.adoc
+++ b/doc/crm.8.adoc
@@ -1211,7 +1211,7 @@ sets only the address for ring0.
 
 Usage:
 .........
-add-node <addr>
+add-node <addr> [name]
 .........
 
 [[cmdhelp_corosync_del-node,Remove a corosync node]]
diff --git a/modules/corosync.py b/modules/corosync.py
index cba061f..5c7080d 100644
--- a/modules/corosync.py
+++ b/modules/corosync.py
@@ -368,35 +368,45 @@ def set_value(path, value):
     f.close()
 
 
-def add_node(name):
+def add_node(addr, name=None):
     '''
     Add node to corosync.conf
     '''
     coronodes = None
     nodes = None
+    nodenames = None
     coronodes = utils.list_corosync_nodes()
+    nodenames = utils.list_corosync_node_names()
     try:
         nodes = utils.list_cluster_nodes()
     except Exception:
         nodes = []
-    ipaddr = get_ip(name)
-    if name in coronodes or (ipaddr and ipaddr in coronodes):
+    ipaddr = get_ip(addr)
+    if addr in nodenames + coronodes or (ipaddr and ipaddr in coronodes):
+        err_buf.warning("%s already in corosync.conf" % (addr))
+        return
+    if name and name in nodenames + coronodes:
         err_buf.warning("%s already in corosync.conf" % (name))
         return
-    if name in nodes:
+    if addr in nodes:
+        err_buf.warning("%s already in configuration" % (addr))
+        return
+    if name and name in nodes:
         err_buf.warning("%s already in configuration" % (name))
         return
 
     f = open(conf()).read()
     p = Parser(f)
 
-    node_addr = name
+    node_addr = addr
     node_id = next_nodeid(p)
+    node_name = name
+    node_value = (make_value('nodelist.node.ring0_addr', node_addr) +
+                  make_value('nodelist.node.nodeid', str(node_id)))
+    if node_name:
+        node_value += make_value('nodelist.node.name', node_name)
 
-    p.add('nodelist',
-          make_section('nodelist.node',
-                       make_value('nodelist.node.ring0_addr', node_addr) +
-                       make_value('nodelist.node.nodeid', str(node_id))))
+    p.add('nodelist', make_section('nodelist.node', node_value))
 
     num_nodes = p.count('nodelist.node')
     if num_nodes > 2:
@@ -414,6 +424,10 @@ def add_node(name):
         utils.ext_cmd(["corosync-cmapctl",
                        "-s", "nodelist.node.%s.ring0_addr" % (num_nodes - 1),
                        "str", node_addr], shell=False)
+        if node_name:
+                utils.ext_cmd(["corosync-cmapctl",
+                               "-s", "nodelist.node.%s.name" % (num_nodes - 1),
+                               "str", node_name], shell=False)
 
 
 def del_node(addr):
@@ -443,3 +457,5 @@ def del_node(addr):
                       shell=False)
         utils.ext_cmd(["corosync-cmapctl", "-D", "nodelist.node.%s.ring0_addr" % (nth)],
                       shell=False)
+        utils.ext_cmd(["corosync-cmapctl", "-D", "nodelist.node.%s.name" % (nth)],
+                      shell=False)
diff --git a/modules/ui_corosync.py b/modules/ui_corosync.py
index 771acdf..0dec867 100644
--- a/modules/ui_corosync.py
+++ b/modules/ui_corosync.py
@@ -120,9 +120,9 @@ class Corosync(command.UI):
     @command.name('add-node')
     @command.alias('add_node')
     @command.skill_level('administrator')
-    def do_addnode(self, context, name):
+    def do_addnode(self, context, addr, name=None):
         "Add a node to the corosync nodelist"
-        corosync.add_node(name)
+        corosync.add_node(addr, name)
 
     @command.name('del-node')
     @command.alias('del_node')
diff --git a/modules/utils.py b/modules/utils.py
index e958c8a..05db843 100644
--- a/modules/utils.py
+++ b/modules/utils.py
@@ -1337,6 +1337,25 @@ def resolve_hostnames(hostnames):
     return True, None
 
 
+def list_corosync_node_names():
+    '''
+    Returns list of nodes configured
+    in corosync.conf
+    '''
+    try:
+        cfg = os.getenv('COROSYNC_MAIN_CONFIG_FILE', '/etc/corosync/corosync.conf')
+        lines = open(cfg).read().split('\n')
+        name_re = re.compile(r'\s*name:\s+(.*)')
+        names = []
+        for line in lines:
+            name = name_re.match(line)
+            if name:
+                names.append(name.group(1))
+        return names
+    except Exception:
+        return []
+
+
 def list_corosync_nodes():
     '''
     Returns list of nodes configured


More information about the Users mailing list