9082c793cc
When an Apache + mod_wsgi configuration is not selected, configure the two Keystone services with uWSGI service profiles. Two arbitrary ports are selected for uWSGI to listen on, so that it may be proxied for by a dedicated web server. This is in preparation for laying down Nginx in a future patch. Notify events are updated to restart the Keystone uWSGI services where Keystone's configuration is modified only. Because federation concerns will be isolated within the dedicated web server, changes to federation configuration of Shiboleth do not trigger restarts of uWSGI. Similarly, SSL certificate changes do not trigger restarts. Change-Id: I99e16a999c496e68fb25fa2630d9b211c9755ea4 Related: blueprint keystone-uwsgi
161 lines
4.7 KiB
YAML
161 lines
4.7 KiB
YAML
---
|
|
# Copyright 2014, Rackspace US, Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
- include: keystone_install_apt.yml
|
|
when:
|
|
- ansible_pkg_mgr == 'apt'
|
|
|
|
- name: Create WSGI symlinks
|
|
file:
|
|
src: "{{ item.src }}"
|
|
dest: "/var/www/cgi-bin/keystone/{{ item.dest }}"
|
|
state: link
|
|
force: yes
|
|
with_items:
|
|
- src: "{{ keystone_bin }}/keystone-wsgi-admin"
|
|
dest: admin
|
|
- src: "{{ keystone_bin }}/keystone-wsgi-public"
|
|
dest: main
|
|
|
|
- name: Create developer mode constraint file
|
|
copy:
|
|
dest: "/opt/developer-pip-constraints.txt"
|
|
content: |
|
|
{% for item in keystone_developer_constraints %}
|
|
{{ item }}
|
|
{% endfor %}
|
|
when:
|
|
- keystone_developer_mode | bool
|
|
|
|
- name: Clone requirements git repository
|
|
git:
|
|
repo: "{{ keystone_requirements_git_repo }}"
|
|
dest: "/opt/requirements"
|
|
clone: yes
|
|
update: yes
|
|
version: "{{ keystone_requirements_git_install_branch }}"
|
|
when:
|
|
- keystone_developer_mode | bool
|
|
|
|
- name: Add constraints to pip_install_options fact for developer mode
|
|
set_fact:
|
|
pip_install_options_fact: "{{ pip_install_options|default('') }} --constraint /opt/developer-pip-constraints.txt --constraint /opt/requirements/upper-constraints.txt"
|
|
when:
|
|
- keystone_developer_mode | bool
|
|
|
|
- name: Set pip_install_options_fact when not in developer mode
|
|
set_fact:
|
|
pip_install_options_fact: "{{ pip_install_options|default('') }}"
|
|
when:
|
|
- not keystone_developer_mode | bool
|
|
|
|
- name: Install required pip packages
|
|
pip:
|
|
name: "{{ keystone_requires_pip_packages | join(' ') }}"
|
|
state: latest
|
|
extra_args: "{{ pip_install_options_fact }}"
|
|
register: install_packages
|
|
until: install_packages|success
|
|
retries: 5
|
|
delay: 2
|
|
|
|
- name: Get local venv checksum
|
|
stat:
|
|
path: "/var/cache/{{ keystone_venv_download_url | basename }}"
|
|
get_md5: False
|
|
when:
|
|
- not keystone_developer_mode | bool
|
|
register: local_venv_stat
|
|
|
|
- name: Get remote venv checksum
|
|
uri:
|
|
url: "{{ keystone_venv_download_url | replace('tgz', 'checksum') }}"
|
|
return_content: True
|
|
when:
|
|
- not keystone_developer_mode | bool
|
|
register: remote_venv_checksum
|
|
|
|
# TODO: When project moves to ansible 2 we can pass this a sha256sum which will:
|
|
# a) allow us to remove force: yes
|
|
# b) allow the module to calculate the checksum of dest file which would
|
|
# result in file being downloaded only if provided and dest sha256sum
|
|
# checksums differ
|
|
- name: Attempt venv download
|
|
get_url:
|
|
url: "{{ keystone_venv_download_url }}"
|
|
dest: "/var/cache/{{ keystone_venv_download_url | basename }}"
|
|
force: yes
|
|
ignore_errors: true
|
|
register: get_venv
|
|
when:
|
|
- not keystone_developer_mode | bool
|
|
- (local_venv_stat.stat.exists == False or
|
|
{{ local_venv_stat.stat.checksum is defined and local_venv_stat.stat.checksum != remote_venv_checksum.content | trim }})
|
|
|
|
- name: Set keystone get_venv fact
|
|
set_fact:
|
|
keystone_get_venv: "{{ get_venv }}"
|
|
|
|
- name: Remove existing venv
|
|
file:
|
|
path: "{{ keystone_bin | dirname }}"
|
|
state: absent
|
|
when:
|
|
- keystone_get_venv | changed
|
|
|
|
- name: Create keystone venv dir
|
|
file:
|
|
path: "{{ keystone_bin | dirname }}"
|
|
state: directory
|
|
register: keystone_venv_dir
|
|
when:
|
|
- not keystone_developer_mode | bool
|
|
|
|
- name: Unarchive pre-built venv
|
|
unarchive:
|
|
src: "/var/cache/{{ keystone_venv_download_url | basename }}"
|
|
dest: "{{ keystone_bin | dirname }}"
|
|
copy: "no"
|
|
when:
|
|
- not keystone_developer_mode | bool
|
|
- keystone_get_venv | changed or keystone_venv_dir | changed
|
|
notify:
|
|
- Restart Apache
|
|
- Restart Keystone APIs
|
|
|
|
- name: Install pip packages
|
|
pip:
|
|
name: "{{ keystone_pip_packages | join(' ') }}"
|
|
state: latest
|
|
virtualenv: "{{ keystone_bin | dirname }}"
|
|
virtualenv_site_packages: "no"
|
|
extra_args: "{{ pip_install_options_fact }}"
|
|
register: install_packages
|
|
until: install_packages|success
|
|
retries: 5
|
|
delay: 2
|
|
when:
|
|
- keystone_get_venv | failed or keystone_developer_mode | bool
|
|
notify:
|
|
- Restart Apache
|
|
- Restart Keystone APIs
|
|
|
|
- name: Update virtualenv path
|
|
command: >
|
|
virtualenv-tools --update-path=auto {{ keystone_bin | dirname }}
|
|
when:
|
|
- not keystone_developer_mode | bool
|
|
- keystone_get_venv | success
|