Skip to content
Snippets Groups Projects
main.yml 5.45 KiB
Newer Older
  • Learn to ignore specific revisions
  • - name: Force binaries directory for CoreOS
      set_fact:
        bin_dir: "/opt/bin"
      when: ansible_os_family == "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: Create kubernetes logs directory
      file:
        path: "{{ kube_log_dir }}"
        state: directory
        owner: kube
    
      when: ansible_service_mgr in ["sysvinit","upstart"] and "{{ inventory_hostname in groups['k8s-cluster'] }}"
    
    Bogdan Dobrelya's avatar
    Bogdan Dobrelya committed
      tags: [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: Fix ipv4 forward rule in GCE security policy
      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'
      when: cloud_provider is defined and cloud_provider == 'gce'
    
    Bogdan Dobrelya's avatar
    Bogdan Dobrelya committed
      tags: [cloud-provider, gce, bootstrap-os]
    
    - 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"] and
    
            ansible_distribution_major_version >= 7
    
      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: ansible_os_family != "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 ansible_os_family != "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]