Revert "Use a common python build/install role for source-base deployment"

This is causing some trouble with the integrated build. For now,
while we work out the role's build/storage delegation, let's revert
this.

This reverts commit 975675b659, except
for the a-r-r entry which is left in place as it will be needed later.

Change-Id: I111baaf1e3d70c036508cccc31887e0f328a67ce
This commit is contained in:
Jesse Pretorius (odyssey4me) 2018-03-29 10:01:00 +00:00 committed by Jesse Pretorius
parent 975675b659
commit 49ed28890e
2 changed files with 105 additions and 30 deletions

View File

@ -32,9 +32,7 @@
until: _stop | success until: _stop | success
retries: 5 retries: 5
delay: 2 delay: 2
listen: listen: "Restart glance services"
- "Restart glance services"
- "venv changed"
# TODO(odyssey4me): # TODO(odyssey4me):
# Assuming glance-registry is removed in the S cycle as planned, this # Assuming glance-registry is removed in the S cycle as planned, this
@ -84,9 +82,7 @@
- "/etc/systemd/system/{{ glance_services['glance-registry']['service_name'] }}.service" - "/etc/systemd/system/{{ glance_services['glance-registry']['service_name'] }}.service"
when: when:
- not glance_services['glance-registry']['condition'] - not glance_services['glance-registry']['condition']
listen: listen: "Restart glance services"
- "Restart glance services"
- "venv changed"
# Note (odyssey4me): # Note (odyssey4me):
# The policy.json file is currently read continually by the services # The policy.json file is currently read continually by the services
@ -104,9 +100,7 @@
group: "{{ glance_system_group_name }}" group: "{{ glance_system_group_name }}"
mode: "0640" mode: "0640"
remote_src: yes remote_src: yes
listen: listen: "Restart glance services"
- "Restart glance services"
- "venv changed"
- name: Start services - name: Start services
service: service:
@ -119,9 +113,7 @@
until: _start | success until: _start | success
retries: 5 retries: 5
delay: 2 delay: 2
listen: listen: "Restart glance services"
- "Restart glance services"
- "venv changed"
- meta: noop - meta: noop
listen: Manage LB listen: Manage LB

View File

@ -103,30 +103,113 @@
{% endfor %} {% endfor %}
when: glance_developer_mode | bool when: glance_developer_mode | bool
- name: Build/install the python venv - name: Install requires pip packages
include_role: pip:
name: "python_venv_build" name: "{{ glance_requires_pip_packages }}"
private: yes state: "{{ glance_pip_package_state }}"
vars: extra_args: >-
distro_package_list: "{{ glance_distro_packages }}"
host_pip_packages: "{{ glance_requires_pip_packages }}"
venv_pip_packages: "{{ glance_pip_packages }}"
host_pip_install_args: >-
{{ glance_developer_mode | ternary(pip_install_developer_constraints | default('--constraint /opt/developer-pip-constraints.txt'), '') }} {{ glance_developer_mode | ternary(pip_install_developer_constraints | default('--constraint /opt/developer-pip-constraints.txt'), '') }}
{{ (pip_install_upper_constraints is defined) | ternary('--constraint ' + pip_install_upper_constraints | default(''),'') }} {{ (pip_install_upper_constraints is defined) | ternary('--constraint ' + pip_install_upper_constraints | default(''),'') }}
{{ pip_install_options | default('') }} {{ pip_install_options | default('') }}
venv_pip_install_args: >- register: install_packages
until: install_packages|success
retries: 5
delay: 2
- name: Retrieve checksum for venv download
uri:
url: "{{ glance_venv_download_url | replace('tgz', 'checksum') }}"
return_content: yes
register: glance_venv_checksum
when: glance_venv_download | bool
- name: Attempt venv download
get_url:
url: "{{ glance_venv_download_url }}"
dest: "/var/cache/{{ glance_venv_download_url | basename }}"
checksum: "sha1:{{ glance_venv_checksum.content | trim }}"
register: glance_get_venv
when: glance_venv_download | bool
- name: Remove existing venv
file:
path: "{{ glance_bin | dirname }}"
state: absent
when: glance_get_venv | changed
- name: Create glance venv dir
file:
path: "{{ glance_bin | dirname }}"
state: directory
register: glance_venv_dir
when: glance_get_venv | changed
- name: Unarchive pre-built venv
unarchive:
src: "/var/cache/{{ glance_venv_download_url | basename }}"
dest: "{{ glance_bin | dirname }}"
copy: "no"
when: glance_get_venv | changed
notify:
- Manage LB
- Restart glance services
- name: Install pip packages
pip:
name: "{{ glance_pip_packages }}"
state: "{{ glance_pip_package_state }}"
virtualenv: "{{ glance_bin | dirname }}"
virtualenv_site_packages: "no"
extra_args: >-
{{ glance_developer_mode | ternary(pip_install_developer_constraints | default('--constraint /opt/developer-pip-constraints.txt'), '') }} {{ glance_developer_mode | ternary(pip_install_developer_constraints | default('--constraint /opt/developer-pip-constraints.txt'), '') }}
{{ (pip_install_upper_constraints is defined) | ternary('--constraint ' + pip_install_upper_constraints | default(''),'') }} {{ (pip_install_upper_constraints is defined) | ternary('--constraint ' + pip_install_upper_constraints | default(''),'') }}
{{ pip_install_options | default('') }} {{ pip_install_options | default('') }}
venv_destination_path: "{{ glance_bin | dirname }}" register: install_packages
venv_facts_when_changed: until: install_packages|success
- section: "glance" retries: 5
option: "need_service_restart" delay: 2
value: True when: glance_get_venv | failed or glance_get_venv | skipped
- section: "glance" notify:
option: "venv_tag" - Manage LB
value: "{{ glance_venv_tag }}" - Restart glance services
- name: Remove python from path first (CentOS, openSUSE)
file:
path: "{{ glance_bin | dirname }}/bin/python2.7"
state: "absent"
when:
- ansible_pkg_mgr in ['yum', 'dnf', 'zypper']
- glance_get_venv | changed
- name: Update virtualenv path
shell: |
find {{ glance_bin }} -name \*.pyc -delete
sed -si '1s/^.*python.*$/#!{{ glance_bin | replace ('/','\/') }}\/python/' {{ glance_bin }}/*
virtualenv {{ glance_bin | dirname }}
when: glance_get_venv | changed
tags:
- skip_ansible_lint
- name: Record the need for a service restart
ini_file:
dest: "/etc/ansible/facts.d/openstack_ansible.fact"
section: glance
option: need_service_restart
value: True
when: (glance_get_venv | changed) or
(glance_venv_dir | changed) or
(install_packages | changed) or
(ansible_local is not defined) or
('openstack_ansible' not in ansible_local) or
('glance' not in ansible_local['openstack_ansible']) or
('need_service_restart' not in ansible_local['openstack_ansible']['glance'])
- name: Record the venv tag deployed
ini_file:
dest: "/etc/ansible/facts.d/openstack_ansible.fact"
section: glance
option: venv_tag
value: "{{ glance_venv_tag }}"
- name: Create TEMP run dir - name: Create TEMP run dir
file: file: