Implement horizon venv support
This commit conditionally allows the os_horizon role to install build and deploy within a venv. This is the new default behavior of the role however the functionality can be disabled. Change-Id: I136eed8bd40f4ae5bc77f3fa925e4cbc6f842271 Implements: blueprint enable-venv-support-within-the-roles Signed-off-by: Kevin Carter <kevin.carter@rackspace.com>
This commit is contained in:
parent
d39f7b8d7d
commit
61827ccfbd
@ -13,13 +13,22 @@
|
|||||||
# See the License for the specific language governing permissions and
|
# See the License for the specific language governing permissions and
|
||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
# Defines that the role will be deployed on a host machine
|
|
||||||
is_metal: true
|
|
||||||
|
|
||||||
## Verbosity Options
|
## Verbosity Options
|
||||||
debug: False
|
debug: False
|
||||||
verbose: True
|
verbose: True
|
||||||
|
|
||||||
|
# Name of the virtual env to deploy into
|
||||||
|
horizon_venv_tag: untagged
|
||||||
|
horizon_venv_bin: "/openstack/venvs/horizon-{{ horizon_venv_tag }}/bin"
|
||||||
|
|
||||||
|
# Set this to enable or disable installing in a venv
|
||||||
|
horizon_venv_enabled: true
|
||||||
|
|
||||||
|
# The bin path defaults to the venv path however if installation in a
|
||||||
|
# venv is disabled the bin path will be dynamically set based on the
|
||||||
|
# system path used when the installing.
|
||||||
|
horizon_bin: "{{ horizon_venv_bin }}"
|
||||||
|
|
||||||
## System info
|
## System info
|
||||||
horizon_system_user_name: horizon
|
horizon_system_user_name: horizon
|
||||||
horizon_system_group_name: www-data
|
horizon_system_group_name: www-data
|
||||||
@ -44,7 +53,10 @@ horizon_session_timeout: 1800
|
|||||||
horizon_help_url: http://docs.openstack.org
|
horizon_help_url: http://docs.openstack.org
|
||||||
|
|
||||||
## Installation directories
|
## Installation directories
|
||||||
horizon_lib_dir: /usr/local/lib/python2.7/dist-packages
|
horizon_venv_lib_dir: "{{ horizon_bin | dirname }}/lib/python2.7/dist-packages"
|
||||||
|
horizon_non_venv_lib_dir: "/usr/local/lib/python2.7/dist-packages"
|
||||||
|
horizon_lib_dir: "{{ (horizon_venv_enabled | bool) | ternary(horizon_venv_lib_dir, horizon_non_venv_lib_dir) }}"
|
||||||
|
horizon_lib_wsgi_file: "{{ horizon_lib_dir }}/openstack_dashboard/wsgi/django.wsgi"
|
||||||
|
|
||||||
horizon_endpoint_type: internalURL
|
horizon_endpoint_type: internalURL
|
||||||
|
|
||||||
@ -115,6 +127,11 @@ horizon_apt_packages:
|
|||||||
- libxslt1.1
|
- libxslt1.1
|
||||||
- openssl
|
- openssl
|
||||||
|
|
||||||
|
# horizon packages that must be installed before anything else
|
||||||
|
horizon_requires_pip_packages:
|
||||||
|
- virtualenv
|
||||||
|
- python-keystoneclient # Keystoneclient needed to OSA keystone lib
|
||||||
|
|
||||||
horizon_pip_packages:
|
horizon_pip_packages:
|
||||||
- django-appconf
|
- django-appconf
|
||||||
- greenlet
|
- greenlet
|
||||||
|
@ -40,19 +40,21 @@
|
|||||||
- horizon-db-setup
|
- horizon-db-setup
|
||||||
|
|
||||||
- name: Perform a horizon DB sync
|
- name: Perform a horizon DB sync
|
||||||
command: horizon-manage.py syncdb --noinput
|
command: "{{ horizon_bin }}/horizon-manage.py syncdb --noinput"
|
||||||
sudo: yes
|
sudo: yes
|
||||||
sudo_user: "{{ horizon_system_user_name }}"
|
sudo_user: "{{ horizon_system_user_name }}"
|
||||||
tags:
|
tags:
|
||||||
|
- horizon-db-setup
|
||||||
- horizon-db-sync
|
- horizon-db-sync
|
||||||
- horizon-setup
|
- horizon-setup
|
||||||
|
- horizon-command-bin
|
||||||
|
|
||||||
- name: Register DB session cleanup cron
|
- name: Register DB session cleanup cron
|
||||||
cron:
|
cron:
|
||||||
name: "Clear out expired sessions"
|
name: "Clear out expired sessions"
|
||||||
minute: "{{ 58 | random(start=2) }}"
|
minute: "{{ 58 | random(start=2) }}"
|
||||||
hour: 21
|
hour: 21
|
||||||
job: "/usr/local/bin/horizon-manage.py clearsessions"
|
job: "{{ horizon_bin }}/horizon-manage.py clearsessions"
|
||||||
user: "{{ horizon_system_user_name }}"
|
user: "{{ horizon_system_user_name }}"
|
||||||
state: present
|
state: present
|
||||||
tags:
|
tags:
|
||||||
|
@ -37,7 +37,24 @@
|
|||||||
- horizon-install
|
- horizon-install
|
||||||
- horizon-apt-packages
|
- horizon-apt-packages
|
||||||
|
|
||||||
- name: Install pip packages
|
- name: Install pip packages (venv)
|
||||||
|
pip:
|
||||||
|
name: "{{ item }}"
|
||||||
|
state: present
|
||||||
|
virtualenv: "{{ horizon_venv_bin | dirname }}"
|
||||||
|
virtualenv_site_packages: "no"
|
||||||
|
extra_args: "{{ pip_install_options|default('') }}"
|
||||||
|
register: install_packages
|
||||||
|
until: install_packages|success
|
||||||
|
retries: 5
|
||||||
|
delay: 2
|
||||||
|
with_items:
|
||||||
|
- "{{ horizon_pip_packages }}"
|
||||||
|
when: horizon_venv_enabled | bool
|
||||||
|
tags:
|
||||||
|
- horizon-pip-packages
|
||||||
|
|
||||||
|
- name: Install pip packages (no venv)
|
||||||
pip:
|
pip:
|
||||||
name: "{{ item }}"
|
name: "{{ item }}"
|
||||||
state: present
|
state: present
|
||||||
@ -48,6 +65,6 @@
|
|||||||
delay: 2
|
delay: 2
|
||||||
with_items:
|
with_items:
|
||||||
- "{{ horizon_pip_packages }}"
|
- "{{ horizon_pip_packages }}"
|
||||||
|
when: not horizon_venv_enabled | bool
|
||||||
tags:
|
tags:
|
||||||
- horizon-install
|
|
||||||
- horizon-pip-packages
|
- horizon-pip-packages
|
||||||
|
@ -13,6 +13,25 @@
|
|||||||
# See the License for the specific language governing permissions and
|
# See the License for the specific language governing permissions and
|
||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
|
# Because there is no specific "horizon" command this method
|
||||||
|
# is looking for the "keystone" command to set the horizon
|
||||||
|
# command path.
|
||||||
|
- name: Get horizon command path
|
||||||
|
command: which keystone
|
||||||
|
register: horizon_command_path
|
||||||
|
when:
|
||||||
|
- not horizon_venv_enabled | bool
|
||||||
|
tags:
|
||||||
|
- horizon-command-bin
|
||||||
|
|
||||||
|
- name: Set horizon command path
|
||||||
|
set_fact:
|
||||||
|
horizon_bin: "{{ horizon_command_path.stdout | dirname }}"
|
||||||
|
when:
|
||||||
|
- not horizon_venv_enabled | bool
|
||||||
|
tags:
|
||||||
|
- horizon-command-bin
|
||||||
|
|
||||||
- name: Setup Horizon config(s)
|
- name: Setup Horizon config(s)
|
||||||
template:
|
template:
|
||||||
src: "{{ item.src }}"
|
src: "{{ item.src }}"
|
||||||
@ -22,22 +41,11 @@
|
|||||||
mode: "{{ item.mode }}"
|
mode: "{{ item.mode }}"
|
||||||
with_items:
|
with_items:
|
||||||
- { src: "horizon_local_settings.py.j2", dest: "/etc/horizon/local_settings.py", mode: "0644" }
|
- { src: "horizon_local_settings.py.j2", dest: "/etc/horizon/local_settings.py", mode: "0644" }
|
||||||
|
- { src: "horizon-manage.py.j2", dest: "{{ horizon_bin }}/horizon-manage.py", mode: "0755" }
|
||||||
notify: Restart apache2
|
notify: Restart apache2
|
||||||
tags:
|
tags:
|
||||||
- horizon-configs
|
- horizon-configs
|
||||||
|
|
||||||
- name: Setup Horizon config(s)
|
|
||||||
copy:
|
|
||||||
src: "{{ item.src }}"
|
|
||||||
dest: "{{ item.dest }}"
|
|
||||||
owner: "{{ horizon_system_user_name }}"
|
|
||||||
group: "{{ horizon_system_group_name }}"
|
|
||||||
mode: "{{ item.mode }}"
|
|
||||||
with_items:
|
|
||||||
- { src: "horizon-manage.py", dest: "/usr/local/bin/horizon-manage.py", mode: "0755" }
|
|
||||||
tags:
|
|
||||||
- horizon-configs
|
|
||||||
|
|
||||||
- name: Create horizon links
|
- name: Create horizon links
|
||||||
file:
|
file:
|
||||||
src: "{{ item.src }}"
|
src: "{{ item.src }}"
|
||||||
@ -55,8 +63,22 @@
|
|||||||
sudo: yes
|
sudo: yes
|
||||||
sudo_user: "{{ horizon_system_user_name }}"
|
sudo_user: "{{ horizon_system_user_name }}"
|
||||||
with_items:
|
with_items:
|
||||||
- horizon-manage.py collectstatic --noinput
|
- "{{ horizon_bin }}/horizon-manage.py collectstatic --noinput"
|
||||||
- horizon-manage.py compress --force
|
- "{{ horizon_bin }}/horizon-manage.py compress --force"
|
||||||
tags:
|
tags:
|
||||||
- horizon-configs
|
- horizon-configs
|
||||||
- horizon-static-collect
|
- horizon-static-collect
|
||||||
|
- horizon-command-bin
|
||||||
|
|
||||||
|
- name: Setup Horizon config(s)
|
||||||
|
template:
|
||||||
|
src: "{{ item.src }}"
|
||||||
|
dest: "{{ item.dest }}"
|
||||||
|
owner: "{{ horizon_system_user_name }}"
|
||||||
|
group: "{{ horizon_system_group_name }}"
|
||||||
|
with_items:
|
||||||
|
- { src: "horizon_django.wsgi.j2", dest: "{{ horizon_lib_wsgi_file }}" }
|
||||||
|
notify: Restart apache2
|
||||||
|
tags:
|
||||||
|
- horizon-configs
|
||||||
|
- horizon-wsgi-venv
|
||||||
|
@ -34,16 +34,82 @@
|
|||||||
- horizon-user
|
- horizon-user
|
||||||
|
|
||||||
- name: Create horizon dir
|
- name: Create horizon dir
|
||||||
|
file:
|
||||||
|
path: "{{ item.path }}"
|
||||||
|
state: "directory"
|
||||||
|
owner: "{{ item.owner|default(horizon_system_user_name) }}"
|
||||||
|
group: "{{ item.group|default(horizon_system_group_name) }}"
|
||||||
|
with_items:
|
||||||
|
- { path: "/openstack", mode: "0755", owner: "root", group: "root" }
|
||||||
|
- { path: "/etc/horizon", mode: "2755" }
|
||||||
|
- { path: "{{ horizon_system_user_home }}", mode: "2755" }
|
||||||
|
tags:
|
||||||
|
- horizon-dirs
|
||||||
|
|
||||||
|
- name: Create horizon venv dir
|
||||||
file:
|
file:
|
||||||
path: "{{ item.path }}"
|
path: "{{ item.path }}"
|
||||||
state: directory
|
state: directory
|
||||||
owner: "{{ item.owner|default(horizon_system_user_name) }}"
|
owner: "{{ item.owner|default(horizon_system_user_name) }}"
|
||||||
group: "{{ item.group|default(horizon_system_group_name) }}"
|
group: "{{ item.group|default(horizon_system_group_name) }}"
|
||||||
with_items:
|
with_items:
|
||||||
- { path: "/etc/horizon" }
|
- { path: "/openstack/venvs", mode: "0755", owner: "root", group: "root" }
|
||||||
- { path: "{{ horizon_system_user_home }}" }
|
- { path: "{{ horizon_venv_bin }}" }
|
||||||
- { path: "/usr/local/lib/python2.7/dist-packages/static" }
|
when: horizon_venv_enabled | bool
|
||||||
- { path: "/usr/local/lib/python2.7/dist-packages/openstack_dashboard/local" }
|
tags:
|
||||||
|
- horizon-dirs
|
||||||
|
|
||||||
|
- name: Install requires pip packages
|
||||||
|
pip:
|
||||||
|
name: "{{ item }}"
|
||||||
|
state: present
|
||||||
|
extra_args: "{{ pip_install_options|default('') }}"
|
||||||
|
register: install_packages
|
||||||
|
until: install_packages|success
|
||||||
|
retries: 5
|
||||||
|
delay: 2
|
||||||
|
with_items:
|
||||||
|
- "{{ horizon_requires_pip_packages }}"
|
||||||
|
tags:
|
||||||
|
- horizon-pip-packages
|
||||||
|
|
||||||
|
- name: Create horizon venv
|
||||||
|
pip:
|
||||||
|
name: "{{ item }}"
|
||||||
|
state: present
|
||||||
|
virtualenv: "{{ horizon_venv_bin | dirname }}"
|
||||||
|
virtualenv_site_packages: "no"
|
||||||
|
extra_args: "{{ pip_install_options|default('') }}"
|
||||||
|
with_items:
|
||||||
|
- "{{ horizon_requires_pip_packages }}"
|
||||||
|
when: horizon_venv_enabled | bool
|
||||||
|
tags:
|
||||||
|
- horizon-pip-packages
|
||||||
|
|
||||||
|
- name: Create horizon links for venv
|
||||||
|
file:
|
||||||
|
src: "{{ item.src }}"
|
||||||
|
dest: "{{ item.dest }}"
|
||||||
|
owner: "{{ horizon_system_user_name }}"
|
||||||
|
group: "{{ horizon_system_group_name }}"
|
||||||
|
state: "link"
|
||||||
|
with_items:
|
||||||
|
- src: "{{ horizon_lib_dir | dirname }}/site-packages"
|
||||||
|
dest: "{{ horizon_lib_dir }}"
|
||||||
|
when: horizon_venv_enabled | bool
|
||||||
|
tags:
|
||||||
|
- horizon-configs
|
||||||
|
|
||||||
|
- name: Create static horizon dir
|
||||||
|
file:
|
||||||
|
path: "{{ item.path }}"
|
||||||
|
state: "directory"
|
||||||
|
owner: "{{ item.owner|default(horizon_system_user_name) }}"
|
||||||
|
group: "{{ item.group|default(horizon_system_group_name) }}"
|
||||||
|
with_items:
|
||||||
|
- { path: "{{ horizon_lib_dir }}/static", mode: "2755" }
|
||||||
|
- { path: "{{ horizon_lib_dir }}/openstack_dashboard", mode: "2755" }
|
||||||
|
- { path: "{{ horizon_lib_dir }}/openstack_dashboard/local", mode: "2755" }
|
||||||
tags:
|
tags:
|
||||||
- horizon-dirs
|
- horizon-dirs
|
||||||
|
|
||||||
|
@ -13,6 +13,14 @@
|
|||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
import os
|
import os
|
||||||
|
|
||||||
|
{% if horizon_venv_enabled | bool %}
|
||||||
|
|
||||||
|
activate_this = os.path.expanduser("{{ horizon_venv_bin }}/activate_this.py")
|
||||||
|
execfile(activate_this, dict(__file__=activate_this))
|
||||||
|
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
from django.core.management import execute_from_command_line # noqa
|
from django.core.management import execute_from_command_line # noqa
|
22
templates/horizon_django.wsgi.j2
Normal file
22
templates/horizon_django.wsgi.j2
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
import logging
|
||||||
|
import os
|
||||||
|
|
||||||
|
{% if horizon_venv_enabled | bool %}
|
||||||
|
|
||||||
|
activate_this = os.path.expanduser("{{ horizon_venv_bin }}/activate_this.py")
|
||||||
|
execfile(activate_this, dict(__file__=activate_this))
|
||||||
|
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
import sys
|
||||||
|
from django.core.wsgi import get_wsgi_application
|
||||||
|
from django.conf import settings
|
||||||
|
|
||||||
|
# Add this file path to sys.path in order to import settings
|
||||||
|
sys.path.insert(0, os.path.join(os.path.dirname(os.path.realpath(__file__)), '../..'))
|
||||||
|
os.environ['DJANGO_SETTINGS_MODULE'] = 'openstack_dashboard.settings'
|
||||||
|
sys.stdout = sys.stderr
|
||||||
|
|
||||||
|
DEBUG = False
|
||||||
|
|
||||||
|
application = get_wsgi_application()
|
@ -29,13 +29,12 @@
|
|||||||
SSLCipherSuite {{ horizon_ssl_cipher_suite }}
|
SSLCipherSuite {{ horizon_ssl_cipher_suite }}
|
||||||
SetEnvIf User-Agent ".*MSIE.*" nokeepalive ssl-unclean-shutdown
|
SetEnvIf User-Agent ".*MSIE.*" nokeepalive ssl-unclean-shutdown
|
||||||
|
|
||||||
WSGIScriptAlias / {{ horizon_lib_dir }}/openstack_dashboard/wsgi/django.wsgi
|
WSGIScriptAlias / {{ horizon_lib_wsgi_file }}
|
||||||
WSGIDaemonProcess horizon user={{ horizon_system_user_name }} group={{ horizon_system_group_name }} processes={{ ansible_processor_cores }} threads={{ threads if threads > 0 else 1 }}
|
WSGIDaemonProcess horizon user={{ horizon_system_user_name }} group={{ horizon_system_group_name }} processes={{ ansible_processor_cores }} threads={{ threads if threads > 0 else 1 }}
|
||||||
WSGIProcessGroup horizon
|
WSGIProcessGroup horizon
|
||||||
WSGIApplicationGroup horizon
|
WSGIApplicationGroup horizon
|
||||||
|
|
||||||
Alias /static {{ horizon_lib_dir }}/static/
|
<Directory {{ horizon_lib_wsgi_file | dirname }}>
|
||||||
<Directory /usr/local/lib/python2.7/dist-packages/openstack_dashboard/wsgi/>
|
|
||||||
<Files django.wsgi>
|
<Files django.wsgi>
|
||||||
Order allow,deny
|
Order allow,deny
|
||||||
allow from all
|
allow from all
|
||||||
@ -43,6 +42,8 @@
|
|||||||
</Files>
|
</Files>
|
||||||
</Directory>
|
</Directory>
|
||||||
|
|
||||||
|
Alias /static {{ horizon_lib_dir }}/static/
|
||||||
|
|
||||||
<Directory {{ horizon_lib_dir }}/static/>
|
<Directory {{ horizon_lib_dir }}/static/>
|
||||||
Options -FollowSymlinks
|
Options -FollowSymlinks
|
||||||
AllowOverride None
|
AllowOverride None
|
||||||
|
Loading…
x
Reference in New Issue
Block a user