2021-03-25 16:52:04 +05:30
|
|
|
heat_template_version: wallaby
|
2017-01-19 21:37:38 -05:00
|
|
|
|
|
|
|
description: >
|
|
|
|
OpenStack containerized Neutron DHCP service
|
|
|
|
|
|
|
|
parameters:
|
2019-05-13 10:13:04 -04:00
|
|
|
ContainerNeutronDHCPImage:
|
2017-01-19 21:37:38 -05:00
|
|
|
description: image
|
|
|
|
type: string
|
2019-05-13 10:13:04 -04:00
|
|
|
ContainerNeutronConfigImage:
|
2017-06-23 18:21:43 +02:00
|
|
|
description: The container image to use for the neutron config_volume
|
2017-01-19 21:37:38 -05:00
|
|
|
type: string
|
2018-04-11 15:53:22 +05:30
|
|
|
DockerNeutronDHCPAgentUlimit:
|
2019-04-09 10:26:27 +02:00
|
|
|
default: ['nofile=16384']
|
2018-04-11 15:53:22 +05:30
|
|
|
description: ulimit for Neutron DHCP Agent Container
|
|
|
|
type: comma_delimited_list
|
2019-06-05 17:42:29 +02:00
|
|
|
DockerAdditionalSockets:
|
|
|
|
default: ['/var/lib/openstack/docker.sock']
|
|
|
|
description: Additional domain sockets for the docker daemon to bind to (useful for mounting
|
|
|
|
into containers that launch other containers)
|
|
|
|
type: comma_delimited_list
|
2018-03-07 09:34:55 -03:30
|
|
|
NeutronEnableDnsmasqDockerWrapper:
|
|
|
|
description: Generate a dnsmasq wrapper script so that neutron launches
|
|
|
|
dnsmasq in a separate container.
|
|
|
|
type: boolean
|
|
|
|
default: true
|
|
|
|
NeutronEnableHaproxyDockerWrapper:
|
|
|
|
description: Generate a wrapper script so neutron launches haproxy in a separate container.
|
|
|
|
type: boolean
|
|
|
|
default: true
|
2018-09-28 15:15:17 +02:00
|
|
|
Debug:
|
|
|
|
type: boolean
|
|
|
|
default: false
|
|
|
|
description: Set to True to enable debugging on all services.
|
|
|
|
NeutronWrapperDebug:
|
|
|
|
type: boolean
|
|
|
|
default: false
|
|
|
|
description: Controls debugging for the wrapper scripts.
|
|
|
|
ContainerCli:
|
|
|
|
type: string
|
2019-03-04 19:17:04 -05:00
|
|
|
default: 'podman'
|
2018-09-28 15:15:17 +02:00
|
|
|
description: CLI tool used to manage containers.
|
|
|
|
constraints:
|
|
|
|
- allowed_values: ['docker', 'podman']
|
2018-05-18 10:18:43 +02:00
|
|
|
NeutronDhcpAgentLoggingSource:
|
|
|
|
type: json
|
|
|
|
default:
|
|
|
|
tag: openstack.neutron.agent.dhcp
|
2019-07-03 11:49:46 +02:00
|
|
|
file: /var/log/containers/neutron/dhcp-agent.log
|
2017-01-19 21:37:38 -05:00
|
|
|
EndpointMap:
|
|
|
|
default: {}
|
|
|
|
description: Mapping of service endpoint -> protocol. Typically set
|
|
|
|
via parameter_defaults in the resource registry.
|
|
|
|
type: json
|
2017-06-22 17:25:03 +02:00
|
|
|
ServiceData:
|
|
|
|
default: {}
|
|
|
|
description: Dictionary packing service data
|
|
|
|
type: json
|
2017-01-19 21:37:38 -05:00
|
|
|
ServiceNetMap:
|
|
|
|
default: {}
|
|
|
|
description: Mapping of service_name -> network name. Typically set
|
|
|
|
via parameter_defaults in the resource registry. This
|
|
|
|
mapping overrides those in ServiceNetMapDefaults.
|
|
|
|
type: json
|
2017-02-24 06:27:58 -05:00
|
|
|
RoleName:
|
|
|
|
default: ''
|
|
|
|
description: Role name on which the service is applied
|
|
|
|
type: string
|
|
|
|
RoleParameters:
|
|
|
|
default: {}
|
|
|
|
description: Parameters specific to the role
|
2017-05-15 19:06:09 +02:00
|
|
|
type: json
|
2018-02-01 17:06:10 -05:00
|
|
|
EnableInternalTLS:
|
|
|
|
type: boolean
|
|
|
|
default: false
|
|
|
|
InternalTLSCAFile:
|
|
|
|
default: '/etc/ipa/ca.crt'
|
|
|
|
type: string
|
|
|
|
description: Specifies the default CA cert to use if TLS is used for
|
|
|
|
services in the internal network.
|
2019-01-09 16:33:33 -05:00
|
|
|
NeutronEnableMetadataNetwork:
|
|
|
|
default: false
|
|
|
|
description: If True, DHCP provide metadata network. Requires either
|
|
|
|
IsolatedMetadata or ForceMetadata parameters to also be True.
|
|
|
|
type: boolean
|
|
|
|
NeutronEnableIsolatedMetadata:
|
|
|
|
default: false
|
|
|
|
description: If True, DHCP provide metadata route to VM.
|
|
|
|
type: boolean
|
|
|
|
NeutronEnableForceMetadata:
|
|
|
|
default: false
|
|
|
|
description: If True, DHCP always provides metadata route to VM.
|
|
|
|
type: boolean
|
|
|
|
NeutronEnableInternalDNS:
|
|
|
|
default: false
|
|
|
|
description: |
|
|
|
|
If True, enable the internal Neutron DNS server that provides name
|
|
|
|
resolution between VMs. This parameter has no effect if
|
|
|
|
NeutronDhcpAgentDnsmasqDnsServers is set.
|
|
|
|
type: boolean
|
|
|
|
MonitoringSubscriptionNeutronDhcp:
|
|
|
|
default: 'overcloud-neutron-dhcp'
|
|
|
|
type: string
|
|
|
|
NeutronDhcpAgentDebug:
|
2021-03-19 11:50:48 +05:30
|
|
|
default: false
|
2019-01-09 16:33:33 -05:00
|
|
|
description: Set to True to enable debugging for Neutron DHCP agent.
|
2021-03-19 11:50:48 +05:30
|
|
|
type: boolean
|
2019-01-09 16:33:33 -05:00
|
|
|
NeutronDhcpAgentDnsmasqDnsServers:
|
|
|
|
default: []
|
|
|
|
description: List of servers to use as dnsmasq forwarders
|
|
|
|
type: comma_delimited_list
|
|
|
|
NeutronInterfaceDriver:
|
|
|
|
default: 'neutron.agent.linux.interface.OVSInterfaceDriver'
|
|
|
|
description: Neutron DHCP Agent interface driver
|
|
|
|
type: string
|
|
|
|
NeutronDhcpOvsIntegrationBridge:
|
|
|
|
default: ''
|
|
|
|
type: string
|
|
|
|
description: Name of Open vSwitch bridge to use
|
2017-11-30 08:11:29 +02:00
|
|
|
NeutronDhcpServerBroadcastReply:
|
|
|
|
default: false
|
|
|
|
description: Neutron DHCP agent to use broadcast in DHCP replies
|
|
|
|
type: boolean
|
2019-05-22 16:07:36 +02:00
|
|
|
# TODO(bogdando): The experimental OVN SRIOV environment includes the
|
|
|
|
# DHCP agent service. We keep it safe to not break it with AZ-related
|
|
|
|
# configurations. Therefore, we have to determine, if
|
|
|
|
# NeutronMechanismDrivers is OVN or not. This may change in future,
|
|
|
|
# when OVN/SRIOV supports Neutron AZ configurations for the agent services.
|
|
|
|
NeutronMechanismDrivers:
|
|
|
|
default: 'ovn'
|
|
|
|
description: |
|
|
|
|
The mechanism drivers for the Neutron tenant network.
|
|
|
|
type: comma_delimited_list
|
|
|
|
NeutronDhcpAgentAvailabilityZone:
|
|
|
|
description: Availability zone for Neutron DHCP agent. If not set,
|
|
|
|
no AZs will be configured for Neutron network services.
|
|
|
|
default: ''
|
|
|
|
type: string
|
2020-02-27 20:48:10 +01:00
|
|
|
NeutronDhcpAgentDnsmasqEnableAddr6List:
|
|
|
|
default: true
|
|
|
|
description: |
|
|
|
|
Enable dhcp-host entry with list of addresses when port has multiple
|
|
|
|
IPv6 addresses in the same subnet.
|
|
|
|
type: boolean
|
2020-11-26 09:50:35 -03:00
|
|
|
CertificateKeySize:
|
|
|
|
type: string
|
|
|
|
default: '2048'
|
|
|
|
description: Specifies the private key size used when creating the
|
|
|
|
certificate.
|
|
|
|
NeutronDhcpCertificateKeySize:
|
|
|
|
type: string
|
|
|
|
default: ''
|
|
|
|
description: Override the private key size used when creating the
|
|
|
|
certificate for this service
|
2018-02-01 17:06:10 -05:00
|
|
|
|
|
|
|
conditions:
|
|
|
|
|
|
|
|
internal_tls_enabled: {equals: [{get_param: EnableInternalTLS}, true]}
|
2018-03-07 09:34:55 -03:30
|
|
|
dnsmasq_wrapper_enabled: {equals: [{get_param: NeutronEnableDnsmasqDockerWrapper}, true]}
|
|
|
|
haproxy_wrapper_enabled: {equals: [{get_param: NeutronEnableHaproxyDockerWrapper}, true]}
|
2018-09-28 15:15:17 +02:00
|
|
|
docker_enabled: {equals: [{get_param: ContainerCli}, 'docker']}
|
2019-01-09 16:33:33 -05:00
|
|
|
dhcp_ovs_intergation_bridge_unset: {equals: [{get_param: NeutronDhcpOvsIntegrationBridge}, '']}
|
2019-05-22 16:07:36 +02:00
|
|
|
az_unset: {equals: [{get_param: NeutronDhcpAgentAvailabilityZone}, '']}
|
2020-11-26 09:50:35 -03:00
|
|
|
key_size_override_unset: {equals: [{get_param: NeutronDhcpCertificateKeySize}, '']}
|
2017-01-19 21:37:38 -05:00
|
|
|
|
|
|
|
resources:
|
|
|
|
|
2017-04-13 13:46:31 +00:00
|
|
|
ContainersCommon:
|
2019-04-05 12:16:13 -04:00
|
|
|
type: ../containers-common.yaml
|
2017-04-13 13:46:31 +00:00
|
|
|
|
2017-01-19 21:37:38 -05:00
|
|
|
NeutronBase:
|
2019-04-22 09:52:04 -04:00
|
|
|
type: ./neutron-base.yaml
|
2017-01-19 21:37:38 -05:00
|
|
|
properties:
|
|
|
|
EndpointMap: {get_param: EndpointMap}
|
2017-06-22 17:25:03 +02:00
|
|
|
ServiceData: {get_param: ServiceData}
|
2017-01-19 21:37:38 -05:00
|
|
|
ServiceNetMap: {get_param: ServiceNetMap}
|
2017-02-24 06:27:58 -05:00
|
|
|
RoleName: {get_param: RoleName}
|
|
|
|
RoleParameters: {get_param: RoleParameters}
|
2017-01-19 21:37:38 -05:00
|
|
|
|
2017-10-09 10:01:07 +00:00
|
|
|
NeutronLogging:
|
|
|
|
type: OS::TripleO::Services::Logging::NeutronCommon
|
2018-02-09 09:49:39 +00:00
|
|
|
properties:
|
|
|
|
NeutronServiceName: dhcp-agent
|
2017-10-09 10:01:07 +00:00
|
|
|
|
2017-01-19 21:37:38 -05:00
|
|
|
outputs:
|
|
|
|
role_data:
|
|
|
|
description: Role data for the Neutron DHCP role.
|
|
|
|
value:
|
2019-01-09 16:33:33 -05:00
|
|
|
service_name: neutron_dhcp
|
2019-08-19 10:38:24 -05:00
|
|
|
firewall_rules:
|
|
|
|
'115 neutron dhcp input':
|
|
|
|
ipversion: 'ipv4'
|
|
|
|
proto: 'udp'
|
|
|
|
dport: 67
|
|
|
|
'116 neutron dhcp output':
|
|
|
|
ipversion: 'ipv4'
|
|
|
|
proto: 'udp'
|
|
|
|
chain: 'OUTPUT'
|
|
|
|
dport: 68
|
|
|
|
'115 neutron dhcpv6 input':
|
|
|
|
ipversion: 'ipv6'
|
|
|
|
proto: 'udp'
|
|
|
|
dport: 547
|
|
|
|
'116 neutron dhcpv6 output':
|
|
|
|
ipversion: 'ipv6'
|
|
|
|
proto: 'udp'
|
|
|
|
chain: 'OUTPUT'
|
|
|
|
dport: 546
|
|
|
|
'116 neutron dhcpv6 relay output':
|
|
|
|
ipversion: 'ipv6'
|
|
|
|
proto: 'udp'
|
|
|
|
chain: 'OUTPUT'
|
|
|
|
dport: 547
|
2019-01-09 16:33:33 -05:00
|
|
|
monitoring_subscription: {get_param: MonitoringSubscriptionNeutronDhcp}
|
2017-01-19 21:37:38 -05:00
|
|
|
config_settings:
|
|
|
|
map_merge:
|
|
|
|
- get_attr: [NeutronBase, role_data, config_settings]
|
2017-10-09 10:01:07 +00:00
|
|
|
- get_attr: [NeutronLogging, config_settings]
|
2020-05-01 07:43:54 -06:00
|
|
|
- tripleo::profile::base::neutron::dhcp_agent_wrappers::enable_dnsmasq_wrapper: {get_param: NeutronEnableDnsmasqDockerWrapper}
|
|
|
|
tripleo::profile::base::neutron::dhcp_agent_wrappers::dnsmasq_process_wrapper: '/var/lib/neutron/dnsmasq_wrapper'
|
|
|
|
tripleo::profile::base::neutron::dhcp_agent_wrappers::dnsmasq_image: {get_param: ContainerNeutronDHCPImage}
|
|
|
|
tripleo::profile::base::neutron::dhcp_agent_wrappers::enable_haproxy_wrapper: {get_param: NeutronEnableHaproxyDockerWrapper}
|
|
|
|
tripleo::profile::base::neutron::dhcp_agent_wrappers::haproxy_process_wrapper: '/var/lib/neutron/dhcp_haproxy_wrapper'
|
|
|
|
tripleo::profile::base::neutron::dhcp_agent_wrappers::haproxy_image: {get_param: ContainerNeutronDHCPImage}
|
|
|
|
tripleo::profile::base::neutron::dhcp_agent_wrappers::debug:
|
|
|
|
if:
|
|
|
|
- {get_param: NeutronWrapperDebug}
|
2021-03-19 11:50:48 +05:30
|
|
|
- true
|
|
|
|
- {get_param: Debug }
|
2020-05-01 07:43:54 -06:00
|
|
|
tripleo::profile::base::neutron::container_cli: {get_param: ContainerCli}
|
|
|
|
neutron::agents::dhcp::enable_isolated_metadata: {get_param: NeutronEnableIsolatedMetadata}
|
2019-01-09 16:33:33 -05:00
|
|
|
neutron::agents::dhcp::enable_force_metadata: {get_param: NeutronEnableForceMetadata}
|
|
|
|
neutron::agents::dhcp::enable_metadata_network: {get_param: NeutronEnableMetadataNetwork}
|
|
|
|
neutron::agents::dhcp::dnsmasq_local_resolv: {get_param: NeutronEnableInternalDNS}
|
|
|
|
neutron::agents::dhcp::dnsmasq_dns_servers: {get_param: NeutronDhcpAgentDnsmasqDnsServers}
|
|
|
|
neutron::agents::dhcp::interface_driver: {get_param: NeutronInterfaceDriver}
|
2017-11-30 08:11:29 +02:00
|
|
|
neutron::agents::dhcp::dhcp_broadcast_reply: {get_param: NeutronDhcpServerBroadcastReply}
|
2020-02-27 20:48:10 +01:00
|
|
|
neutron::agents::dhcp::dnsmasq_enable_addr6_list: {get_param: NeutronDhcpAgentDnsmasqEnableAddr6List}
|
2019-01-09 16:33:33 -05:00
|
|
|
neutron::agents::dhcp::debug:
|
|
|
|
if:
|
|
|
|
- {get_param: NeutronDhcpAgentDebug}
|
2021-03-19 11:50:48 +05:30
|
|
|
- true
|
|
|
|
- {get_param: Debug}
|
2019-01-09 16:33:33 -05:00
|
|
|
- if:
|
|
|
|
- internal_tls_enabled
|
|
|
|
- neutron::agents::dhcp::ovsdb_agent_ssl_key_file: '/etc/pki/tls/private/neutron.key'
|
|
|
|
neutron::agents::dhcp::ovsdb_agent_ssl_cert_file: '/etc/pki/tls/certs/neutron.crt'
|
|
|
|
neutron::agents::dhcp::ovsdb_agent_ssl_ca_file: {get_param: InternalTLSCAFile}
|
|
|
|
- {}
|
|
|
|
- if:
|
|
|
|
- dhcp_ovs_intergation_bridge_unset
|
|
|
|
- {}
|
|
|
|
- neutron::agents::dhcp::ovs_integration_bridge: {get_param: NeutronDhcpOvsIntegrationBridge}
|
2019-05-22 16:07:36 +02:00
|
|
|
- if:
|
2021-03-26 11:56:20 +00:00
|
|
|
- az_unset
|
2019-05-22 16:07:36 +02:00
|
|
|
- {}
|
|
|
|
- neutron::agents::dhcp::availability_zone: {get_param: NeutronDhcpAgentAvailabilityZone}
|
2018-05-18 10:18:43 +02:00
|
|
|
service_config_settings:
|
|
|
|
map_merge:
|
|
|
|
- get_attr: [NeutronBase, role_data, service_config_settings]
|
2019-07-03 11:49:46 +02:00
|
|
|
- rsyslog:
|
|
|
|
tripleo_logging_sources_neutron_dhcp:
|
2018-05-18 10:18:43 +02:00
|
|
|
- {get_param: NeutronDhcpAgentLoggingSource}
|
2017-01-19 21:37:38 -05:00
|
|
|
# BEGIN DOCKER SETTINGS
|
2017-03-01 03:09:31 +00:00
|
|
|
puppet_config:
|
|
|
|
config_volume: neutron
|
|
|
|
puppet_tags: neutron_config,neutron_dhcp_agent_config
|
2019-01-09 16:33:33 -05:00
|
|
|
step_config: |
|
|
|
|
include tripleo::profile::base::neutron::dhcp
|
2019-05-13 10:13:04 -04:00
|
|
|
config_image: {get_param: ContainerNeutronConfigImage}
|
2017-01-19 21:37:38 -05:00
|
|
|
kolla_config:
|
2017-03-29 14:11:21 +02:00
|
|
|
/var/lib/kolla/config_files/neutron_dhcp.json:
|
2018-02-09 09:49:39 +00:00
|
|
|
command:
|
|
|
|
list_join:
|
|
|
|
- ' '
|
|
|
|
- - /usr/bin/neutron-dhcp-agent --config-file /usr/share/neutron/neutron-dist.conf --config-file /etc/neutron/neutron.conf --config-file /etc/neutron/dhcp_agent.ini --config-dir /etc/neutron/conf.d/common --config-dir /etc/neutron/conf.d/neutron-dhcp-agent
|
|
|
|
- get_attr: [NeutronLogging, cmd_extra_args]
|
2017-06-21 16:02:55 +02:00
|
|
|
config_files:
|
|
|
|
- source: "/var/lib/kolla/config_files/src/*"
|
|
|
|
dest: "/"
|
|
|
|
merge: true
|
|
|
|
preserve_properties: true
|
2018-04-30 12:46:42 +02:00
|
|
|
- source: "/var/lib/kolla/config_files/src-tls/*"
|
|
|
|
dest: "/"
|
|
|
|
merge: true
|
|
|
|
preserve_properties: true
|
|
|
|
optional: true
|
2017-03-07 17:12:36 +01:00
|
|
|
permissions:
|
|
|
|
- path: /var/log/neutron
|
|
|
|
owner: neutron:neutron
|
|
|
|
recurse: true
|
2017-07-19 13:04:29 -02:30
|
|
|
- path: /var/lib/neutron
|
|
|
|
owner: neutron:neutron
|
|
|
|
recurse: true
|
2018-03-26 15:15:56 -07:00
|
|
|
- path: /etc/pki/tls/certs/neutron.crt
|
|
|
|
owner: neutron:neutron
|
|
|
|
- path: /etc/pki/tls/private/neutron.key
|
|
|
|
owner: neutron:neutron
|
2019-03-05 19:22:34 -05:00
|
|
|
container_config_scripts: {get_attr: [ContainersCommon, container_config_scripts]}
|
2017-01-19 21:37:38 -05:00
|
|
|
docker_config:
|
2020-05-01 07:43:54 -06:00
|
|
|
step_2:
|
|
|
|
create_dnsmasq_wrapper:
|
|
|
|
start_order: 1
|
|
|
|
detach: false
|
|
|
|
net: host
|
|
|
|
pid: host
|
|
|
|
user: root
|
|
|
|
command: # '/container_puppet_apply.sh "STEP" "TAGS" "CONFIG" "DEBUG"'
|
|
|
|
list_concat:
|
|
|
|
-
|
|
|
|
- '/container_puppet_apply.sh'
|
|
|
|
- '4'
|
|
|
|
- 'file'
|
|
|
|
- 'include ::tripleo::profile::base::neutron::dhcp_agent_wrappers'
|
|
|
|
image: {get_param: ContainerNeutronDHCPImage}
|
|
|
|
volumes:
|
|
|
|
list_concat:
|
|
|
|
- {get_attr: [ContainersCommon, container_puppet_apply_volumes]}
|
|
|
|
-
|
|
|
|
- /run/openvswitch:/run/openvswitch:shared,z
|
|
|
|
- /var/lib/neutron:/var/lib/neutron:shared,z
|
2017-01-19 21:37:38 -05:00
|
|
|
step_4:
|
|
|
|
neutron_dhcp:
|
2017-11-28 12:15:14 -07:00
|
|
|
start_order: 10
|
2019-05-13 10:13:04 -04:00
|
|
|
image: {get_param: ContainerNeutronDHCPImage}
|
2017-01-19 21:37:38 -05:00
|
|
|
net: host
|
|
|
|
pid: host
|
|
|
|
privileged: true
|
|
|
|
restart: always
|
2018-10-19 10:15:01 +02:00
|
|
|
security_opt: 'label=disable'
|
2019-04-02 09:37:21 -02:30
|
|
|
depends_on:
|
2020-01-13 22:49:25 -05:00
|
|
|
- openvswitch.service
|
2019-05-15 14:37:58 -04:00
|
|
|
healthcheck: {get_attr: [ContainersCommon, healthcheck_rpc_port]}
|
2018-04-11 15:53:22 +05:30
|
|
|
ulimit: {get_param: DockerNeutronDHCPAgentUlimit}
|
2017-01-19 21:37:38 -05:00
|
|
|
volumes:
|
2017-04-25 10:55:25 +03:00
|
|
|
list_concat:
|
|
|
|
- {get_attr: [ContainersCommon, volumes]}
|
2017-10-09 10:01:07 +00:00
|
|
|
- {get_attr: [NeutronLogging, volumes]}
|
2017-04-25 10:55:25 +03:00
|
|
|
-
|
|
|
|
- /var/lib/kolla/config_files/neutron_dhcp.json:/var/lib/kolla/config_files/config.json:ro
|
2019-12-04 08:47:19 +02:00
|
|
|
- /var/lib/config-data/puppet-generated/neutron:/var/lib/kolla/config_files/src:ro
|
2017-04-25 10:55:25 +03:00
|
|
|
- /lib/modules:/lib/modules:ro
|
2019-11-26 12:26:45 +00:00
|
|
|
- /run/openvswitch:/run/openvswitch:shared,z
|
2018-10-19 10:15:01 +02:00
|
|
|
- /var/lib/neutron:/var/lib/neutron:shared,z
|
2018-12-20 13:34:47 +05:30
|
|
|
- /run/netns:/run/netns:shared
|
2019-06-05 17:42:29 +02:00
|
|
|
- /var/lib/neutron/kill_scripts:/etc/neutron/kill_scripts:shared,z
|
2018-09-28 15:15:17 +02:00
|
|
|
-
|
|
|
|
if:
|
|
|
|
- docker_enabled
|
|
|
|
- - /var/lib/openstack:/var/lib/openstack
|
|
|
|
- null
|
2018-03-07 09:34:55 -03:30
|
|
|
-
|
|
|
|
if:
|
|
|
|
- dnsmasq_wrapper_enabled
|
2020-05-01 07:43:54 -06:00
|
|
|
- - /var/lib/neutron/dnsmasq_wrapper:/usr/local/bin/dnsmasq:ro
|
2018-03-07 09:34:55 -03:30
|
|
|
- null
|
|
|
|
-
|
|
|
|
if:
|
|
|
|
- haproxy_wrapper_enabled
|
2020-05-01 07:43:54 -06:00
|
|
|
- - /var/lib/neutron/dhcp_haproxy_wrapper:/usr/local/bin/haproxy:ro
|
2018-03-07 09:34:55 -03:30
|
|
|
- null
|
2018-02-01 17:06:10 -05:00
|
|
|
-
|
|
|
|
if:
|
|
|
|
- internal_tls_enabled
|
2018-04-30 12:46:42 +02:00
|
|
|
- - /etc/pki/tls/certs/neutron.crt:/var/lib/kolla/config_files/src-tls/etc/pki/tls/certs/neutron.crt:ro
|
|
|
|
- /etc/pki/tls/private/neutron.key:/var/lib/kolla/config_files/src-tls/etc/pki/tls/private/neutron.key:ro
|
2018-02-01 17:06:10 -05:00
|
|
|
- null
|
2017-01-19 21:37:38 -05:00
|
|
|
environment:
|
2019-10-07 23:36:43 -04:00
|
|
|
KOLLA_CONFIG_STRATEGY: COPY_ALWAYS
|
2018-02-01 17:06:10 -05:00
|
|
|
metadata_settings:
|
2019-02-18 18:35:46 +02:00
|
|
|
if:
|
|
|
|
- internal_tls_enabled
|
|
|
|
-
|
|
|
|
- service: neutron
|
|
|
|
network: {get_param: [ServiceNetMap, NeutronApiNetwork]}
|
|
|
|
type: node
|
|
|
|
- null
|
2021-01-21 16:37:32 +01:00
|
|
|
deploy_steps_tasks:
|
2021-03-17 10:19:54 +01:00
|
|
|
- name: Certificate generation
|
|
|
|
when:
|
|
|
|
- step|int == 1
|
|
|
|
- enable_internal_tls
|
|
|
|
block:
|
|
|
|
- include_role:
|
|
|
|
name: linux-system-roles.certificate
|
|
|
|
vars:
|
|
|
|
certificate_requests:
|
|
|
|
- name: neutron
|
|
|
|
dns:
|
|
|
|
str_replace:
|
|
|
|
template: "{{fqdn_$NETWORK}}"
|
|
|
|
params:
|
|
|
|
$NETWORK: {get_param: [ServiceNetMap, NeutronApiNetwork]}
|
|
|
|
principal:
|
|
|
|
str_replace:
|
|
|
|
template: "neutron/{{fqdn_$NETWORK}}@{{idm_realm}}"
|
|
|
|
params:
|
|
|
|
$NETWORK: {get_param: [ServiceNetMap, NeutronApiNetwork]}
|
|
|
|
run_after: |
|
|
|
|
container_name=$({{container_cli}} ps --format=\{\{.Names\}\} | grep neutron_dhcp)
|
|
|
|
# The certificate is also installed on the computes, but neutron_dhcp is only
|
|
|
|
# present on the controllers, so we exit if the container could not be found.
|
|
|
|
[[ -z $container_name ]] && exit 0
|
2021-01-21 16:37:32 +01:00
|
|
|
|
2021-03-17 10:19:54 +01:00
|
|
|
service_crt="/etc/pki/tls/certs/neutron.crt"
|
|
|
|
service_key="/etc/pki/tls/private/neutron.key"
|
|
|
|
# Copy the new cert from the mount-point to the real path
|
|
|
|
{{container_cli}} exec -u root "$container_name" cp "/var/lib/kolla/config_files/src-tls$service_crt" "$service_crt"
|
|
|
|
# Copy the new key from the mount-point to the real path
|
|
|
|
{{container_cli}} exec -u root "$container_name" cp "/var/lib/kolla/config_files/src-tls$service_key "$service_key"
|
|
|
|
# No need to trigger a reload for neutron dhcpd since the cert is not cached
|
|
|
|
key_size:
|
|
|
|
if:
|
|
|
|
- key_size_override_unset
|
|
|
|
- {get_param: CertificateKeySize}
|
|
|
|
- {get_param: NeutronDhcpCertificateKeySize}
|
|
|
|
ca: ipa
|
2017-03-07 17:12:36 +01:00
|
|
|
host_prep_tasks:
|
2017-10-09 10:01:07 +00:00
|
|
|
list_concat:
|
|
|
|
- {get_attr: [NeutronLogging, host_prep_tasks]}
|
2019-01-15 16:13:33 +05:30
|
|
|
- - name: create /run/netns with temp namespace
|
|
|
|
command: ip netns add ns_temp
|
|
|
|
register: ipnetns_add_result
|
2020-03-03 11:59:14 -05:00
|
|
|
failed_when: false
|
2020-06-17 09:51:05 -06:00
|
|
|
- name: remove temp namespace
|
2019-01-15 16:13:33 +05:30
|
|
|
command: ip netns delete ns_temp
|
2020-03-03 11:59:14 -05:00
|
|
|
failed_when: false
|
2020-06-11 09:51:45 -04:00
|
|
|
when:
|
2020-09-25 09:43:58 -04:00
|
|
|
- ipnetns_add_result.rc is defined
|
2020-06-11 09:51:45 -04:00
|
|
|
- ipnetns_add_result.rc == 0
|
2020-06-17 09:51:05 -06:00
|
|
|
- name: create /var/lib/neutron
|
2017-10-09 10:01:07 +00:00
|
|
|
file:
|
|
|
|
path: /var/lib/neutron
|
|
|
|
state: directory
|
2020-02-07 13:33:20 +01:00
|
|
|
setype: container_file_t
|
2019-11-12 15:04:20 +05:30
|
|
|
- name: enable virt_sandbox_use_netlink for healthcheck
|
2019-01-10 13:56:56 +01:00
|
|
|
seboolean:
|
|
|
|
name: virt_sandbox_use_netlink
|
|
|
|
persistent: yes
|
|
|
|
state: yes
|
2020-06-17 09:51:05 -06:00
|
|
|
- name: set conditions
|
|
|
|
set_fact:
|
|
|
|
dnsmasq_wrapper_enabled: {get_param: NeutronEnableDnsmasqDockerWrapper}
|
|
|
|
haproxy_wrapper_enabled: {get_param: NeutronEnableHaproxyDockerWrapper}
|
|
|
|
debug_enabled:
|
|
|
|
if:
|
|
|
|
- {get_param: NeutronWrapperDebug}
|
2021-03-19 11:50:48 +05:30
|
|
|
- true
|
|
|
|
- {get_param: Debug }
|
2020-06-17 09:51:05 -06:00
|
|
|
docker_additional_sockets: {get_param: DockerAdditionalSockets}
|
|
|
|
- name: create kill_scripts directory within /var/lib/neutron
|
|
|
|
file:
|
|
|
|
state: directory
|
|
|
|
path: /var/lib/neutron/kill_scripts
|
|
|
|
- name: create dnsmasq dhcp kill script
|
|
|
|
when: dnsmasq_wrapper_enabled|bool
|
|
|
|
copy:
|
|
|
|
dest: /var/lib/neutron/kill_scripts/dnsmasq-kill
|
|
|
|
mode: 0755
|
|
|
|
content: {get_file: ./kill-script}
|
|
|
|
- name: create haproxy kill script
|
|
|
|
when: haproxy_wrapper_enabled|bool
|
|
|
|
copy:
|
|
|
|
dest: /var/lib/neutron/kill_scripts/haproxy-kill
|
|
|
|
mode: 0755
|
|
|
|
content: {get_file: ./kill-script}
|
2018-12-04 14:36:12 -05:00
|
|
|
upgrade_tasks: []
|
2018-05-10 15:03:41 -02:30
|
|
|
post_upgrade_tasks:
|
|
|
|
- name: Check for neutron user
|
|
|
|
getent:
|
|
|
|
database: passwd
|
|
|
|
key: neutron
|
2020-03-03 11:59:14 -05:00
|
|
|
fail_key: false
|
2018-05-10 15:03:41 -02:30
|
|
|
- name: Set neutron_user_avail
|
|
|
|
set_fact:
|
|
|
|
neutron_user_avail: "{{ getent_passwd is defined }}"
|
|
|
|
- when:
|
|
|
|
- step|int == 2
|
|
|
|
- neutron_user_avail|bool
|
|
|
|
block:
|
|
|
|
- name: Ensure read/write access for files created after upgrade
|
|
|
|
become: true
|
|
|
|
shell: |
|
|
|
|
umask 0002
|
|
|
|
setfacl -d -R -m u:neutron:rwx /var/lib/neutron
|
|
|
|
setfacl -R -m u:neutron:rw /var/lib/neutron
|
|
|
|
find /var/lib/neutron -type d -exec setfacl -m u:neutron:rwx '{}' \;
|
|
|
|
- name: Provide access for domain sockets
|
|
|
|
become: true
|
|
|
|
shell: |
|
|
|
|
umask 0002
|
|
|
|
setfacl -m u:neutron:rwx "{{ item }}"
|
|
|
|
with_items:
|
|
|
|
- /var/lib/neutron/metadata_proxy
|
|
|
|
- /var/lib/neutron
|
|
|
|
# These files are not necessarily present
|
2020-03-03 11:59:14 -05:00
|
|
|
failed_when: false
|