-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathfuncs.sh
263 lines (246 loc) · 10.8 KB
/
funcs.sh
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
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
#!/bin/bash
GREEN='\033[1;32m'
RED='\033[1;31m'
YELLOW='\033[1;33m'
NC='\033[0m' # No Color
DOCKER_COMPOSE_VERSION="2.10.2"
TERRAFORM_VERSION="1.2.8"
PACKER_VERSION="1.8.3"
KIND_VERSION="0.11.1"
CRICTL_VERSION="v1.24.2"
CRI_LATEST_VER=$(curl -s https://api.github.com/repos/Mirantis/cri-dockerd/releases/latest|grep tag_name | cut -d '"' -f 4|sed 's/v//g')
VAGRANT_VERSION="2.2.19"
AWS_OS=$(cat /etc/os-release | awk -F '=' '/^ID=/ {print $2}' | cut -d '"' -f 2)
function install_ansible() {
echo -e "${YELLOW}[+] Installing Ansible...${NC}"
if [ "${AWS_OS}" = "amzn" ]; then
sudo yum update -y
sudo amazon-linux-extras install ansible2 -y
else [ "${AWS_OS}" = "ubuntu" ];
sudo apt -y remove needrestart
sudo apt update -y
sudo apt install software-properties-common -y
sudo apt-add-repository -y --update ppa:ansible/ansible
sudo apt install ansible -y
fi
}
function install_docker() {
echo -e "${YELLOW}[+] Installing Docker...${NC}"
if [ "${AWS_OS}" = "amzn" ]; then
sudo yum update -y
sudo amazon-linux-extras install docker -y
sudo usermod -a -G docker ec2-user
id ec2-user
newgrp docker
wget https://github.com/docker/compose/releases/latest/download/docker-compose-$(uname -s)-$(uname -m)
sudo mv docker-compose-$(uname -s)-$(uname -m) /usr/local/bin/docker-compose
sudo chmod -v +x /usr/local/bin/docker-compose
# TODO docker-compose is not installed on the instance
sudo systemctl enable docker.service
sudo systemctl start docker.service
elif [ "${AWS_OS}" = "ubuntu" ]; then
sudo apt-get update --yes
sudo apt install -y \
apt-transport-https \
ca-certificates \
curl \
software-properties-common
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
sudo add-apt-repository -y \
"deb [arch=amd64] https://download.docker.com/linux/ubuntu \
$(lsb_release -cs) \
stable"
sudo apt-get install -y docker-ce
sudo usermod -aG docker $USER
sudo curl -L "https://github.com/docker/compose/releases/download/$DOCKER_COMPOSE_VERSION/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose
sudo systemctl start docker
sudo systemctl enable docker
else
echo "Unsupported OS"
exit 1
fi
}
function install_cri-dockerd() {
echo -e "${YELLOW}[+] Installing CRI-Dockerd...${NC}"
if [ "${AWS_OS}" = "amzn" ]; then
wget https://github.com/Mirantis/cri-dockerd/releases/download/v${CRI_LATEST_VER}/cri-dockerd-${CRI_LATEST_VER}.amd64.tgz
tar xvf cri-dockerd-${CRI_LATEST_VER}.amd64.tgz
sudo mv cri-dockerd/cri-dockerd /usr/local/bin/
rm -rf cri-dockerd-${CRI_LATEST_VER}.amd64.tgz cri-dockerd
elif [ "${AWS_OS}" = "ubuntu" ]; then
sudo apt update
sudo apt install -y git wget curl
if [ $(dpkg --print-architecture) = "amd64" ]; then
wget https://github.com/Mirantis/cri-dockerd/releases/download/v${CRI_LATEST_VER}/cri-dockerd-${CRI_LATEST_VER}.amd64.tgz
tar xvf cri-dockerd-${CRI_LATEST_VER}.amd64.tgz
sudo mv cri-dockerd/cri-dockerd /usr/local/bin/
rm -rf cri-dockerd-${CRI_LATEST_VER}.amd64.tgz cri-dockerd
elif [ $(dpkg --print-architecture) = "arm64" ]; then
wget https://github.com/Mirantis/cri-dockerd/releases/download/v${CRI_LATEST_VER}/cri-dockerd-${CRI_LATEST_VER}.arm64.tgz
tar xvf cri-dockerd-${CRI_LATEST_VER}.arm64.tgz
sudo mv cri-dockerd/cri-dockerd /usr/local/bin/
rm -rf cri-dockerd-${CRI_LATEST_VER}.arm64.tgz cri-dockerd
else
echo "Unsupported architecture"
fi
else
echo "Unsupported OS"
fi
wget https://raw.githubusercontent.com/Mirantis/cri-dockerd/master/packaging/systemd/cri-docker.service
wget https://raw.githubusercontent.com/Mirantis/cri-dockerd/master/packaging/systemd/cri-docker.socket
sudo mv cri-docker.socket cri-docker.service /etc/systemd/system/
sudo sed -i -e 's,/usr/bin/cri-dockerd,/usr/local/bin/cri-dockerd,' /etc/systemd/system/cri-docker.service
sudo systemctl daemon-reload
sudo systemctl enable cri-docker.service
sudo systemctl enable --now cri-docker.socket
# wget https://storage.googleapis.com/golang/getgo/installer_linux
# chmod +x ./installer_linux
# ./installer_linux
# # source ~/.bash_profile
# sudo source root/.bash_profile
# git clone https://github.com/Mirantis/cri-dockerd.git
# cd cri-dockerd
# mkdir bin
# go build -o bin/cri-dockerd
# mkdir -p /usr/local/bin
# sudo install -o root -g root -m 0755 bin/cri-dockerd /usr/local/bin/cri-dockerd
# sudo cp -a packaging/systemd/* /etc/systemd/system
# sudo sed -i -e 's,/usr/bin/cri-dockerd,/usr/local/bin/cri-dockerd,' /etc/systemd/system/cri-docker.service
# sudo systemctl daemon-reload
# sudo systemctl enable cri-docker.service
# sudo systemctl enable --now cri-docker.socket
# sudo systemctl status cri-docker.socket | grep Active
[ ! -e ./cri-dockerd* ] || sudo rm -f -d ./cri-dockerd*
}
function install_kubectl() {
echo -e "${YELLOW}[+] Installing Kubectl...${NC}"
if [ "${AWS_OS}" = "amzn" ]; then
curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl"
sudo install -o root -g root -m 0755 kubectl /usr/local/bin/kubectl
elif [ "${AWS_OS}" = "ubuntu" ]; then
sudo apt-get update -y
sudo apt-get install -y apt-transport-https ca-certificates curl
sudo curl -fsSLo /usr/share/keyrings/kubernetes-archive-keyring.gpg https://packages.cloud.google.com/apt/doc/apt-key.gpg
echo "deb [signed-by=/usr/share/keyrings/kubernetes-archive-keyring.gpg] https://apt.kubernetes.io/ kubernetes-xenial main" | sudo tee /etc/apt/sources.list.d/kubernetes.list
curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl"
sudo apt-get update -y
sudo apt-get install -y kubectl
sudo install -o root -g root -m 0755 kubectl /usr/local/bin/kubectl
else
echo "Unsupported OS"
fi
}
function install_helm() {
echo -e "${YELLOW}[+] Installing Helm...${NC}"
curl -fsSL -o get_helm.sh https://raw.githubusercontent.com/helm/helm/main/scripts/get-helm-3
chmod 700 get_helm.sh
./get_helm.sh && rm -f get_helm.sh
[ ! -e ./helm* ] || sudo rm -f -d ./helm*
}
function install_terraform() {
echo -e "${YELLOW}[+] Installing Terraform...${NC}"
if [ "${AWS_OS}" = "amzn" ]; then
sudo yum install -y unzip
elif [ "${AWS_OS}" = "ubuntu" ]; then
sudo apt-get install -y unzip
fi
wget https://releases.hashicorp.com/terraform/${TERRAFORM_VERSION}/terraform_${TERRAFORM_VERSION}_linux_amd64.zip
unzip terraform_${TERRAFORM_VERSION}_linux_amd64.zip
sudo mv terraform /usr/local/bin/
rm terraform_${TERRAFORM_VERSION}_linux_amd64.zip
}
function install_packer() {
echo -e "${YELLOW}[+] Installing Packer...${NC}"
if [ "${AWS_OS}" = "amzn" ]; then
sudo yum install -y unzip
elif [ "${AWS_OS}" = "ubuntu" ]; then
sudo apt-get install -y unzip
fi
wget https://releases.hashicorp.com/packer/${PACKER_VERSION}/packer_${PACKER_VERSION}_linux_amd64.zip
unzip packer_${PACKER_VERSION}_linux_amd64.zip
sudo mv packer /usr/local/bin/
rm packer_${PACKER_VERSION}_linux_amd64.zip
}
function install_kind() {
echo -e "${YELLOW}[+] Installing Kind...${NC}"
curl -Lo ./kind https://kind.sigs.k8s.io/dl/v${KIND_VERSION}/kind-linux-amd64
chmod +x ./kind
sudo mv ./kind /usr/local/bin/
}
function install_kubectx() {
echo -e "${YELLOW}[+] Installing Kubectx...${NC}"
curl -Lo ./kubectx https://raw.githubusercontent.com/ahmetb/kubectx/master/kubectx
chmod +x ./kubectx
sudo mv ./kubectx /usr/local/bin/
}
function install_kubens() {
echo -e "${YELLOW}[+] Installing Kubens...${NC}"
curl -Lo ./kubens https://raw.githubusercontent.com/ahmetb/kubectx/master/kubens
chmod +x ./kubens
sudo mv ./kubens /usr/local/bin/
}
function install_minikube() {
echo -e "${YELLOW}[+] Installing Minikube...${NC}"
if [ "${AWS_OS}" = "amzn" ]; then
sudo yum install -y conntrack
curl -LO https://storage.googleapis.com/minikube/releases/latest/minikube-linux-amd64
sudo install minikube-linux-amd64 /usr/local/bin/minikube
rm -f minikube-linux-amd64
elif [ "${AWS_OS}" = "ubuntu" ]; then
sudo apt-get install -y conntrack
sudo curl -LO https://storage.googleapis.com/minikube/releases/latest/minikube_latest_amd64.deb
sudo dpkg -i minikube_latest_amd64.deb
rm -f minikube_latest_amd64.deb
fi
}
function install_crictl() {
echo -e "${YELLOW}[+] Installing Crictl...${NC}"
wget https://github.com/kubernetes-sigs/cri-tools/releases/download/$CRICTL_VERSION/crictl-$CRICTL_VERSION-linux-amd64.tar.gz
sudo tar zxvf crictl-$CRICTL_VERSION-linux-amd64.tar.gz -C /usr/local/bin
rm -f crictl-$CRICTL_VERSION-linux-amd64.tar.gz
}
function install_vagrant() {
echo -e "${YELLOW}[+] Installing Vagrant...${NC}"
if [ "${AWS_OS}" = "amzn" ]; then
sudo yum install -y yum-utils
## Add HashiCorp repository
sudo yum-config-manager --add-repo https://rpm.releases.hashicorp.com/AmazonLinux/hashicorp.repo
## Install HashiCorp vagrant
sudo yum -y install vagrant
elif [ "${AWS_OS}" = "ubuntu" ]; then
sudo apt-get install -y virtualbox
wget https://releases.hashicorp.com/vagrant/${VAGRANT_VERSION}/vagrant_${VAGRANT_VERSION}_x86_64.deb
sudo dpkg -i vagrant_${VAGRANT_VERSION}_x86_64.deb
rm vagrant_${VAGRANT_VERSION}_x86_64.deb
fi
}
function install_td-agent() {
echo -e "${YELLOW}[+] Installing td-agent...${NC}"
if [ "${AWS_OS}" = "amzn" ]; then
curl -L https://toolbelt.treasuredata.com/sh/install-amazon2-td-agent4.sh | sh
elif [ "${AWS_OS}" = "ubuntu" ]; then
sudo apt-get install -y td-agent
wget http://archive.ubuntu.com/ubuntu/pool/main/o/openssl/libssl1.1_1.1.1f-1ubuntu2.16_amd64.deb
sudo dpkg -i libssl1.1_1.1.1f-1ubuntu2.16_amd64.deb
sudo curl -fsSL https://toolbelt.treasuredata.com/sh/install-ubuntu-focal-td-agent4.sh | sh
sudo apt --fix-broken install
sudo apt upgrade -y
sudo systemctl start td-agent.service
[ ! -e ./libssl1.1_1.1.1f-1ubuntu2.16_amd64.deb ] || rm -f ./libssl1.1_1.1.1f-1ubuntu2.16_amd64.deb
[ ! -e ./td-agent-* ] || rm -f ./td-agent-*
fi
}
function install_crane() {
echo -e "${YELLOW}[+] Installing Crane...${NC}"
wget https://github.com/tsuru/crane/releases/download/1.0.0/crane-1.0.0-linux_amd64.tar.gz
tar -xvzf crane-1.0.0-linux_amd64.tar.gz
sudo mv crane /usr/local/bin/
rm crane-1.0.0-linux_amd64.tar.gz
}
function install_argocd() {
echo -e "${YELLOW}[+] Installing ArgoCD...${NC}"
wget https://github.com/argoproj/argo-cd/releases/download/v2.2.5/argocd-linux-amd64 -O argocd
chmod +x argocd
sudo mv argocd /usr/local/bin/
}