Fix for opencontrail.compute (member list uniq)

- make member list for collectors uniq (4.x)
- make member list for controllers uniq (4.x)
- backport it to 3.0 (otherwise two same servers may be chosen)

Prod-Related: PROD-33809
Change-Id: Ie220d385144aecf2f7ea3427c4e572a0e69028df
(cherry picked from commit 183b8b0f6e942b371ef6f630fa2395d01d1f2a63)
diff --git a/opencontrail/files/3.0/contrail-vrouter-agent.conf b/opencontrail/files/3.0/contrail-vrouter-agent.conf
index f057de4..4e5a422 100644
--- a/opencontrail/files/3.0/contrail-vrouter-agent.conf
+++ b/opencontrail/files/3.0/contrail-vrouter-agent.conf
@@ -9,7 +9,13 @@
 # value provided by discovery service will be used. (Optional)
 # server=10.0.0.1 10.0.0.2
 {%- if not compute.discovery.get('enabled', True) %}
-server={% for member in compute.control.members[0:2] %}{{ member.host }}{% if not loop.last %} {% endif %}{% endfor %}
+{%- set control_members = [] %}
+{%- for member in compute.control.members %}
+{%-   if member not in control_members %}
+{%-     do control_members.append(member) %}
+{%-   endif %}
+{%- endfor %}
+server={% for member in control_members[0:2] %}{{ member.host }}{% if not loop.last %} {% endif %}{% endfor %}
 {%- endif %}
 
 [DEFAULT]
@@ -20,7 +26,13 @@
 # IP:port strings separated by space can be provided
 # collectors=127.0.0.1:8086
 {%- if not compute.discovery.get('enabled', True) %}
-collectors={% for member in compute.collector.members[0:2] %}{{ member.host }}:8086{% if not loop.last %} {% endif %}{% endfor %}
+{%- set collector_members = [] %}
+{%- for member in compute.collector.members %}
+{%-   if member not in collector_members %}
+{%-     do collector_members.append(member) %}
+{%-   endif %}
+{%- endfor %}
+collectors={% for member in collector_members[0:2] %}{{ member.host }}:8086{% if not loop.last %} {% endif %}{% endfor %}
 {%- endif %}
 
 # Agent mode : can be vrouter / tsn / tor (default is vrouter)
@@ -121,7 +133,7 @@
 # the value provided by discovery service will be used.
 # server=10.0.0.1:53 10.0.0.2:53
 {%- if not compute.discovery.get('enabled', True) %}
-server={% for member in compute.control.members[0:2] %}{{ member.host }}:53{% if not loop.last %} {% endif %}{% endfor %}
+server={% for member in control_members[0:2] %}{{ member.host }}:53{% if not loop.last %} {% endif %}{% endfor %}
 {%- endif %}
 
 # Client port used by vrouter-agent while connecting to contrail-named
diff --git a/opencontrail/files/3.0/contrail-vrouter-nodemgr.conf b/opencontrail/files/3.0/contrail-vrouter-nodemgr.conf
index 1efe1f2..09c1717 100644
--- a/opencontrail/files/3.0/contrail-vrouter-nodemgr.conf
+++ b/opencontrail/files/3.0/contrail-vrouter-nodemgr.conf
@@ -5,5 +5,11 @@
 port=5998
 {%- else %}
 [COLLECTOR]
-server_list={% for member in compute.collector.members %}{{ member.host }}:8086{% if not loop.last %} {% endif %}{% endfor %}
+{%- set collector_members = [] %}
+{%- for member in compute.collector.members %}
+{%-   if member not in collector_members %}
+{%-     do collector_members.append(member) %}
+{%-   endif %}
+{%- endfor %}
+server_list={% for member in collector_members %}{{ member.host }}:8086{% if not loop.last %} {% endif %}{% endfor %}
 {%- endif %}
diff --git a/opencontrail/files/4.0/contrail-vrouter-agent.conf b/opencontrail/files/4.0/contrail-vrouter-agent.conf
index b5bca55..5f0e29c 100644
--- a/opencontrail/files/4.0/contrail-vrouter-agent.conf
+++ b/opencontrail/files/4.0/contrail-vrouter-agent.conf
@@ -6,14 +6,26 @@
 [CONTROL-NODE]
 # List of IPAdress:Port of control-node's separated by space.(Mandatory)
 # servers=10.0.0.1:5269 10.0.0.2:5260 10.0.0.3:5260
-servers={% for member in compute.control.members %}{{ member.host }}:5269{% if not loop.last %} {% endif %}{% endfor %}
+{%- set control_members = [] %}
+{%- for member in compute.control.members %}
+{%-   if member not in control_members %}
+{%-     do control_members.append(member) %}
+{%-   endif %}
+{%- endfor %}
+servers={% for member in control_members %}{{ member.host }}:5269{% if not loop.last %} {% endif %}{% endfor %}
 
 [DEFAULT]
 # Everything in this section is optional
 
 # IP address and port to be used to connect to collector.
 # Multiple IP:port strings separated by space can be provided
-collectors = {% for member in compute.collector.members %}{{ member.host }}:8086{% if not loop.last %} {% endif %}{% endfor %}
+{%- set collector_members = [] %}
+{%- for member in compute.collector.members %}
+{%-   if member not in collector_members %}
+{%-     do collector_members.append(member) %}
+{%-   endif %}
+{%- endfor %}
+collectors = {% for member in collector_members %}{{ member.host }}:8086{% if not loop.last %} {% endif %}{% endfor %}
 
 # Agent mode : can be vrouter / tsn / tor (default is vrouter)
 # agent_mode=
@@ -141,7 +153,7 @@
 
 # List of IPAdress:Port of DNS Servers separated by space.
 # servers=10.0.0.1:53 10.0.0.2:53 10.0.0.3:53
-servers={% for member in compute.control.members %}{{ member.host }}:53{% if not loop.last %} {% endif %}{% endfor %}
+servers={% for member in control_members %}{{ member.host }}:53{% if not loop.last %} {% endif %}{% endfor %}
 
 # Timeout for DNS server queries in milli-seconds
 # dns_timeout=
diff --git a/opencontrail/files/4.0/contrail-vrouter-nodemgr.conf b/opencontrail/files/4.0/contrail-vrouter-nodemgr.conf
index 9ae7b81..9c2f26d 100644
--- a/opencontrail/files/4.0/contrail-vrouter-nodemgr.conf
+++ b/opencontrail/files/4.0/contrail-vrouter-nodemgr.conf
@@ -10,4 +10,10 @@
 {%- endif %}
 
 [COLLECTOR]
-server_list = {% for member in compute.collector.members %}{{ member.host }}:8086 {% endfor %}
+{%- set collector_members = [] %}
+{%- for member in compute.collector.members %}
+{%-   if member not in collector_members %}
+{%-     do collector_members.append(member) %}
+{%-   endif %}
+{%- endfor %}
+server_list = {% for member in collector_members %}{{ member.host }}:8086 {% endfor %}