Fix ironic failed

* Mount system folder in ironic-conductor
* Add package need in ironic-conductor
* Fix the log path issue
* Add ironic sudoer in ironic-base
* Fix credential issue
* Do not start nova-compute when enable ironic

Closes-Bug: #1629334
Change-Id: If9d478c6513de37465403d458a88cf0da7ebd8a6
This commit is contained in:
Jeffrey Zhang 2016-09-29 11:38:10 +08:00 committed by Jeffrey Zhang
parent 0226cca1a2
commit 903b0ff211
10 changed files with 64 additions and 17 deletions

View File

@ -19,6 +19,8 @@
name: "ironic_api" name: "ironic_api"
volumes: volumes:
- "{{ node_config_directory }}/ironic-api/:{{ container_config_directory }}/:ro" - "{{ node_config_directory }}/ironic-api/:{{ container_config_directory }}/:ro"
- "/etc/localtime:/etc/localtime:ro"
- "kolla_logs:/var/log/kolla"
when: inventory_hostname in groups['ironic-api'] when: inventory_hostname in groups['ironic-api']
- name: Starting ironic-conductor container - name: Starting ironic-conductor container
@ -27,9 +29,15 @@
common_options: "{{ docker_common_options }}" common_options: "{{ docker_common_options }}"
image: "{{ ironic_conductor_image_full }}" image: "{{ ironic_conductor_image_full }}"
name: "ironic_conductor" name: "ironic_conductor"
privileged: True
volumes: volumes:
- "{{ node_config_directory }}/ironic-conductor/:{{ container_config_directory }}/:ro" - "{{ node_config_directory }}/ironic-conductor/:{{ container_config_directory }}/:ro"
- "/etc/localtime:/etc/localtime:ro" - "/etc/localtime:/etc/localtime:ro"
- "/sys:/sys"
- "/dev:/dev"
- "/run:/run"
- "kolla_logs:/var/log/kolla"
- "ironic:/var/lib/ironic"
- "ironic_pxe:/tftpboot/" - "ironic_pxe:/tftpboot/"
when: inventory_hostname in groups['ironic-conductor'] when: inventory_hostname in groups['ironic-conductor']

View File

