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:
Kevin Carter 2015-09-29 21:49:24 -05:00 committed by Jesse Pretorius
parent d39f7b8d7d
commit 61827ccfbd
8 changed files with 184 additions and 29 deletions

View File

@ -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

View File

@ -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:

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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

View 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()

View File

@ -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