k8s-sig-cluster-lifecycleawskubesprayhigh-availabilityansiblekubernetes-clustergcekubernetesbare-metal
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
100 lines
2.7 KiB
100 lines
2.7 KiB
---
|
|
- include: gitinfos.yml
|
|
when: run_gitinfos
|
|
|
|
- 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
|
|
|
|
- name: Create kubernetes config directory
|
|
file:
|
|
path: "{{ kube_config_dir }}"
|
|
state: directory
|
|
owner: kube
|
|
|
|
- name: Create kubernetes script directory
|
|
file:
|
|
path: "{{ kube_script_dir }}"
|
|
state: directory
|
|
owner: kube
|
|
|
|
- name: Create kubernetes manifests directory
|
|
file:
|
|
path: "{{ kube_manifest_dir }}"
|
|
state: directory
|
|
owner: kube
|
|
|
|
- name: Create kubernetes logs directory
|
|
file:
|
|
path: "{{ kube_log_dir }}"
|
|
state: directory
|
|
owner: kube
|
|
when: ansible_service_mgr in ["sysvinit","upstart"]
|
|
|
|
- name: Create cni directories
|
|
file:
|
|
path: "{{ item }}"
|
|
state: directory
|
|
owner: kube
|
|
with_items:
|
|
- "/etc/cni/net.d"
|
|
- "/opt/cni/bin"
|
|
when: kube_network_plugin == "calico"
|
|
|
|
- name: Update package management cache (APT)
|
|
apt: update_cache=yes
|
|
when: ansible_pkg_mgr == 'apt'
|
|
|
|
- name: Update package management cache (YUM)
|
|
yum: update_cache=yes name='*'
|
|
when: ansible_pkg_mgr == 'yum'
|
|
|
|
- name: Install python-apt for Debian distribs
|
|
command: apt-get install -y python-apt
|
|
when: ansible_os_family == "Debian"
|
|
changed_when: False
|
|
|
|
- name: Install python-dnf for latest RedHat versions
|
|
command: dnf install -y python-dnf yum
|
|
when: ansible_distribution == "Fedora" and
|
|
ansible_distribution_major_version > 21
|
|
changed_when: False
|
|
|
|
- name: Install epel-release on RHEL
|
|
command: rpm -ivh http://dl.fedoraproject.org/pub/epel/7/x86_64/e/epel-release-7-5.noarch.rpm
|
|
when: ansible_distribution == "RedHat"
|
|
|
|
- name: Install epel-release on CentOS
|
|
action:
|
|
module: "{{ ansible_pkg_mgr }}"
|
|
name: "epel-release"
|
|
state: latest
|
|
when: ansible_distribution == "CentOS"
|
|
|
|
- name: Install packages requirements
|
|
action:
|
|
module: "{{ ansible_pkg_mgr }}"
|
|
name: "{{ item }}"
|
|
state: latest
|
|
with_items: "{{required_pkgs | union(common_required_pkgs)}}"
|
|
when: ansible_os_family in [ "Debian", "RedHat" ]
|
|
|
|
# Todo : selinux configuration
|
|
- name: Set selinux policy to permissive
|
|
selinux: policy=targeted state=permissive
|
|
when: ansible_os_family == "RedHat"
|
|
changed_when: False
|
|
|
|
- include: etchosts.yml
|
|
|
|
- include: python-bootstrap.yml
|
|
when: ansible_os_family not in [ "Debian", "RedHat" ]
|