summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--build/opendaylight-tripleo-heat-templates.patch83
1 files changed, 47 insertions, 36 deletions
diff --git a/build/opendaylight-tripleo-heat-templates.patch b/build/opendaylight-tripleo-heat-templates.patch
index c75be102..e163b452 100644
--- a/build/opendaylight-tripleo-heat-templates.patch
+++ b/build/opendaylight-tripleo-heat-templates.patch
@@ -1,4 +1,4 @@
-From 187401f1be6b4a85c032d66d3d436683fbd2514c Mon Sep 17 00:00:00 2001
+From 94df637aa818881118c52b6e25d3266e0fa6b853 Mon Sep 17 00:00:00 2001
From: Dan Radez <dradez@redhat.com>
Date: Sun, 13 Dec 2015 21:20:40 -0500
Subject: [PATCH] Adds OpenDaylight support
@@ -7,8 +7,8 @@ To enable OpenDaylight on controllers use environments/opendaylight.yaml
To enable OpenDaylight on external node use
environments/opendaylight-external.yaml
---
- environments/opendaylight-external.yaml | 21 +++
- environments/opendaylight.yaml | 18 ++
+ environments/opendaylight-external.yaml | 25 +++
+ environments/opendaylight.yaml | 25 +++
overcloud-resource-registry-puppet.yaml | 3 +
overcloud-without-mergepy.yaml | 62 ++++++
puppet/all-nodes-config.yaml | 6 +
@@ -19,7 +19,7 @@ environments/opendaylight-external.yaml
puppet/manifests/overcloud_controller_pacemaker.pp | 184 +++++++++++-------
puppet/manifests/overcloud_opendaylight.pp | 26 +++
puppet/opendaylight-puppet.yaml | 209 +++++++++++++++++++++
- 12 files changed, 569 insertions(+), 80 deletions(-)
+ 12 files changed, 580 insertions(+), 80 deletions(-)
create mode 100644 environments/opendaylight-external.yaml
create mode 100644 environments/opendaylight.yaml
create mode 100644 puppet/manifests/overcloud_opendaylight.pp
@@ -27,10 +27,10 @@ environments/opendaylight-external.yaml
diff --git a/environments/opendaylight-external.yaml b/environments/opendaylight-external.yaml
new file mode 100644
-index 0000000..bbc78db
+index 0000000..411df21
--- /dev/null
+++ b/environments/opendaylight-external.yaml
-@@ -0,0 +1,21 @@
+@@ -0,0 +1,25 @@
+# Environment file used to enable OpenDaylight
+# Currently uses overcloud image that is assumed
+# to be virt-customized with ODL RPM already on it
@@ -47,37 +47,48 @@ index 0000000..bbc78db
+
+parameters:
+ # increase this if you need more ODL nodes
-+ # OpenDaylightCount: 1
++ OpenDaylightCount: 1
+ NeutronL3HA: false
+ ExtraConfig:
+ neutron_mechanism_drivers: ['opendaylight']
+ neutron_tenant_network_type: vxlan
++ # Enable this if you want OpenDaylight on the contollers
++ # reduce OpenDaylightCount to 0 if you don't want any
++ # OpenDaylight only nodes
++ #opendaylight_install: true
diff --git a/environments/opendaylight.yaml b/environments/opendaylight.yaml
new file mode 100644
-index 0000000..b9ffeb9
+index 0000000..c8abf75
--- /dev/null
+++ b/environments/opendaylight.yaml
-@@ -0,0 +1,18 @@
+@@ -0,0 +1,25 @@
+# Environment file used to enable OpenDaylight
+# Currently uses overcloud image that is assumed
+# to be virt-customized with ODL RPM already on it
+
-+# These parameters customize the OpenDaylight Service
++# These parameters customize the OpenDaylight Node
++# The user name and password are for the ODL service
+# Defaults are included here for reference
+#parameter_defaults:
++# OpenDaylightFlavor: baremetal
++# OpenDaylightHostname: opendaylight-server
++# OpenDaylightImage: overcloud-full
+# OpenDaylightUsername: admin
+# OpenDaylightPassword: admin
+
+parameters:
-+ # instructs there not to be any ODL only nodes
-+ OpenDaylightCount: 0
++ # increase this if you need more ODL nodes
++ # OpenDaylightCount: 1
+ NeutronL3HA: false
+ ExtraConfig:
+ neutron_mechanism_drivers: ['opendaylight']
+ neutron_tenant_network_type: vxlan
++ # Enable this if you want OpenDaylight on the contollers
++ # reduce OpenDaylightCount to 0 if you don't want any
++ # OpenDaylight only nodes
+ opendaylight_install: true
diff --git a/overcloud-resource-registry-puppet.yaml b/overcloud-resource-registry-puppet.yaml
-index 4cfed6b..adecc79 100644
+index c072c29..2413450 100644
--- a/overcloud-resource-registry-puppet.yaml
+++ b/overcloud-resource-registry-puppet.yaml
@@ -27,6 +27,9 @@ resource_registry:
@@ -91,7 +102,7 @@ index 4cfed6b..adecc79 100644
# NodeUserData == Cloud-init additional user-data, e.g cloud-config
# ControllerExtraConfigPre == Controller configuration pre service deployment
diff --git a/overcloud-without-mergepy.yaml b/overcloud-without-mergepy.yaml
-index a532c2f..733eb7f 100644
+index 01c0079..210ec11 100644
--- a/overcloud-without-mergepy.yaml
+++ b/overcloud-without-mergepy.yaml
@@ -227,6 +227,23 @@ parameters:
@@ -118,14 +129,14 @@ index a532c2f..733eb7f 100644
PublicVirtualFixedIPs:
default: []
description: >
-@@ -664,6 +681,18 @@ parameters:
+@@ -650,6 +667,18 @@ parameters:
structure as ExtraConfig.
type: json
+# OpenDaylight specific parameters
+ OpenDaylightCount:
+ type: number
-+ default: 1
++ default: 0
+ OpenDaylightImage:
+ default: overcloud-full
+ type: string
@@ -137,7 +148,7 @@ index a532c2f..733eb7f 100644
# Hostname format for each role
# Note %index% is translated into the index of the node, e.g 0/1/2 etc
# and %stackname% is replaced with OS::stack_name in the template below.
-@@ -688,6 +717,10 @@ parameters:
+@@ -674,6 +703,10 @@ parameters:
type: string
description: Format for CephStorage node hostnames
default: '%stackname%-cephstorage-%index%'
@@ -148,7 +159,7 @@ index a532c2f..733eb7f 100644
# Identifiers to trigger tasks on nodes
UpdateIdentifier:
-@@ -770,6 +803,27 @@ resources:
+@@ -756,6 +789,27 @@ resources:
SwiftProxyVirtualIP: {get_attr: [VipMap, net_ip_map, {get_param: [ServiceNetMap, SwiftProxyNetwork]}]}
PublicVirtualIP: {get_attr: [VipMap, net_ip_map, external]}
@@ -176,7 +187,7 @@ index a532c2f..733eb7f 100644
Controller:
type: OS::Heat::ResourceGroup
depends_on: Networks
-@@ -853,6 +907,10 @@ resources:
+@@ -839,6 +893,10 @@ resources:
NovaPassword: {get_param: NovaPassword}
NtpServer: {get_param: NtpServer}
MongoDbNoJournal: {get_param: MongoDbNoJournal}
@@ -187,8 +198,8 @@ index a532c2f..733eb7f 100644
PcsdPassword: {get_resource: PcsdPassword}
PublicVirtualInterface: {get_param: PublicVirtualInterface}
RabbitPassword: {get_param: RabbitPassword}
-@@ -948,6 +1006,9 @@ resources:
- NovaPublicIP: {get_attr: [PublicVirtualIP, ip_address]}
+@@ -933,6 +991,9 @@ resources:
+ NovaPublicIP: {get_attr: [VipMap, net_ip_map, external]}
NovaPassword: {get_param: NovaPassword}
NtpServer: {get_param: NtpServer}
+ OpenDaylightPort: {get_param: OpenDaylightPort}
@@ -197,7 +208,7 @@ index a532c2f..733eb7f 100644
RabbitHost: {get_attr: [VipMap, net_ip_map, {get_param: [ServiceNetMap, RabbitMqNetwork]}]}
RabbitPassword: {get_param: RabbitPassword}
RabbitUserName: {get_param: RabbitUserName}
-@@ -1068,6 +1129,7 @@ resources:
+@@ -1053,6 +1114,7 @@ resources:
compute_hosts: {get_attr: [Compute, hosts_entry]}
controller_hosts: {get_attr: [Controller, hosts_entry]}
controller_ips: {get_attr: [Controller, ip_address]}
@@ -230,7 +241,7 @@ index 2bc519b..98283c2 100644
list_join:
- ','
diff --git a/puppet/compute.yaml b/puppet/compute.yaml
-index 70c7403..df6c16f 100644
+index e259cff..d2184bd 100644
--- a/puppet/compute.yaml
+++ b/puppet/compute.yaml
@@ -213,6 +213,19 @@ parameters:
@@ -253,8 +264,8 @@ index 70c7403..df6c16f 100644
RabbitHost:
type: string
default: '' # Has to be here because of the ignored empty value bug
-@@ -406,6 +419,9 @@ resources:
- neutron::rabbit_user: {get_input: rabbit_user}
+@@ -415,6 +428,9 @@ resources:
+ neutron::rabbit_user: {get_input: rabbit_username}
neutron::rabbit_use_ssl: {get_input: rabbit_client_use_ssl}
neutron::rabbit_port: {get_input: rabbit_client_port}
+ opendaylight_port: {get_input: opendaylight_port}
@@ -263,7 +274,7 @@ index 70c7403..df6c16f 100644
neutron_flat_networks: {get_input: neutron_flat_networks}
neutron_host: {get_input: neutron_host}
neutron::agents::ml2::ovs::local_ip: {get_input: neutron_local_ip}
-@@ -459,6 +475,9 @@ resources:
+@@ -468,6 +484,9 @@ resources:
snmpd_readonly_user_name: {get_param: SnmpdReadonlyUserName}
snmpd_readonly_user_password: {get_param: SnmpdReadonlyUserPassword}
glance_api_servers: {get_param: [EndpointMap, GlanceInternal, uri]}
@@ -274,7 +285,7 @@ index 70c7403..df6c16f 100644
neutron_host: {get_param: NeutronHost}
neutron_local_ip: {get_attr: [NetIpMap, net_ip_map, {get_param: [ServiceNetMap, NeutronTenantNetwork]}]}
diff --git a/puppet/controller.yaml b/puppet/controller.yaml
-index ea0b3af..a339eb2 100644
+index fdc1821..955fdc4 100644
--- a/puppet/controller.yaml
+++ b/puppet/controller.yaml
@@ -443,6 +443,23 @@ parameters:
@@ -301,7 +312,7 @@ index ea0b3af..a339eb2 100644
PcsdPassword:
type: string
description: The password for the 'pcsd' user.
-@@ -805,6 +822,10 @@ resources:
+@@ -819,6 +836,10 @@ resources:
template: tripleo-CLUSTER
params:
CLUSTER: {get_param: MysqlClusterUniquePart}
@@ -312,7 +323,7 @@ index ea0b3af..a339eb2 100644
neutron_flat_networks: {get_param: NeutronFlatNetworks}
neutron_metadata_proxy_shared_secret: {get_param: NeutronMetadataProxySharedSecret}
neutron_agent_mode: {get_param: NeutronAgentMode}
-@@ -1136,6 +1157,12 @@ resources:
+@@ -1151,6 +1172,12 @@ resources:
mysql_bind_host: {get_input: mysql_network}
mysql_virtual_ip: {get_input: mysql_virtual_ip}
@@ -364,7 +375,7 @@ index cd41cc7..a81f88d 100644
if 'cisco_n1kv' in hiera('neutron_mechanism_drivers') {
diff --git a/puppet/manifests/overcloud_controller.pp b/puppet/manifests/overcloud_controller.pp
-index 1f6c2be..75bbee7 100644
+index 1b0429b..9f99e45 100644
--- a/puppet/manifests/overcloud_controller.pp
+++ b/puppet/manifests/overcloud_controller.pp
@@ -30,6 +30,13 @@ if hiera('step') >= 1 {
@@ -381,7 +392,7 @@ index 1f6c2be..75bbee7 100644
if count(hiera('ntp::servers')) > 0 {
include ::ntp
}
-@@ -242,10 +249,43 @@ if hiera('step') >= 3 {
+@@ -243,10 +250,43 @@ if hiera('step') >= 3 {
tenant_network_types => [hiera('neutron_tenant_network_type')],
mechanism_drivers => [hiera('neutron_mechanism_drivers')],
}
@@ -428,7 +439,7 @@ index 1f6c2be..75bbee7 100644
if 'cisco_n1kv' in hiera('neutron_mechanism_drivers') {
include ::neutron::plugins::ml2::cisco::nexus1000v
-@@ -281,7 +321,6 @@ if hiera('step') >= 3 {
+@@ -282,7 +322,6 @@ if hiera('step') >= 3 {
Service['neutron-server'] -> Service['neutron-dhcp-service']
Service['neutron-server'] -> Service['neutron-l3']
@@ -437,7 +448,7 @@ index 1f6c2be..75bbee7 100644
include ::cinder
diff --git a/puppet/manifests/overcloud_controller_pacemaker.pp b/puppet/manifests/overcloud_controller_pacemaker.pp
-index 3fb92f3..31c5332 100644
+index 863cc5f..1a99985 100644
--- a/puppet/manifests/overcloud_controller_pacemaker.pp
+++ b/puppet/manifests/overcloud_controller_pacemaker.pp
@@ -380,6 +380,13 @@ if hiera('step') >= 2 {
@@ -454,7 +465,7 @@ index 3fb92f3..31c5332 100644
exec { 'galera-ready' :
command => '/usr/bin/clustercheck >/dev/null',
timeout => 30,
-@@ -614,13 +621,43 @@ if hiera('step') >= 3 {
+@@ -615,13 +622,43 @@ if hiera('step') >= 3 {
tenant_network_types => [hiera('neutron_tenant_network_type')],
mechanism_drivers => [hiera('neutron_mechanism_drivers')],
}
@@ -504,7 +515,7 @@ index 3fb92f3..31c5332 100644
if 'cisco_ucsm' in hiera('neutron_mechanism_drivers') {
include ::neutron::plugins::ml2::cisco::ucsm
}
-@@ -1061,56 +1098,13 @@ if hiera('step') >= 4 {
+@@ -1079,56 +1116,13 @@ if hiera('step') >= 4 {
pacemaker::resource::service { $::neutron::params::dhcp_agent_service:
clone_params => 'interleave=true',
}
@@ -561,7 +572,7 @@ index 3fb92f3..31c5332 100644
pacemaker::constraint::base { 'keystone-to-neutron-server-constraint':
constraint_type => 'order',
first_resource => "${::keystone::params::service_name}-clone",
-@@ -1120,31 +1114,75 @@ if hiera('step') >= 4 {
+@@ -1138,31 +1132,75 @@ if hiera('step') >= 4 {
require => [Pacemaker::Resource::Service[$::keystone::params::service_name],
Pacemaker::Resource::Service[$::neutron::params::server_service]],
}