-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmaster-playbook.yml
120 lines (102 loc) · 2.92 KB
/
master-playbook.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
---
- hosts: all
become: true
tasks:
- name: Install packages that allow apt to be used over HTTPS
apt:
name: "{{ packages }}"
state: present
update_cache: yes
vars:
packages:
- apt-transport-https
- ca-certificates
- curl
- gnupg-agent
- software-properties-common
- name: Add an apt signing key for Docker
apt_key:
url: https://download.docker.com/linux/ubuntu/gpg
state: present
- name: Add apt repository for stable version
apt_repository:
repo: deb [arch=amd64] https://download.docker.com/linux/ubuntu xenial stable
state: present
- name: Install docker and its dependecies
apt:
name: "{{ packages }}"
state: present
update_cache: yes
vars:
packages:
- docker-ce
- docker-ce-cli
- containerd.io
notify:
- docker status
- name: Add vagrant user to docker group
user:
name: vagrant
group: docker
- name: Disable swap
command: swapoff -a
- name: Add an apt signing key for Kubernetes
apt_key:
url: https://packages.cloud.google.com/apt/doc/apt-key.gpg
state: present
- name: Adding apt repository for Kubernetes
apt_repository:
repo: deb https://apt.kubernetes.io/ kubernetes-xenial main
state: present
filename: kubernetes.list
- name: Install Kubernetes binaries
apt:
name: "{{ packages }}"
state: present
update_cache: yes
vars:
packages:
- kubelet
- kubeadm
- kubectl
register: installed
- name: Restart kubelet
service:
name: kubelet
daemon_reload: yes
state: restarted
- name: Initialize the Kubernetes cluster using kubeadm
command: kubeadm init --apiserver-advertise-address="192.169.50.10" --apiserver-cert-extra-sans="192.169.50.10" --node-name master --pod-network-cidr=192.168.0.0/16
when: installed is changed
- name: Create .kube folder
become: false
file:
path: /home/vagrant/.kube
state: directory
- name: Copy admin.conf file
copy: remote_src=True src=/etc/kubernetes/admin.conf dest=/home/vagrant/.kube/config
- name: Change admin.conf owner
file:
path: /home/vagrant/.kube/config
owner: vagrant
group: vagrant
- name: Install calico pod network
become: false
command: kubectl apply -f https://docs.projectcalico.org/manifests/calico.yaml
- name: Generate join command
command: kubeadm token create --print-join-command
register: join_command
- name: Copy join command to local file
copy:
dest: "join"
content: "{{ join_command.stdout_lines[0] }}"
become: false
delegate_to: localhost
- name: Copy .kube/config to local file
fetch:
dest: "kubeconfig"
src: /home/vagrant/.kube/config
become: false
handlers:
- name: docker status
service: name=docker state=started