diff options
author | Harry Huang <huangxiangyu5@huawei.com> | 2017-11-07 15:30:51 +0800 |
---|---|---|
committer | Harry Huang <huangxiangyu5@huawei.com> | 2017-12-21 15:35:12 +0800 |
commit | a360411cb8c775dffa24a4157cec2b566cbde6f3 (patch) | |
tree | 400e879a6f6779c294d7f2113c05b29d5578cff3 /util/docker-compose/roles/compass/tasks | |
parent | 4074d39e93d7e7697dd2aaad2e08433ca0a60221 (diff) |
Add compass-docker-compose
1. Add ansible for docker compose containerized
compass
2. deploy/conf/compass.conf no longer specify
image tags for runtime. build.yaml now is added
into compass tarball to be the only place determine
image tags
3. This patch is based on patch:
https://gerrit.opnfv.org/gerrit/#/c/47393/
use merged compass-tasks
4. Tempoarily using private docker repo for
compass-tasks. Switch to opnfv repo when patch
https://gerrit.opnfv.org/gerrit/#/c/47329/
is merged
5. Modify ansible callback module accrodingly
Change-Id: I0728a9002a1cc7804c9e8f13bd1afdccb684a159
Signed-off-by: Harry Huang <huangxiangyu5@huawei.com>
Diffstat (limited to 'util/docker-compose/roles/compass/tasks')
-rwxr-xr-x | util/docker-compose/roles/compass/tasks/main.yml | 139 |
1 files changed, 139 insertions, 0 deletions
diff --git a/util/docker-compose/roles/compass/tasks/main.yml b/util/docker-compose/roles/compass/tasks/main.yml new file mode 100755 index 00000000..9ee7902e --- /dev/null +++ b/util/docker-compose/roles/compass/tasks/main.yml @@ -0,0 +1,139 @@ +--- +- include_vars: "{{ compass_dists_dir }}/build.yaml" + +- set_fact: + image_name: "{{ item.name | regex_replace('-', '_') }}" + image_repo: "{{ item.url }}" + with_items: "{{ packages }}" + when: item.name in compose_images + register: compass_images + +- name: generate compose_images.yml + copy: + dest: "{{ compass_dists_dir }}/compose_images.yml" + content: | + {% set image_dict = {} %} + {% for item in compass_images.results %} + {% if "ansible_facts" in item %} + {% set facts = item.ansible_facts %} + {% set _ = image_dict.update({facts.image_name: facts.image_repo}) %} + {% endif %} + {% endfor %} + {% for key in image_dict %} + {{ key }}: {{ image_dict[key] }} + {% endfor %} + +- include_vars: "{{ compass_dists_dir }}/compose_images.yml" + +- name: get jumphost ip + shell: | + external_nic=`ip route |grep '^default'|awk '{print $5F}'|sed -n '1p'` + host_ip=`ifconfig $external_nic | grep 'inet addr:' | cut -d: -f2 | awk '{ print $1}'` + echo $host_ip + register: external_ip + +- name: fix name.service + shell: | + if [ ! -f "/etc/apparmor.d/disable/usr.sbin.named" ]; then + ln -s /etc/apparmor.d/usr.sbin.named /etc/apparmor.d/disable/ + apparmor_parser -R /etc/apparmor.d/usr.sbin.named + fi + +- name: render docker-compose file + template: + src: docker-compose.yml.j2 + dest: "{{ docker_compose_dir }}/docker-compose.yml" + +- name: docker-compose down + shell: docker-compose down + args: + chdir: "{{ docker_compose_dir }}" + +- name: load docker images + shell: | + images=$(ls "{{ compass_dists_dir }}" | grep .*.tar) + for image in $images + do + docker load -i "{{ compass_dists_dir }}/$image" + done + +- name: copy files + shell: + cp -rf "{{ item }}" "{{ docker_compose_dir }}" + with_items: + - "{{ compass_dir }}/deploy/adapters/ansible" + - "{{ compass_dir }}/deploy/compass_conf" + - "{{ compass_dir }}/deploy/adapters/cobbler" + +- name: retrieve plugins list + command: "ls {{ compass_dir }}/plugins/" + register: plugin_list + +- name: copy plugins roles + copy: + src: "{{ compass_dir }}/plugins/{{ item }}/roles/" + dest: "{{ docker_compose_dir }}/ansible/roles/" + with_items: "{{ plugin_list.stdout_lines }}" + when: item != 'template' + +- name: chmod directory + file: + dest: "{{ item }}" + mode: 0755 + with_items: + - "{{ compass_dir }}/deploy/adapters/ansible" + - "{{ compass_dir }}/deploy/compass_conf" + - "{{ compass_dir }}/deploy/adapters/cobbler" + +- name: copy ansible scripts into ansible folder + shell: | + for i in `ls "{{ docker_compose_dir }}/ansible" | grep "openstack_"`; do + cp -rf "{{ docker_compose_dir }}"/ansible/openstack/* \ + "{{ docker_compose_dir }}"/ansible/$i + done + +- name: create run dir + file: + path: "{{ docker_compose_dir }}/ansible/run" + state: directory + +- name: render cobbler + template: + src: "{{ item }}.j2" + dest: "{{ docker_compose_dir }}/compass_conf/os_installer/{{ item }}" + with_items: + - cobbler.conf + +- name: docker-compose up + shell: docker-compose up -d + args: + chdir: "{{ docker_compose_dir }}" + +- name: create compass db tables + shell: | + sleep 3; \ + docker exec compass-deck bash -c "/opt/compass/bin/manage_db.py createdb" + register: result1 + until: result1.rc == 0 + retries: 10 + delay: 2 + tags: + - redploy + +- name: add ansible callback + shell: | + docker cp "{{ item }}" \ + compass-deck:/root/compass-deck/bin/ansible_callbacks + docker cp "{{ item }}" \ + compass-tasks:/opt/ansible_callbacks + with_items: + - "{{ compass_dir }}/deploy/status_callback.py" + - "{{ compass_dir }}/deploy/playbook_done.py" + +- name: rm ansible run + shell: | + docker exec compass-tasks bash -c "rm -rf /var/ansible/run/*" + +- name: start httpd service + shell: | + docker exec compass-deck bash -c "systemctl start httpd" |