-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDockerfile
118 lines (98 loc) · 4.05 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
ARG UBUNTU_VERSION=18.04
FROM ubuntu:${UBUNTU_VERSION}
# ================================================================================================
# Inspiration: Docker Framework (https://github.com/dockube/dockube)
# Dwi Fahni Denni <[email protected]>
# ================================================================================================
MAINTAINER "ZeroC0D3 Team <[email protected]>"
ENV DEBIAN_FRONTEND noninteractive
RUN apt-get update; sync
RUN apt-get -y -o Dpkg::Options::="--force-confdef" -o Dpkg::Options::="--force-confold" install \
build-essential \
ca-certificates \
gcc \
git \
bash \
curl \
wget \
software-properties-common \
openssh-server \
openssh-client \
zip \
unzip \
net-tools \
vim-tiny \
nano \
libpq-dev \
make \
python-pip \
python2.7 \
python2.7-dev \
ssh
COPY rootfs/ /
# ================================================================================================
# INSTALL SSH
# ================================================================================================
#-----------------------------------------------------------------------------
# Change 'root' Password
#-----------------------------------------------------------------------------
# RUN echo 'root:'${SSH_ROOT_PASSWORD} | chpasswd
RUN echo 'root:root' | chpasswd; sync
RUN sed -ri 's/^#?PermitRootLogin\s+.*/PermitRootLogin yes/' /etc/ssh/sshd_config
RUN sed -ri 's/UsePAM yes/#UsePAM yes/g' /etc/ssh/sshd_config
#-----------------------------------------------------------------------------
# Generate Public Key
#-----------------------------------------------------------------------------
# Create new public key
RUN /usr/bin/ssh-keygen -t rsa -b 4096 -C "[email protected]" -f $HOME/.ssh/id_rsa -q -N ""; sync
RUN mkdir -p $HOME/.ssh \
&& touch $HOME/.ssh/authorized_keys \
&& chmod 700 $HOME/.ssh \
&& chmod go-w $HOME $HOME/.ssh \
&& chmod 600 $HOME/.ssh/authorized_keys \
&& chown `whoami` $HOME/.ssh/authorized_keys \
&& cat $HOME/.ssh/id_rsa.pub > $HOME/.ssh/authorized_keys
# Create new pem file from public key
RUN /usr/bin/ssh-keygen -f $HOME/.ssh/id_rsa.pub -e -m pem > $HOME/.ssh/id_rsa.pem
# Create new public key for host
RUN /usr/bin/ssh-keygen -A; sync
COPY ./ssh-key/id_rsa.pub /tmp/ownkey.pub
RUN cat /tmp/ownkey.pub >> $HOME/.ssh/authorized_keys
CMD ["/usr/sbin/sshd", "-D"]
# ================================================================================================
# INSTALL ANSIBLE
# ================================================================================================
USER root
ARG INSTALL_ANSIBLE=false
RUN if [ "${INSTALL_ANSIBLE}" = true ]; then \
/bin/sh /opt/install_ansible.sh \
;fi
# ================================================================================================
# INSTALL GOLANG
# ================================================================================================
USER root
ARG INSTALL_GOLANG=false
RUN if [ "${INSTALL_GOLANG}" = true ]; then \
/bin/sh /opt/install_golang.sh \
;fi
ENV GOPATH=$HOME/go
ENV GOROOT=/usr/local/go
ENV PATH=$PATH:$GOROOT/bin:$GOPATH/bin
RUN mkdir -p "${GOPATH}/src" "${GOPATH}/bin" && chmod -R 777 "${GOPATH}"
# ================================================================================================
# INSTALL NFS (CLIENT)
# ================================================================================================
RUN apt-get -y -o Dpkg::Options::="--force-confdef" -o Dpkg::Options::="--force-confold" install \
mc \
nfs-common
RUN mkdir -p /data-node
# ================================================================================================
# CLEAN UP INSTALLATION
# ================================================================================================
RUN apt-get clean && \
rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
CMD ["/sbin/init"]
EXPOSE 22 22/tcp
EXPOSE 2379 2379/tcp
EXPOSE 6443 6443/tcp
EXPOSE 10251 10251/tcp