Merge "Add a Kolla 'devstack' mode"

This commit is contained in:
Jenkins 2017-06-14 00:02:42 +00:00 committed by Gerrit Code Review
commit ca95e2c4e4
12 changed files with 134 additions and 7 deletions

View File

@ -43,6 +43,10 @@ kolla_enable_sanity_glance: "{{ kolla_enable_sanity_checks }}"
kolla_enable_sanity_cinder: "{{ kolla_enable_sanity_checks }}" kolla_enable_sanity_cinder: "{{ kolla_enable_sanity_checks }}"
kolla_enable_sanity_swift: "{{ kolla_enable_sanity_checks }}" kolla_enable_sanity_swift: "{{ kolla_enable_sanity_checks }}"
kolla_dev_repos_directory: "/opt/stack/"
kolla_dev_repos_git: "https://git.openstack.org/openstack"
kolla_dev_repos_pull: "no"
kolla_dev_mode: "no"
#################### ####################
# kolla-kubernetes # kolla-kubernetes

View File

@ -1,2 +1,3 @@
--- ---
destroy_include_images: "{{ enable_destroy_images }}" destroy_include_images: "{{ enable_destroy_images }}"
destroy_include_dev: "no"

View File

@ -5,6 +5,8 @@
enable_swift={{ enable_swift }} enable_swift={{ enable_swift }}
kolla_internal_vip_address={{ kolla_internal_vip_address }} kolla_internal_vip_address={{ kolla_internal_vip_address }}
kolla_external_vip_address={{ kolla_external_vip_address }} kolla_external_vip_address={{ kolla_external_vip_address }}
kolla_dev_repos_directory={{ kolla_dev_repos_directory }}
destroy_include_dev={{ destroy_include_dev }}
/tmp/kolla-cleanup/tools/cleanup-host /tmp/kolla-cleanup/tools/cleanup-host
- name: Destroying kolla-cleanup folder - name: Destroying kolla-cleanup folder

View File

@ -10,6 +10,7 @@ heat_services:
volumes: volumes:
- "{{ node_config_directory }}/heat-api/:{{ container_config_directory }}/:ro" - "{{ node_config_directory }}/heat-api/:{{ container_config_directory }}/:ro"
- "/etc/localtime:/etc/localtime:ro" - "/etc/localtime:/etc/localtime:ro"
- "{{ kolla_dev_repos_directory ~ '/heat/heat:/var/lib/kolla/venv/lib/python2.7/site-packages/heat' if heat_dev_mode | bool else '' }}"
- "kolla_logs:/var/log/kolla/" - "kolla_logs:/var/log/kolla/"
heat-api-cfn: heat-api-cfn:
container_name: heat_api_cfn container_name: heat_api_cfn
@ -19,6 +20,7 @@ heat_services:
volumes: volumes:
- "{{ node_config_directory }}/heat-api-cfn/:{{ container_config_directory }}/:ro" - "{{ node_config_directory }}/heat-api-cfn/:{{ container_config_directory }}/:ro"
- "/etc/localtime:/etc/localtime:ro" - "/etc/localtime:/etc/localtime:ro"
- "{{ kolla_dev_repos_directory ~ '/heat/heat:/var/lib/kolla/venv/lib/python2.7/site-packages/heat' if heat_dev_mode | bool else '' }}"
- "kolla_logs:/var/log/kolla/" - "kolla_logs:/var/log/kolla/"
heat-engine: heat-engine:
container_name: heat_engine container_name: heat_engine
@ -28,6 +30,7 @@ heat_services:
volumes: volumes:
- "{{ node_config_directory }}/heat-engine/:{{ container_config_directory }}/:ro" - "{{ node_config_directory }}/heat-engine/:{{ container_config_directory }}/:ro"
- "/etc/localtime:/etc/localtime:ro" - "/etc/localtime:/etc/localtime:ro"
- "{{ kolla_dev_repos_directory ~ '/heat/heat:/var/lib/kolla/venv/lib/python2.7/site-packages/heat' if heat_dev_mode | bool else '' }}"
- "kolla_logs:/var/log/kolla/" - "kolla_logs:/var/log/kolla/"
#################### ####################
@ -56,6 +59,7 @@ heat_engine_image: "{{ docker_registry ~ '/' if docker_registry else '' }}{{ doc
heat_engine_tag: "{{ heat_tag }}" heat_engine_tag: "{{ heat_tag }}"
heat_engine_image_full: "{{ heat_engine_image }}:{{ heat_engine_tag }}" heat_engine_image_full: "{{ heat_engine_image }}:{{ heat_engine_tag }}"
#################### ####################
# OpenStack # OpenStack
#################### ####################
@ -73,3 +77,11 @@ heat_stack_user_role: "heat_stack_user"
heat_stack_owner_role: "heat_stack_owner" heat_stack_owner_role: "heat_stack_owner"
openstack_heat_auth: "{{ openstack_auth }}" openstack_heat_auth: "{{ openstack_auth }}"
####################
# Kolla
####################
heat_git_repository: "{{ kolla_dev_repos_git }}/{{ project_name }}"
heat_dev_repos_pull: "{{ kolla_dev_repos_pull }}"
heat_dev_mode: "{{ kolla_dev_mode }}"

