Skip to content
main.yml 5.48 KiB
Newer Older
- include: pre-upgrade.yml
  tags: [upgrade,  bootstrap-os]

Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
- name: Force binaries directory for Container Linux by CoreOS
  set_fact:
    bin_dir: "/opt/bin"
  when: ansible_os_family in ["CoreOS", "Container Linux by CoreOS"]
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: facts
ant31's avatar
ant31 committed
- name: check bin dir exists
  file:
    path: "{{bin_dir}}"
    state: directory
    owner: root
  become: true
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: bootstrap-os
- include: gitinfos.yml
  when: run_gitinfos
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: facts
- include: set_facts.yml
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: facts
Smaine Kahlouch's avatar
Smaine Kahlouch committed
- name: gather os specific variables
  include_vars: "{{ item }}"
  with_first_found:
    - files:
      - "{{ ansible_distribution|lower }}-{{ ansible_distribution_version|lower|replace('/', '_') }}.yml"
      - "{{ ansible_distribution|lower }}-{{ ansible_distribution_release }}.yml"
      - "{{ ansible_distribution|lower }}-{{ ansible_distribution_major_version|lower|replace('/', '_') }}.yml"
      - "{{ ansible_distribution|lower }}.yml"
      - "{{ ansible_os_family|lower }}.yml"
      - defaults.yml
      paths:
      - ../vars
Smana's avatar
Smana committed
      skip: true
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: facts
- name: Create kubernetes config directory
  file:
    path: "{{ kube_config_dir }}"
    state: directory
    owner: kube
  when: "{{ inventory_hostname in groups['k8s-cluster'] }}"
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: [kubelet, k8s-secrets, kube-controller-manager, kube-apiserver, bootstrap-os, apps, network, master, node]

- name: Create kubernetes script directory
  file:
    path: "{{ kube_script_dir }}"
    state: directory
    owner: kube
  when: "{{ inventory_hostname in groups['k8s-cluster'] }}"
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: [k8s-secrets, bootstrap-os]

- name: Create kubernetes manifests directory
  file:
    path: "{{ kube_manifest_dir }}"
    state: directory
    owner: kube
  when: "{{ inventory_hostname in groups['k8s-cluster'] }}"
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: [kubelet, bootstrap-os, master, node]
- name: check cloud_provider value
  fail:
    msg: "If set the 'cloud_provider' var must be set either to 'generic', 'gce', 'aws', 'azure' or 'openstack'"
  when: cloud_provider is defined and cloud_provider not in ['generic', 'gce', 'aws', 'openstack', 'azure']
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: [cloud-provider, facts]

- include: openstack-credential-check.yml
  when: cloud_provider is defined and cloud_provider == 'openstack'
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: [cloud-provider, openstack, facts]
- include: azure-credential-check.yml
  when: cloud_provider is defined and cloud_provider == 'azure'
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: [cloud-provider, azure, facts]
- name: Enable ip forwarding
  lineinfile:
    dest: /etc/sysctl.d/99-sysctl.conf
    regexp: '^net.ipv4.ip_forward='
    line: 'net.ipv4.ip_forward=1'
    state: present
    create: yes
    backup: yes
    validate: 'sysctl -f %s'
- name: Create cni directories
  file:
    path: "{{ item }}"
    state: directory
    owner: kube
  with_items:
    - "/etc/cni/net.d"
    - "/opt/cni/bin"
  when: kube_network_plugin in ["calico", "weave", "canal"] and "{{ inventory_hostname in groups['k8s-cluster'] }}"
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: [network, calico, weave, canal, bootstrap-os]
- name: Update package management cache (YUM)
  yum: update_cache=yes name='*'
  when: ansible_pkg_mgr == 'yum'
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: bootstrap-os
- name: Install latest version of python-apt for Debian distribs
  apt: name=python-apt state=latest update_cache=yes cache_valid_time=3600
  when: ansible_os_family == "Debian"
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: bootstrap-os
Smaine Kahlouch's avatar
Smaine Kahlouch committed

- name: Install python-dnf for latest RedHat versions
Smana's avatar
Smana committed
  command: dnf install -y python-dnf yum
Smaine Kahlouch's avatar
Smaine Kahlouch committed
  when: ansible_distribution == "Fedora" and
        ansible_distribution_major_version > 21
  changed_when: False
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: bootstrap-os
Smana's avatar
Smana committed
- name: Install epel-release on RedHat/CentOS
  shell: rpm -qa | grep epel-release || rpm -ivh {{ epel_rpm_download_url }}
  when: ansible_distribution in ["CentOS","RedHat"]
  changed_when: False
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: bootstrap-os
Smaine Kahlouch's avatar
Smaine Kahlouch committed
- name: Install packages requirements
  action:
    module: "{{ ansible_pkg_mgr }}"
    name: "{{ item }}"
    state: latest
  register: pkgs_task_result
  until: pkgs_task_result|success
  retries: 4
  delay: "{{ retry_stagger | random + 3 }}"
Smana's avatar
Smana committed
  with_items: "{{required_pkgs | default([]) | union(common_required_pkgs|default([]))}}"
  when: not ansible_os_family in ["CoreOS", "Container Linux by CoreOS"]
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: bootstrap-os
- name: Disable IPv6 DNS lookup
  lineinfile:
    dest: /etc/gai.conf
    line: "precedence ::ffff:0:0/96  100"
    state: present
    backup: yes
  when: disable_ipv6_dns and not ansible_os_family in ["CoreOS", "Container Linux by CoreOS"]
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: bootstrap-os
Smaine Kahlouch's avatar
Smaine Kahlouch committed
# Todo : selinux configuration
- name: Set selinux policy to permissive
  selinux: policy=targeted state=permissive
  when: ansible_os_family == "RedHat"
Smaine Kahlouch's avatar
Smaine Kahlouch committed
  changed_when: False
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: bootstrap-os
- name: Write openstack cloud-config
  template:
    src: openstack-cloud-config.j2
    dest: "{{ kube_config_dir }}/cloud_config"
    group: "{{ kube_cert_group }}"
    mode: 0640
  when: cloud_provider is defined and cloud_provider == "openstack"
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: [cloud-provider, openstack]
- name: Write azure cloud-config
  template:
    src: azure-cloud-config.j2
    dest: "{{ kube_config_dir }}/cloud_config"
    group: "{{ kube_cert_group }}"
    mode: 0640
  when: cloud_provider is defined and cloud_provider == "azure"
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: [cloud-provider, azure]
- include: etchosts.yml
Bogdan Dobrelya's avatar
Bogdan Dobrelya committed
  tags: [bootstrap-os, etchosts]

- include: resolvconf.yml
  tags: [bootstrap-os, resolvconf]
- name: Check if we are running inside a Azure VM
  stat: path=/var/lib/waagent/
  register: azure_check
  tags: bootstrap-os

- include: growpart-azure-centos-7.yml
  when: azure_check.stat.exists and
        ansible_distribution in ["CentOS","RedHat"]