From 02ce804a441a42b2f4dca03b2e3fb0ba054cfe33 Mon Sep 17 00:00:00 2001 From: Eduardo Gonzalez Date: Fri, 1 Sep 2017 12:45:12 +0200 Subject: [PATCH] Fix vitrage images Vitrage start api service under apache or uwsgi. We have not created a migration to uwsgi. This change adds apache packages needed for api also add rdo binaries to rpm distros. Adds missing collector image. Change-Id: Iecb32e321b46f9b567af25fa6acafbe9a292bbca Closes-Bug: #1681613 --- docker/vitrage/vitrage-api/Dockerfile.j2 | 26 ++++++++++- docker/vitrage/vitrage-api/extend_start.sh | 11 +++++ docker/vitrage/vitrage-base/Dockerfile.j2 | 46 +++++++++++++++++-- docker/vitrage/vitrage-base/extend_start.sh | 2 + .../vitrage/vitrage-collector/Dockerfile.j2 | 30 ++++++++++++ docker/vitrage/vitrage-graph/Dockerfile.j2 | 14 ++++++ docker/vitrage/vitrage-ml/Dockerfile.j2 | 14 ++++++ docker/vitrage/vitrage-notifier/Dockerfile.j2 | 14 ++++++ kolla/image/build.py | 2 - 9 files changed, 151 insertions(+), 8 deletions(-) create mode 100644 docker/vitrage/vitrage-api/extend_start.sh create mode 100644 docker/vitrage/vitrage-collector/Dockerfile.j2 diff --git a/docker/vitrage/vitrage-api/Dockerfile.j2 b/docker/vitrage/vitrage-api/Dockerfile.j2 index c5f88d79de..5a9cae22e1 100644 --- a/docker/vitrage/vitrage-api/Dockerfile.j2 +++ b/docker/vitrage/vitrage-api/Dockerfile.j2 @@ -3,14 +3,36 @@ LABEL maintainer="{{ maintainer }}" name="{{ image_name }}" build-date="{{ build {% block vitrage_api_header %}{% endblock %} +{% import "macros.j2" as macros with context %} + {% if install_type == 'binary' %} + {% if base_distro in ['centos', 'oraclelinux', 'rhel'] %} + + {% set vitrage_api_packages = [ + 'httpd', + 'mod_wsgi', + 'mod_ssl', + 'python-ldappool', + 'openstack-vitrage-api' + ] %} + +{{ macros.install_packages(vitrage_api_packages | customizable("packages")) }} +RUN sed -i -r 's,^(Listen 80),#\1,' /etc/httpd/conf/httpd.conf \ + && sed -i -r 's,^(Listen 443),#\1,' /etc/httpd/conf.d/ssl.conf + + {% elif base_distro in ['debian', 'ubuntu'] %} + RUN echo '{{ install_type }} not yet available for {{ base_distro }}' \ && /bin/false + {% endif %} + {% endif %} + +COPY extend_start.sh /usr/local/bin/kolla_vitrage_extend_start +RUN chmod 755 /usr/local/bin/kolla_vitrage_extend_start + {% block vitrage_api_footer %}{% endblock %} {% block footer %}{% endblock %} - -USER vitrage diff --git a/docker/vitrage/vitrage-api/extend_start.sh b/docker/vitrage/vitrage-api/extend_start.sh new file mode 100644 index 0000000000..4596bf6a1d --- /dev/null +++ b/docker/vitrage/vitrage-api/extend_start.sh @@ -0,0 +1,11 @@ +#!/bin/bash + +# NOTE(pbourke): httpd will not clean up after itself in some cases which +# results in the container not being able to restart. (bug #1489676, 1557036) +if [[ "${KOLLA_BASE_DISTRO}" =~ debian|ubuntu ]]; then + # Loading Apache2 ENV variables + . /etc/apache2/envvars + rm -rf /var/run/apache2/* +else + rm -rf /var/run/httpd/* /run/httpd/* /tmp/httpd* +fi diff --git a/docker/vitrage/vitrage-base/Dockerfile.j2 b/docker/vitrage/vitrage-base/Dockerfile.j2 index 1cb4ed9f53..9d3aba6606 100644 --- a/docker/vitrage/vitrage-base/Dockerfile.j2 +++ b/docker/vitrage/vitrage-base/Dockerfile.j2 @@ -9,11 +9,48 @@ LABEL maintainer="{{ maintainer }}" name="{{ image_name }}" build-date="{{ build {% if install_type == 'binary' %} + {% if base_distro in ['centos', 'oraclelinux', 'rhel'] %} + + {% set vitrage_base_packages = [ + 'openstack-vitrage-common' + ] %} + +{{ macros.install_packages(vitrage_base_packages | customizable("packages")) }} + + {% elif base_distro in ['debian', 'ubuntu'] %} + RUN echo '{{ install_type }} not yet available for {{ base_distro }}' \ && /bin/false + {% endif %} + {% elif install_type == 'source' %} + {% if base_distro in ['centos', 'oraclelinux', 'rhel'] %} + + {% set vitrage_base_packages = [ + 'httpd', + 'mod_wsgi', + 'mod_ssl', + 'python-ldappool' + ] %} + +{{ macros.install_packages(vitrage_base_packages | customizable("packages")) }} +RUN sed -i -r 's,^(Listen 80),#\1,' /etc/httpd/conf/httpd.conf \ + && sed -i -r 's,^(Listen 443),#\1,' /etc/httpd/conf.d/ssl.conf + + {% elif base_distro in ['debian', 'ubuntu'] %} + + {% set vitrage_base_packages = [ + 'apache2', + 'libapache2-mod-wsgi', + 'python-ldappool' + ] %} + +{{ macros.install_packages(vitrage_base_packages | customizable("packages")) }} +RUN echo > /etc/apache2/ports.conf +{% endif %} + {% set vitrage_base_pip_packages = [ '/vitrage' ] %} @@ -21,14 +58,15 @@ RUN echo '{{ install_type }} not yet available for {{ base_distro }}' \ ADD vitrage-base-archive /vitrage-base-source RUN ln -s vitrage-base-source/* vitrage \ && {{ macros.install_pip(vitrage_base_pip_packages | customizable("pip_packages")) }} \ - && mkdir -p /etc/vitrage \ + && mkdir -p /etc/vitrage /var/www/cgi-bin/vitrage \ && cp -r /vitrage/etc/vitrage/* /etc/vitrage/ \ - && chown -R vitrage: /etc/vitrage + && cp /vitrage/vitrage/api/app.wsgi /var/www/cgi-bin/vitrage \ + && chown -R vitrage: /etc/vitrage /var/www/cgi-bin/vitrage {% endif %} COPY extend_start.sh /usr/local/bin/kolla_extend_start - -RUN chmod 755 /usr/local/bin/kolla_extend_start +RUN touch /usr/local/bin/kolla_vitrage_extend_start \ + && chmod 755 /usr/local/bin/kolla_extend_start /usr/local/bin/kolla_vitrage_extend_start {% block vitrage_base_footer %}{% endblock %} diff --git a/docker/vitrage/vitrage-base/extend_start.sh b/docker/vitrage/vitrage-base/extend_start.sh index d796350579..3092c81465 100755 --- a/docker/vitrage/vitrage-base/extend_start.sh +++ b/docker/vitrage/vitrage-base/extend_start.sh @@ -10,3 +10,5 @@ fi if [[ $(stat -c %a ${VITRAGE_LOG_DIR}) != "755" ]]; then chmod 755 ${VITRAGE_LOG_DIR} fi + +. /usr/local/bin/kolla_vitrage_extend_start diff --git a/docker/vitrage/vitrage-collector/Dockerfile.j2 b/docker/vitrage/vitrage-collector/Dockerfile.j2 new file mode 100644 index 0000000000..2f299b4b2a --- /dev/null +++ b/docker/vitrage/vitrage-collector/Dockerfile.j2 @@ -0,0 +1,30 @@ +FROM {{ namespace }}/{{ image_prefix }}vitrage-base:{{ tag }} +LABEL maintainer="{{ maintainer }}" name="{{ image_name }}" build-date="{{ build_date }}" + +{% block vitrage_collector_header %}{% endblock %} + +{% import "macros.j2" as macros with context %} + +{% if install_type == 'binary' %} + + {% if base_distro in ['centos', 'oraclelinux', 'rhel'] %} + + {% set vitrage_collector_packages = [ + 'openstack-vitrage-collector' + ] %} + +{{ macros.install_packages(vitrage_collector_packages | customizable("packages")) }} + + {% elif base_distro in ['debian', 'ubuntu'] %} + +RUN echo '{{ install_type }} not yet available for {{ base_distro }}' \ + && /bin/false + + {% endif %} + +{% endif %} + +{% block vitrage_collector_footer %}{% endblock %} +{% block footer %}{% endblock %} + +USER vitrage diff --git a/docker/vitrage/vitrage-graph/Dockerfile.j2 b/docker/vitrage/vitrage-graph/Dockerfile.j2 index b0bd32083b..983c39d881 100644 --- a/docker/vitrage/vitrage-graph/Dockerfile.j2 +++ b/docker/vitrage/vitrage-graph/Dockerfile.j2 @@ -3,11 +3,25 @@ LABEL maintainer="{{ maintainer }}" name="{{ image_name }}" build-date="{{ build {% block vitrage_graph_header %}{% endblock %} +{% import "macros.j2" as macros with context %} + {% if install_type == 'binary' %} + {% if base_distro in ['centos', 'oraclelinux', 'rhel'] %} + + {% set vitrage_graph_packages = [ + 'openstack-vitrage-graph' + ] %} + +{{ macros.install_packages(vitrage_graph_packages | customizable("packages")) }} + + {% elif base_distro in ['debian', 'ubuntu'] %} + RUN echo '{{ install_type }} not yet available for {{ base_distro }}' \ && /bin/false + {% endif %} + {% endif %} {% block vitrage_graph_footer %}{% endblock %} diff --git a/docker/vitrage/vitrage-ml/Dockerfile.j2 b/docker/vitrage/vitrage-ml/Dockerfile.j2 index c317f41e79..4fdc0ecbd6 100644 --- a/docker/vitrage/vitrage-ml/Dockerfile.j2 +++ b/docker/vitrage/vitrage-ml/Dockerfile.j2 @@ -3,11 +3,25 @@ LABEL maintainer="{{ maintainer }}" name="{{ image_name }}" build-date="{{ build {% block vitrage_ml_header %}{% endblock %} +{% import "macros.j2" as macros with context %} + {% if install_type == 'binary' %} + {% if base_distro in ['centos', 'oraclelinux', 'rhel'] %} + + {% set vitrage_ml_packages = [ + 'openstack-vitrage-ml' + ] %} + +{{ macros.install_packages(vitrage_ml_packages | customizable("packages")) }} + + {% elif base_distro in ['debian', 'ubuntu'] %} + RUN echo '{{ install_type }} not yet available for {{ base_distro }}' \ && /bin/false + {% endif %} + {% endif %} {% block vitrage_ml_footer %}{% endblock %} diff --git a/docker/vitrage/vitrage-notifier/Dockerfile.j2 b/docker/vitrage/vitrage-notifier/Dockerfile.j2 index d55d539f5d..f3edaccb93 100644 --- a/docker/vitrage/vitrage-notifier/Dockerfile.j2 +++ b/docker/vitrage/vitrage-notifier/Dockerfile.j2 @@ -3,11 +3,25 @@ LABEL maintainer="{{ maintainer }}" name="{{ image_name }}" build-date="{{ build {% block vitrage_notifier_header %}{% endblock %} +{% import "macros.j2" as macros with context %} + {% if install_type == 'binary' %} + {% if base_distro in ['centos', 'oraclelinux', 'rhel'] %} + + {% set vitrage_notifier_packages = [ + 'openstack-vitrage-notifier' + ] %} + +{{ macros.install_packages(vitrage_notifier_packages | customizable("packages")) }} + + {% elif base_distro in ['debian', 'ubuntu'] %} + RUN echo '{{ install_type }} not yet available for {{ base_distro }}' \ && /bin/false + {% endif %} + {% endif %} {% block vitrage_notifier_footer %}{% endblock %} diff --git a/kolla/image/build.py b/kolla/image/build.py index b6e959b468..20e994f069 100755 --- a/kolla/image/build.py +++ b/kolla/image/build.py @@ -109,7 +109,6 @@ SKIPPED_IMAGES = { "searchlight-base", "senlin-base", "solum-base", - "vitrage-base", "vmtp", "zun-base", ], @@ -188,7 +187,6 @@ SKIPPED_IMAGES = { "searchlight-base", "senlin-base", "solum-base", - "vitrage-base", "vmtp", "zun-base" ],