2018-03-05 18:28:35 +00:00
|
|
|
heat_template_version: rocky
|
2016-05-05 15:46:51 +00:00
|
|
|
|
|
|
|
description: >
|
2016-05-31 20:50:19 +00:00
|
|
|
HAproxy service configured with Puppet
|
2016-05-05 15:46:51 +00:00
|
|
|
|
|
|
|
parameters:
|
2017-06-22 15:25:03 +00:00
|
|
|
ServiceData:
|
|
|
|
default: {}
|
|
|
|
description: Dictionary packing service data
|
|
|
|
type: json
|
2016-08-11 21:07:46 +00: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
|
2016-08-17 13:26:05 +00:00
|
|
|
DefaultPasswords:
|
|
|
|
default: {}
|
|
|
|
type: json
|
2017-02-24 11:27:58 +00:00
|
|
|
RoleName:
|
|
|
|
default: ''
|
|
|
|
description: Role name on which the service is applied
|
|
|
|
type: string
|
|
|
|
RoleParameters:
|
|
|
|
default: {}
|
|
|
|
description: Parameters specific to the role
|
|
|
|
type: json
|
2016-05-05 15:46:51 +00:00
|
|
|
EndpointMap:
|
|
|
|
default: {}
|
|
|
|
description: Mapping of service endpoint -> protocol. Typically set
|
|
|
|
via parameter_defaults in the resource registry.
|
|
|
|
type: json
|
2017-07-06 16:39:00 +00:00
|
|
|
EnableLoadBalancer:
|
|
|
|
default: true
|
|
|
|
description: Whether to deploy a LoadBalancer, set to false when an external load balancer is used.
|
|
|
|
type: boolean
|
2016-08-18 16:30:14 +00:00
|
|
|
HAProxyStatsPassword:
|
|
|
|
description: Password for HAProxy stats endpoint
|
|
|
|
hidden: true
|
|
|
|
type: string
|
|
|
|
HAProxyStatsUser:
|
|
|
|
description: User for HAProxy stats endpoint
|
|
|
|
default: admin
|
|
|
|
type: string
|
|
|
|
HAProxySyslogAddress:
|
|
|
|
default: /dev/log
|
|
|
|
description: Syslog address where HAproxy will send its log
|
|
|
|
type: string
|
2017-06-26 11:13:36 +00:00
|
|
|
HAProxyStatsEnabled:
|
|
|
|
default: true
|
|
|
|
description: Whether or not to enable the HAProxy stats interface.
|
|
|
|
type: boolean
|
2016-08-18 16:30:14 +00:00
|
|
|
RedisPassword:
|
2017-06-27 16:01:50 +00:00
|
|
|
description: The password for the redis service account.
|
2016-08-18 16:30:14 +00:00
|
|
|
type: string
|
|
|
|
hidden: true
|
2016-06-09 13:39:22 +00:00
|
|
|
MonitoringSubscriptionHaproxy:
|
|
|
|
default: 'overcloud-haproxy'
|
|
|
|
type: string
|
2017-08-07 11:25:38 +00:00
|
|
|
SSLCertificate:
|
|
|
|
default: ''
|
|
|
|
description: >
|
|
|
|
The content of the SSL certificate (without Key) in PEM format.
|
|
|
|
type: string
|
2018-01-10 16:14:12 +00:00
|
|
|
PublicSSLCertificateAutogenerated:
|
|
|
|
default: false
|
|
|
|
description: >
|
|
|
|
Whether the public SSL certificate was autogenerated or not.
|
|
|
|
type: boolean
|
2018-04-26 14:08:50 +00:00
|
|
|
EnablePublicTLS:
|
|
|
|
default: true
|
|
|
|
description: >
|
|
|
|
Whether to enable TLS on the public interface or not.
|
|
|
|
type: boolean
|
2017-08-07 11:25:38 +00:00
|
|
|
DeployedSSLCertificatePath:
|
|
|
|
default: '/etc/pki/tls/private/overcloud_endpoint.pem'
|
|
|
|
description: >
|
|
|
|
The filepath of the certificate as it will be stored in the controller.
|
|
|
|
type: string
|
2018-09-18 13:39:06 +00:00
|
|
|
EnableInternalTLS:
|
|
|
|
type: boolean
|
|
|
|
default: false
|
2017-04-26 09:36:10 +00:00
|
|
|
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.
|
2017-05-04 12:16:47 +00:00
|
|
|
InternalTLSCRLPEMFile:
|
|
|
|
default: '/etc/pki/CA/crl/overcloud-crl.pem'
|
|
|
|
type: string
|
|
|
|
description: Specifies the default CRL PEM file to use for revocation if
|
|
|
|
TLS is used for services in the internal network.
|
2016-05-05 15:46:51 +00:00
|
|
|
|
2017-08-07 11:25:38 +00:00
|
|
|
conditions:
|
|
|
|
|
|
|
|
public_tls_enabled:
|
2018-04-26 14:08:50 +00:00
|
|
|
and:
|
|
|
|
- {get_param: EnablePublicTLS}
|
|
|
|
- or:
|
|
|
|
- not:
|
|
|
|
equals:
|
|
|
|
- {get_param: SSLCertificate}
|
|
|
|
- ""
|
|
|
|
- equals:
|
|
|
|
- {get_param: PublicSSLCertificateAutogenerated}
|
|
|
|
- true
|
2018-09-18 13:39:06 +00:00
|
|
|
internal_tls_enabled: {equals: [{get_param: EnableInternalTLS}, true]}
|
2017-08-07 11:25:38 +00:00
|
|
|
|
2016-08-17 12:24:23 +00:00
|
|
|
resources:
|
|
|
|
|
|
|
|
HAProxyPublicTLS:
|
|
|
|
type: OS::TripleO::Services::HAProxyPublicTLS
|
|
|
|
properties:
|
2017-06-22 15:25:03 +00:00
|
|
|
ServiceData: {get_param: ServiceData}
|
2016-08-17 12:24:23 +00:00
|
|
|
ServiceNetMap: {get_param: ServiceNetMap}
|
|
|
|
DefaultPasswords: {get_param: DefaultPasswords}
|
|
|
|
EndpointMap: {get_param: EndpointMap}
|
2017-02-24 11:27:58 +00:00
|
|
|
RoleName: {get_param: RoleName}
|
|
|
|
RoleParameters: {get_param: RoleParameters}
|
2016-08-17 12:24:23 +00:00
|
|
|
|
|
|
|
HAProxyInternalTLS:
|
|
|
|
type: OS::TripleO::Services::HAProxyInternalTLS
|
|
|
|
properties:
|
2017-06-22 15:25:03 +00:00
|
|
|
ServiceData: {get_param: ServiceData}
|
2016-08-17 12:24:23 +00:00
|
|
|
ServiceNetMap: {get_param: ServiceNetMap}
|
|
|
|
DefaultPasswords: {get_param: DefaultPasswords}
|
|
|
|
EndpointMap: {get_param: EndpointMap}
|
2017-02-24 11:27:58 +00:00
|
|
|
RoleName: {get_param: RoleName}
|
|
|
|
RoleParameters: {get_param: RoleParameters}
|
2016-08-17 12:24:23 +00:00
|
|
|
|
2016-05-05 15:46:51 +00:00
|
|
|
outputs:
|
|
|
|
role_data:
|
2016-05-31 20:50:19 +00:00
|
|
|
description: Role data for the HAproxy role.
|
2016-05-05 15:46:51 +00:00
|
|
|
value:
|
2016-07-19 20:08:22 +00:00
|
|
|
service_name: haproxy
|
2016-06-09 13:39:22 +00:00
|
|
|
monitoring_subscription: {get_param: MonitoringSubscriptionHaproxy}
|
2016-07-20 14:48:23 +00:00
|
|
|
config_settings:
|
2016-08-17 12:24:23 +00:00
|
|
|
map_merge:
|
|
|
|
- tripleo.haproxy.firewall_rules:
|
|
|
|
'107 haproxy stats':
|
|
|
|
dport: 1993
|
|
|
|
tripleo::haproxy::haproxy_log_address: {get_param: HAProxySyslogAddress}
|
|
|
|
tripleo::haproxy::haproxy_stats_user: {get_param: HAProxyStatsUser}
|
|
|
|
tripleo::haproxy::haproxy_stats_password: {get_param: HAProxyStatsPassword}
|
|
|
|
tripleo::haproxy::redis_password: {get_param: RedisPassword}
|
2017-05-04 12:16:47 +00:00
|
|
|
tripleo::haproxy::crl_file: {get_param: InternalTLSCRLPEMFile}
|
2017-06-26 11:13:36 +00:00
|
|
|
tripleo::haproxy::haproxy_stats: {get_param: HAProxyStatsEnabled}
|
2017-07-06 16:39:00 +00:00
|
|
|
enable_load_balancer: {get_param: EnableLoadBalancer}
|
2016-08-17 12:24:23 +00:00
|
|
|
tripleo::profile::base::haproxy::certificates_specs:
|
|
|
|
map_merge:
|
|
|
|
- get_attr: [HAProxyPublicTLS, role_data, certificates_specs]
|
|
|
|
- get_attr: [HAProxyInternalTLS, role_data, certificates_specs]
|
2017-08-07 11:25:38 +00:00
|
|
|
- if:
|
|
|
|
- public_tls_enabled
|
|
|
|
- tripleo::haproxy::service_certificate: {get_param: DeployedSSLCertificatePath}
|
|
|
|
- {}
|
2018-09-18 13:39:06 +00:00
|
|
|
- if:
|
|
|
|
- internal_tls_enabled
|
|
|
|
- tripleo::haproxy::ca_bundle: {get_param: InternalTLSCAFile}
|
|
|
|
- null
|
2017-08-07 11:25:38 +00:00
|
|
|
- get_attr: [HAProxyPublicTLS, role_data, config_settings]
|
|
|
|
- get_attr: [HAProxyInternalTLS, role_data, config_settings]
|
2016-05-05 15:46:51 +00:00
|
|
|
step_config: |
|
2016-05-31 20:50:19 +00:00
|
|
|
include ::tripleo::profile::base::haproxy
|
2016-12-01 10:00:57 +00:00
|
|
|
upgrade_tasks:
|
2017-02-27 18:04:08 +00:00
|
|
|
- name: Check if haproxy is deployed
|
|
|
|
command: systemctl is-enabled haproxy
|
|
|
|
tags: common
|
|
|
|
ignore_errors: True
|
|
|
|
register: haproxy_enabled
|
2016-12-23 14:07:44 +00:00
|
|
|
- name: "PreUpgrade step0,validation: Check service haproxy is running"
|
|
|
|
shell: /usr/bin/systemctl show 'haproxy' --property ActiveState | grep '\bactive\b'
|
2018-01-31 10:06:53 +00:00
|
|
|
when:
|
|
|
|
- step|int == 0
|
|
|
|
- haproxy_enabled.rc == 0
|
2017-10-11 06:51:08 +00:00
|
|
|
tags: validation
|
2016-12-01 10:00:57 +00:00
|
|
|
- name: Stop haproxy service
|
2018-01-31 10:06:53 +00:00
|
|
|
when:
|
|
|
|
- step|int == 2
|
|
|
|
- haproxy_enabled.rc == 0
|
2016-12-01 10:00:57 +00:00
|
|
|
service: name=haproxy state=stopped
|
|
|
|
- name: Start haproxy service
|
2018-01-31 10:06:53 +00:00
|
|
|
when:
|
|
|
|
- step|int == 4
|
|
|
|
- haproxy_enabled.rc == 0
|
2016-12-01 10:00:57 +00:00
|
|
|
service: name=haproxy state=started
|
2018-05-25 13:52:25 +00:00
|
|
|
host_prep_tasks: {get_attr: [HAProxyPublicTLS, role_data, host_prep_tasks]}
|
2016-12-15 14:20:40 +00:00
|
|
|
metadata_settings:
|
2017-04-25 07:39:16 +00:00
|
|
|
list_concat:
|
|
|
|
- {get_attr: [HAProxyPublicTLS, role_data, metadata_settings]}
|
|
|
|
- {get_attr: [HAProxyInternalTLS, role_data, metadata_settings]}
|