forked from qubole/rubix
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Dockerfile
109 lines (86 loc) · 2.98 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
FROM maven:3.6.3-jdk-8-slim
MAINTAINER Kamesh Vankayala - Qubole Inc.
#####
# Ant (Needed to build libthrift jar)
#####
# Preparation
ENV ANT_VERSION 1.9.14
ENV ANT_HOME /etc/ant-${ANT_VERSION}
# Installation
RUN cd /tmp
RUN curl -sSL http://www.us.apache.org/dist/ant/binaries/apache-ant-${ANT_VERSION}-bin.tar.gz -o apache-ant-${ANT_VERSION}-bin.tar.gz
RUN mkdir ant-${ANT_VERSION}
RUN tar -zxvf apache-ant-${ANT_VERSION}-bin.tar.gz --directory ant-${ANT_VERSION} --strip-components=1
RUN mv ant-${ANT_VERSION} ${ANT_HOME}
ENV PATH ${PATH}:${ANT_HOME}/bin
# Cleanup
RUN rm apache-ant-${ANT_VERSION}-bin.tar.gz
RUN unset ANT_VERSION
# Testing
RUN java -version
RUN javac -version
RUN mvn -version
RUN ant -version
## Install thrift 0.9.3
ENV THRIFT_VERSION 0.9.3
RUN buildDeps=" \
automake \
bison \
curl \
flex \
g++ \
libboost-dev \
libboost-filesystem-dev \
libboost-program-options-dev \
libboost-system-dev \
libboost-test-dev \
libevent-dev \
libssl-dev \
libtool \
make \
pkg-config \
"; \
apt-get update && apt-get install -y --no-install-recommends $buildDeps && rm -rf /var/lib/apt/lists/* \
&& curl -sSL "http://apache.mirrors.spacedump.net/thrift/$THRIFT_VERSION/thrift-$THRIFT_VERSION.tar.gz" -o thrift.tar.gz \
&& mkdir -p /usr/src/thrift \
&& tar zxf thrift.tar.gz -C /usr/src/thrift --strip-components=1 \
&& rm thrift.tar.gz \
&& cd /usr/src/thrift \
&& ./configure --without-python --without-cpp \
&& make \
&& make install \
&& cd / \
&& rm -rf /usr/src/thrift \
&& curl -k -sSL "https://storage.googleapis.com/golang/go1.4.linux-amd64.tar.gz" -o go.tar.gz \
&& tar xzf go.tar.gz \
&& rm go.tar.gz \
&& cp go/bin/gofmt /usr/bin/gofmt \
&& rm -rf go \
&& apt-get purge -y --auto-remove $buildDeps
## Install git
RUN apt-get update && apt-get install -y git
# install dev tools
RUN apt-get update
RUN apt-get install -y curl tar sudo openssh-server openssh-client rsync
ENV HADOOP_VERSION 2.7.2
ENV HADOOP_URL https://archive.apache.org/dist/hadoop/core/hadoop-$HADOOP_VERSION/hadoop-$HADOOP_VERSION.tar.gz
RUN set -x \
&& curl -fSL "$HADOOP_URL" -o /tmp/hadoop.tar.gz \
&& tar -xvf /tmp/hadoop.tar.gz -C /usr/lib/ \
&& rm /tmp/hadoop.tar.gz*
ENV HADOOP_HOME /usr/lib/hadoop
RUN cd /usr/lib && mv hadoop-$HADOOP_VERSION hadoop2 && ln -s ./hadoop2 hadoop
ENV HADOOP_CLASSPATH=$HADOOP_CLASSPATH:/usr/lib/hadoop2/share/hadoop/tools/lib/*
ENV USER=root
ENV PATH $HADOOP_HOME/bin/:$PATH
# Install Docker and Docker Compose for integration tests
RUN set -x \
&& curl -fSL "https://download.docker.com/linux/static/stable/x86_64/docker-17.09.0-ce.tgz" -o /tmp/docker-ce.tgz \
&& tar -xvzf /tmp/docker-ce.tgz \
&& cp docker/* /usr/local/bin
RUN set -x \
&& curl -L "https://github.com/docker/compose/releases/download/1.24.0/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose \
&& chmod +x /usr/local/bin/docker-compose
RUN mkdir -p /media/ephemeral0
RUN apt-get install -yqq python
RUN apt-get -yqq install python-pip