Allow horizon listening port to be different than reachable port

This adds a horizon_listen_port option, which defaults to horizon_port
for backward compatibility.

This option allow the user to differentiate between the port the
service listens on, and the port the service is reachable on. This is
useful for external load balancers which live on the same host as the
service itself.

Change-Id: I1e47e9524fd9c41bbb2cd2fc80560e53d9296599
Implements: blueprint service-hostnames
This commit is contained in:
Jim Rollenhagen 2018-12-27 15:55:55 -05:00
parent f8a1a716ac
commit 3ee1a7ce3c
4 changed files with 7 additions and 3 deletions

View File

@ -249,6 +249,7 @@ heat_api_cfn_port: "8000"
heat_api_cfn_listen_port: "{{ heat_api_cfn_port }}" heat_api_cfn_listen_port: "{{ heat_api_cfn_port }}"
horizon_port: "80" horizon_port: "80"
horizon_listen_port: "{{ horizon_port }}"
influxdb_admin_port: "8083" influxdb_admin_port: "8083"
influxdb_http_port: "8086" influxdb_http_port: "8086"

View File

@ -49,6 +49,7 @@ horizon_services:
mode: "http" mode: "http"
external: false external: false
port: "{{ horizon_port }}" port: "{{ horizon_port }}"
listen_port: "{{ horizon_listen_port }}"
frontend_http_extra: frontend_http_extra:
- "balance source" - "balance source"
horizon_external: horizon_external:
@ -56,6 +57,7 @@ horizon_services:
mode: "http" mode: "http"
external: true external: true
port: "{% if kolla_enable_tls_external|bool %}443{% else %}{{ horizon_port }}{% endif %}" port: "{% if kolla_enable_tls_external|bool %}443{% else %}{{ horizon_port }}{% endif %}"
listen_port: "{{ horizon_listen_port }}"
frontend_http_extra: frontend_http_extra:
- "balance source" - "balance source"
horizon_external_redirect: horizon_external_redirect:
@ -63,6 +65,7 @@ horizon_services:
mode: "redirect" mode: "redirect"
external: true external: true
port: "{{ horizon_port }}" port: "{{ horizon_port }}"
listen_port: "{{ horizon_listen_port }}"
horizon_keystone_domain_choices: horizon_keystone_domain_choices:
Default: default Default: default

View File

@ -10,7 +10,7 @@
horizon: "{{ horizon_services['horizon'] }}" horizon: "{{ horizon_services['horizon'] }}"
wait_for: wait_for:
host: "{{ api_interface_address }}" host: "{{ api_interface_address }}"
port: "{{ horizon_port }}" port: "{{ horizon_listen_port }}"
connect_timeout: 1 connect_timeout: 1
timeout: 1 timeout: 1
state: stopped state: stopped

View File

@ -1,11 +1,11 @@
{% set python_path = '/usr/share/openstack-dashboard' if horizon_install_type == 'binary' else '/var/lib/kolla/venv/lib/python2.7/site-packages' %} {% set python_path = '/usr/share/openstack-dashboard' if horizon_install_type == 'binary' else '/var/lib/kolla/venv/lib/python2.7/site-packages' %}
Listen {{ api_interface_address }}:{{ horizon_port }} Listen {{ api_interface_address }}:{{ horizon_listen_port }}
ServerSignature Off ServerSignature Off
ServerTokens Prod ServerTokens Prod
TraceEnable off TraceEnable off
<VirtualHost *:{{ horizon_port }}> <VirtualHost *:{{ horizon_listen_port }}>
LogLevel warn LogLevel warn
ErrorLog /var/log/kolla/horizon/horizon.log ErrorLog /var/log/kolla/horizon/horizon.log
LogFormat "%{X-Forwarded-For}i %l %u %t \"%r\" %>s %b %D \"%{Referer}i\" \"%{User-Agent}i\"" logformat LogFormat "%{X-Forwarded-For}i %l %u %t \"%r\" %>s %b %D \"%{Referer}i\" \"%{User-Agent}i\"" logformat