@ -1,6 +1,8 @@
[DEFAULT] [DEFAULT]
debug = {{ ironic_logging_debug }} debug = {{ ironic_logging_debug }}
log_dir = /var/log/kolla/ironic
admin_user = {{ openstack_auth.username }} admin_user = {{ openstack_auth.username }}
admin_password = {{ keystone_admin_password }} admin_password = {{ keystone_admin_password }}
@ -16,7 +18,7 @@ host_ip = {{ hostvars[inventory_hostname]['ansible_' + api_interface]['ipv4']['a
{% if service_name == 'ironic-conductor' %} {% if service_name == 'ironic-conductor' %}
[conductor] [conductor]
api_url = {{ internal_protocol }}://{{ kolla_internal_fqdn }}:{{ ironic_api_port }} api_url = {{ internal_protocol }}://{{ kolla_internal_fqdn }}:{{ ironic_api_port }}
clean_nodes = false automated_clean=false
{% endif %} {% endif %}
{% if service_name == 'ironic-inspector' %} {% if service_name == 'ironic-inspector' %}
@ -41,9 +43,9 @@ auth_url = {{ admin_protocol }}://{{ kolla_internal_fqdn }}:{{ keystone_admin_po
auth_type = password auth_type = password
project_domain_id = default project_domain_id = default
user_domain_id = default user_domain_id = default
admin_tenant_name = service project_name = service
admin_user = {{ ironic_keystone_user }} username = {{ ironic_keystone_user }}
admin_password = {{ ironic_keystone_password }} password = {{ ironic_keystone_password }}
memcache_security_strategy = ENCRYPT memcache_security_strategy = ENCRYPT
memcache_secret_key = {{ memcache_secret_key }} memcache_secret_key = {{ memcache_secret_key }}

View File

@ -49,6 +49,7 @@
when: when:
- inventory_hostname in groups['compute'] - inventory_hostname in groups['compute']
- not enable_nova_fake | bool - not enable_nova_fake | bool
- not enable_ironic | bool
- name: Starting nova-compute-ironic container - name: Starting nova-compute-ironic container
kolla_docker: kolla_docker:

View File

@ -96,6 +96,7 @@ html5proxy_port = {{ nova_spicehtml5proxy_port }}
username = {{ ironic_keystone_user }} username = {{ ironic_keystone_user }}
password = {{ ironic_keystone_password }} password = {{ ironic_keystone_password }}
auth_url = {{ openstack_auth.auth_url }}/v3 auth_url = {{ openstack_auth.auth_url }}/v3
auth_type = password
project_name = service project_name = service
user_domain_name = default user_domain_name = default
project_domain_name = default project_domain_name = default

View File

@ -16,8 +16,8 @@ MAINTAINER {{ maintainer }}
{% endif %} {% endif %}
COPY extend_start.sh /usr/local/bin/kolla_extend_start COPY extend_start.sh /usr/local/bin/kolla_ironic_extend_start
RUN chmod 755 /usr/local/bin/kolla_extend_start RUN chmod 755 /usr/local/bin/kolla_ironic_extend_start
{% block ironic_api_footer %}{% endblock %} {% block ironic_api_footer %}{% endblock %}
{% block footer %}{% endblock %} {% block footer %}{% endblock %}

View File

@ -18,16 +18,24 @@ MAINTAINER {{ maintainer }}
ADD ironic-base-archive /ironic-base-source ADD ironic-base-archive /ironic-base-source
RUN ln -s ironic-base-source/* ironic \ RUN ln -s ironic-base-source/* ironic \
&& useradd --user-group ironic \ && useradd --user-group --create-home --home-dir /var/lib/ironic ironic \
&& /var/lib/kolla/venv/bin/pip --no-cache-dir install --upgrade -c requirements/upper-constraints.txt /ironic \ && /var/lib/kolla/venv/bin/pip --no-cache-dir install --upgrade -c requirements/upper-constraints.txt /ironic \
&& mkdir -p /etc/ironic /var/log/ironic /home/ironic \ && mkdir -p /etc/ironic /var/lib/ironic \
&& cp -r /ironic/etc/ironic/* /etc/ironic/ \ && cp -r /ironic/etc/ironic/* /etc/ironic/ \
&& chown -R ironic: /etc/ironic /var/log/ironic /home/ironic \ && chown -R ironic: /etc/ironic /var/lib/ironic \
&& sed -i 's|^exec_dirs.*|exec_dirs=/var/lib/kolla/venv/bin,/sbin,/usr/sbin,/bin,/usr/bin,/usr/local/bin,/usr/local/sbin|g' /etc/ironic/rootwrap.conf && sed -i 's|^exec_dirs.*|exec_dirs=/var/lib/kolla/venv/bin,/sbin,/usr/sbin,/bin,/usr/bin,/usr/local/bin,/usr/local/sbin|g' /etc/ironic/rootwrap.conf
ADD ironic_sudoers /etc/sudoers.d/kolla_ironic_sudoers
RUN chmod 750 /etc/sudoers.d \
&& chmod 440 /etc/sudoers.d/kolla_ironic_sudoers
{% endif %} {% endif %}
RUN usermod -a -G kolla ironic \ COPY extend_start.sh /usr/local/bin/kolla_extend_start
RUN touch /usr/local/bin/kolla_ironic_extend_start \
&& chmod 755 /usr/local/bin/kolla_extend_start /usr/local/bin/kolla_ironic_extend_start \
&& usermod -a -G kolla ironic \
&& chown -R ironic: /etc/ironic && chown -R ironic: /etc/ironic
{% block ironic_base_footer %}{% endblock %} {% block ironic_base_footer %}{% endblock %}

View File

@ -0,0 +1,12 @@
#!/bin/bash
LOG_PATH=/var/log/kolla/ironic
if [[ ! -d "${LOG_PATH}" ]]; then
mkdir -p "${LOG_PATH}"
fi
if [[ $(stat -c %a "${LOG_PATH}") != "755" ]]; then
chmod 755 "${LOG_PATH}"
fi
. /usr/local/bin/kolla_ironic_extend_start

View File

@ -0,0 +1 @@
ironic ALL = (root) NOPASSWD: /var/lib/kolla/venv/bin/ironic-rootwrap /etc/ironic/rootwrap.conf *

View File

@ -9,25 +9,39 @@ MAINTAINER {{ maintainer }}
{% if base_distro in ['centos', 'fedora', 'oraclelinux', 'rhel'] %} {% if base_distro in ['centos', 'fedora', 'oraclelinux', 'rhel'] %}
{% set ironic_conductor_packages = [ {% set ironic_conductor_packages = [
'openstack-ironic-conductor', 'openstack-ironic-conductor',
'qemu-img' 'qemu-img',
'ipmitool',
'parted',
'gdisk',
'psmisc'
] %} ] %}
{% elif base_distro in ['ubuntu'] %} {% elif base_distro in ['ubuntu'] %}
{% set ironic_conductor_packages = [ {% set ironic_conductor_packages = [
'ironic-conductor', 'ironic-conductor',
'qemu-utils', 'qemu-utils',
'ipmitool' 'ipmitool',
'gdisk',
'psmisc',
'parted'
] %} ] %}
{% endif %} {% endif %}
{% elif install_type == 'source' %} {% elif install_type == 'source' %}
{% if base_distro in ['centos', 'fedora', 'oraclelinux', 'rhel'] %} {% if base_distro in ['centos', 'fedora', 'oraclelinux', 'rhel'] %}
{% set ironic_conductor_packages = [ {% set ironic_conductor_packages = [
'qemu-img', 'qemu-img',
'ipmitool' 'ipmitool',
'parted',
'gdisk',
'psmisc',
'fuse'
] %} ] %}
{% elif base_distro in ['ubuntu', 'debian'] %} {% elif base_distro in ['ubuntu', 'debian'] %}
{% set ironic_conductor_packages = [ {% set ironic_conductor_packages = [
'qemu-utils', 'qemu-utils',
'ipmitool' 'ipmitool',
'gdisk',
'psmisc',
'parted'
] %} ] %}
{% endif %} {% endif %}
{% endif %} {% endif %}

View File

@ -21,8 +21,8 @@ MAINTAINER {{ maintainer }}
{{ macros.install_packages(ironic_pxe_packages | customizable("packages")) }} {{ macros.install_packages(ironic_pxe_packages | customizable("packages")) }}
COPY tftp-map-file /map-file COPY tftp-map-file /map-file
COPY extend_start.sh /usr/local/bin/kolla_extend_start COPY extend_start.sh /usr/local/bin/kolla_ironic_extend_start
RUN chmod 755 /usr/local/bin/kolla_extend_start RUN chmod 755 /usr/local/bin/kolla_ironic_extend_start
{% block ironic_pxe_footer %}{% endblock %} {% block ironic_pxe_footer %}{% endblock %}
{% block footer %}{% endblock %} {% block footer %}{% endblock %}