View File

@ -12,7 +12,7 @@
common_options: "{{ docker_common_options }}" common_options: "{{ docker_common_options }}"
name: "{{ service.container_name }}" name: "{{ service.container_name }}"
image: "{{ service.image }}" image: "{{ service.image }}"
volumes: "{{ service.volumes }}" volumes: "{{ service.volumes|reject('equalto', '')|list }}"
when: when:
- action != "config" - action != "config"
- inventory_hostname in groups[service.group] - inventory_hostname in groups[service.group]
@ -35,7 +35,7 @@
common_options: "{{ docker_common_options }}" common_options: "{{ docker_common_options }}"
name: "{{ service.container_name }}" name: "{{ service.container_name }}"
image: "{{ service.image }}" image: "{{ service.image }}"
volumes: "{{ service.volumes }}" volumes: "{{ service.volumes|reject('equalto', '')|list }}"
when: when:
- action != "config" - action != "config"
- inventory_hostname in groups[service.group] - inventory_hostname in groups[service.group]
@ -58,7 +58,7 @@
common_options: "{{ docker_common_options }}" common_options: "{{ docker_common_options }}"
name: "{{ service.container_name }}" name: "{{ service.container_name }}"
image: "{{ service.image }}" image: "{{ service.image }}"
volumes: "{{ service.volumes }}" volumes: "{{ service.volumes|reject('equalto', '')|list }}"
when: when:
- action != "config" - action != "config"
- inventory_hostname in groups[service.group] - inventory_hostname in groups[service.group]

View File

@ -0,0 +1,6 @@
---
- name: Cloning source repositories for development
git:
repo: "{{ heat_git_repository }}"
dest: "{{ kolla_dev_repos_directory }}/{{ project_name }}"
update: "{{ heat_dev_repos_pull }}"

View File

@ -7,6 +7,13 @@
inventory_hostname in groups['heat-api-cfn'] or inventory_hostname in groups['heat-api-cfn'] or
inventory_hostname in groups['heat-engine'] inventory_hostname in groups['heat-engine']
- include: clone.yml
when:
- heat_dev_mode | bool
- inventory_hostname in groups['heat-api'] or
inventory_hostname in groups['heat-api-cfn'] or
inventory_hostname in groups['heat-engine']
- include: bootstrap.yml - include: bootstrap.yml
when: inventory_hostname in groups['heat-api'] when: inventory_hostname in groups['heat-api']

View File

@ -48,6 +48,7 @@ Overview
advanced-configuration advanced-configuration
operating-kolla operating-kolla
security security
kolla-for-openstack-development
troubleshooting troubleshooting
Services Services

View File

@ -0,0 +1,75 @@
=====================================
Using Kolla For OpenStack Development
=====================================
Kolla-ansible can be used to deploy containers in a way suitable for doing
development on OpenStack services.
.. note::
This functionality is new in the Pike release.
Heat was the first service to be supported, and so the following will use
submitting a patch to Heat using Kolla as an example.
Only source containers are supported.
.. WARNING::
Kolla dev mode is intended for OpenStack hacking/development only. Do not
use this in production!
Enabling Kolla "dev mode"
-------------------------
To enable dev mode for all supported services, set in ``/etc/kolla/globals.yml``:
::
kolla_dev_mode: true
To enable it just for heat, set:
::
heat_dev_mode: true
Usage
-----
When enabled, the source repo for the service in question will be cloned under
``/opt/stack/`` on the target node(s). This will be bind mounted into the
container's virtualenv under the location expected by the service on startup.
After making code changes, simply restart the container to pick them up:
::
docker restart heat_api
Debugging
---------
``remote_pdb`` can be used to perform debugging with Kolla containers. First,
make sure it is installed in the container in question:
::
docker exec -it -u root heat_api pip install remote_pdb
Then, set your breakpoint as follows:
::
from remote_pdb import RemotePdb
RemotePdb('127.0.0.1', 4444).set_trace()
Once you run the code(restart the container), pdb can be accessed using
``socat``:
::
socat readline tcp:127.0.0.1:4444
For more information on remote_pdb, see
https://pypi.python.org/pypi/remote-pdb.

