01d2e2e331
Since compute nodes needs to resolve each other, and controller nodes needs to resolve each other, let everyone resolve everyone. Change-Id: I1ee117bdb2d71d48a064c4d317b53a1500bdd753 Closes-Bug: #1623669
141 lines
3.5 KiB
YAML
141 lines
3.5 KiB
YAML
---
|
|
# NOTE: raw install is required to support cloud images which do not have python installed
|
|
- name: "install python2 and python-simplejson"
|
|
become: true
|
|
raw: "yum install -y python python-simplejson || (apt-get update && apt-get install -y python2.7 python-simplejson)"
|
|
|
|
- name: gather facts
|
|
setup:
|
|
|
|
- name: get node hostname
|
|
shell: echo $(hostname)
|
|
register: node_hostname
|
|
|
|
- name: update /etc/hosts with hostname
|
|
lineinfile:
|
|
dest: /etc/hosts
|
|
regexp: "127.0.0.1 {{ node_hostname.stdout }} localhost"
|
|
line: "127.0.0.1 {{ node_hostname.stdout }} localhost"
|
|
state: present
|
|
become: True
|
|
when: customize_etc_hosts | bool == True
|
|
|
|
- name: Generate etc/hosts
|
|
blockinfile:
|
|
dest: /etc/hosts
|
|
marker: "# {mark} ANSIBLE GENERATED HOSTS"
|
|
block: |
|
|
{% for host in groups['all'] %}
|
|
{{ hostvars[host]['ansible_' + hostvars[host]['api_interface']]['ipv4']['address'] }} {{ hostvars[host]['ansible_hostname'] }}
|
|
{% endfor %}
|
|
when: customize_etc_hosts | bool
|
|
|
|
- name: ensure sudo group is present
|
|
group: name=sudo state=present
|
|
become: True
|
|
|
|
- name: ensure kolla group is present
|
|
group: name=kolla state=present
|
|
become: True
|
|
when: create_kolla_user | bool == True
|
|
|
|
- name: create kolla user
|
|
user:
|
|
name: kolla
|
|
state: present
|
|
group: kolla
|
|
groups: "sudo"
|
|
become: True
|
|
when: create_kolla_user | bool == True
|
|
|
|
- name: grant kolla user passwordless sudo
|
|
lineinfile:
|
|
dest: /etc/sudoers
|
|
state: present
|
|
regexp: '^kolla'
|
|
line: 'kolla ALL=(ALL) NOPASSWD: ALL'
|
|
become: True
|
|
when: create_kolla_user | bool == True
|
|
|
|
- name: add public key to kolla user authorized keys
|
|
authorized_key:
|
|
user: kolla
|
|
key: "{{ kolla_ssh_key.public_key }}"
|
|
become: True
|
|
when: create_kolla_user | bool == True
|
|
|
|
- name: install apt packages
|
|
command: apt-get update
|
|
become: True
|
|
when: ansible_os_family == 'Debian'
|
|
|
|
- name: install ubuntu ca certs
|
|
package: name={{item}} state=latest
|
|
become: True
|
|
with_items:
|
|
- ca-certificates
|
|
- apt-transport-https
|
|
when:
|
|
- ansible_os_family == 'Debian'
|
|
|
|
- name: Ensure apt sources list directory exists
|
|
file: path=/etc/apt/sources.list.d state=directory recurse=yes
|
|
become: True
|
|
when: ansible_os_family == 'Debian'
|
|
|
|
- name: enable docker repo apt
|
|
template:
|
|
src: docker_apt_repo.j2
|
|
dest: /etc/apt/sources.list.d/docker.list
|
|
become: True
|
|
when: ansible_os_family == 'Debian'
|
|
|
|
- name: install docker apt gpg key
|
|
apt_key:
|
|
url: "{{ docker_apt_url }}/gpg"
|
|
id: "{{ docker_apt_key_id }}"
|
|
state: present
|
|
become: True
|
|
when:
|
|
- ansible_os_family == 'Debian'
|
|
- ansible_distribution == 'Ubuntu'
|
|
|
|
- name: Ensure yum repos directory exists
|
|
file: path=/etc/yum.repos.d/ state=directory recurse=yes
|
|
become: True
|
|
when: ansible_os_family == 'RedHat'
|
|
|
|
- name: enable docker repo yum
|
|
become: True
|
|
template:
|
|
src: docker_yum_repo.j2
|
|
dest: /etc/yum.repos.d/docker.repo
|
|
when: ansible_os_family == 'RedHat'
|
|
|
|
- name: install docker rpm gpg key
|
|
rpm_key:
|
|
state: present
|
|
key: "{{ docker_yum_url }}/gpg"
|
|
become: True
|
|
when: ansible_os_family == 'RedHat'
|
|
|
|
- name: Ensure /etc/kolla directory exists
|
|
file:
|
|
path: /etc/kolla
|
|
state: directory
|
|
recurse: yes
|
|
owner: kolla
|
|
group: kolla
|
|
mode: 755
|
|
become: True
|
|
when: create_kolla_user | bool == True
|
|
|
|
- name: Ensure /etc/kolla directory exists
|
|
file:
|
|
path: /etc/kolla
|
|
state: directory
|
|
recurse: yes
|
|
mode: 666
|
|
become: True
|
|
when: create_kolla_user | bool == False
|