View File

@ -0,0 +1,4 @@
---
features:
- Add a Kolla 'devstack' mode. See doc/kolla-for-openstack-development.rst
for more info.

View File

@ -63,3 +63,8 @@ for dir in $FOLDER_PATH*; do
rm -rfv $dir rm -rfv $dir
fi fi
done done
if [[ "$destroy_include_dev" == "yes" ]]; then
echo "Cleaning up dev repos..."
rm -rfv "${kolla_dev_repos_directory}"
fi

View File

@ -51,7 +51,8 @@ Commands:
mariadb_recovery Recover a completely stopped mariadb cluster mariadb_recovery Recover a completely stopped mariadb cluster
bootstrap-servers bootstrap servers with kolla deploy dependencies bootstrap-servers bootstrap servers with kolla deploy dependencies
destroy Destroy Kolla containers, volumes and host configuration destroy Destroy Kolla containers, volumes and host configuration
(--include-images to also destroy Kolla images) --include-images to also destroy Kolla images
--include-dev to also destroy dev mode repos
deploy Deploy and start all kolla containers deploy Deploy and start all kolla containers
deploy-bifrost Deploy and start bifrost container deploy-bifrost Deploy and start bifrost container
deploy-servers Enroll and deploy servers with bifrost deploy-servers Enroll and deploy servers with bifrost
@ -96,7 +97,7 @@ EOF
} }
SHORT_OPTS="hi:p:t:k:e:v" SHORT_OPTS="hi:p:t:k:e:v"
LONG_OPTS="help,inventory:,playbook:,tags:,key:,extra:,verbose,configdir:,passwords:,limit:,yes-i-really-really-mean-it,include-images" LONG_OPTS="help,inventory:,playbook:,tags:,key:,extra:,verbose,configdir:,passwords:,limit:,yes-i-really-really-mean-it,include-images,include-dev"
ARGS=$(getopt -o "${SHORT_OPTS}" -l "${LONG_OPTS}" --name "$0" -- "$@") || { usage >&2; exit 2; } ARGS=$(getopt -o "${SHORT_OPTS}" -l "${LONG_OPTS}" --name "$0" -- "$@") || { usage >&2; exit 2; }
eval set -- "$ARGS" eval set -- "$ARGS"
@ -111,8 +112,9 @@ CONFIG_DIR="/etc/kolla"
PASSWORDS_FILE="${CONFIG_DIR}/passwords.yml" PASSWORDS_FILE="${CONFIG_DIR}/passwords.yml"
DANGER_CONFIRM= DANGER_CONFIRM=
INCLUDE_IMAGES= INCLUDE_IMAGES=
# Serial is not recommended and disabled by default. User could enable it by INCLUDE_DEV=
# simply configuring ANSIBLE_SERIAL variable. # Serial is not recommended and disabled by default. Users can enable it by
# configuring ANSIBLE_SERIAL variable.
ANSIBLE_SERIAL=${ANSIBLE_SERIAL:-0} ANSIBLE_SERIAL=${ANSIBLE_SERIAL:-0}
while [ "$#" -gt 0 ]; do while [ "$#" -gt 0 ]; do
@ -153,6 +155,11 @@ while [ "$#" -gt 0 ]; do
shift 1 shift 1
;; ;;
(--include-dev)
INCLUDE_DEV="$1"
shift 1
;;
(--key|-k) (--key|-k)
VAULT_PASS_FILE="$2" VAULT_PASS_FILE="$2"
EXTRA_OPTS="$EXTRA_OPTS --vault-password-file=$VAULT_PASS_FILE" EXTRA_OPTS="$EXTRA_OPTS --vault-password-file=$VAULT_PASS_FILE"
@ -211,6 +218,9 @@ case "$1" in
if [[ "${INCLUDE_IMAGES}" == "--include-images" ]]; then if [[ "${INCLUDE_IMAGES}" == "--include-images" ]]; then
EXTRA_OPTS="$EXTRA_OPTS -e destroy_include_images=yes" EXTRA_OPTS="$EXTRA_OPTS -e destroy_include_images=yes"
fi fi
if [[ "${INCLUDE_DEV}" == "--include-dev" ]]; then
EXTRA_OPTS="$EXTRA_OPTS -e destroy_include_dev=yes"
fi
if [[ "${DANGER_CONFIRM}" != "--yes-i-really-really-mean-it" ]]; then if [[ "${DANGER_CONFIRM}" != "--yes-i-really-really-mean-it" ]]; then
cat << EOF cat << EOF
WARNING: WARNING: