From 5f9f01669bdb81c60019a9fa80c11eae1924c14c Mon Sep 17 00:00:00 2001 From: tangxiaoqing Date: Wed, 5 Dec 2018 18:27:50 +0800 Subject: [PATCH] Fix building Docker image error (#390) --- build.sh | 17 +++++++++++++++++ docker/Dockerfile | 35 ++++++++++++++++++++++------------- env.sh | 17 ----------------- 3 files changed, 39 insertions(+), 30 deletions(-) diff --git a/build.sh b/build.sh index 1c1a168be3b8ad..502f84b5952e5e 100755 --- a/build.sh +++ b/build.sh @@ -47,6 +47,23 @@ if [[ -z ${JAVA_HOME} ]]; then export JAVA_HOME=${DORIS_THIRDPARTY}/installed/jdk1.8.0_131 fi +# check java version +if [[ ! -z ${JAVA_HOME} ]]; then + export JAVA=${JAVA_HOME}/bin/java + JAVA_VER=$(${JAVA} -version 2>&1 | sed 's/.* version "\(.*\)\.\(.*\)\..*"/\1\2/; 1q' | cut -f1 -d " ") + if [[ $JAVA_VER -lt 18 ]]; then + echo "Error: require JAVA with JDK version at least 1.8" + return 1 + fi +fi + +# check maven +export MVN=mvn +if ! ${MVN} --version; then + echo "Error: mvn is not found" + exit 1 +fi + PARALLEL=$[$(nproc)/4+1] # Check args diff --git a/docker/Dockerfile b/docker/Dockerfile index 100ebece0e9ca1..7c28aee1802515 100644 --- a/docker/Dockerfile +++ b/docker/Dockerfile @@ -22,13 +22,13 @@ MAINTAINER tangxiaoqing214445 ENV DEFAULT_DIR /var/local # change .bashrc -RUN echo -e "if [ ! -d "/var/local/incubator-doris/thirdparty/installed" ]; then\n\tmkdir /var/local/incubator-doris/thirdparty/installed\n\tcp -rf /var/local/thirdparty/installed/* /var/local/incubator-doris/thirdparty/installed/\nfi" >> /root/.bashrc +RUN echo -e "if [ ! -d "/var/local/incubator-doris/thirdparty/installed" ]; then\n\tmkdir /var/local/incubator-doris/thirdparty/installed\n\tcp -rf /var/local/thirdparty/installed/* /var/local/incubator-doris/thirdparty/installed/\n\texport JAVA_HOME=/var/local/incubator-doris/thirdparty/installed/jdk1.8.0_131\n\tln -s /var/local/incubator-doris/thirdparty/installed/bin/thrift /usr/bin/thrift\n\tln -s /var/local/incubator-doris/thirdparty/installed/jdk1.8.0_131/bin/java /usr/bin/java \nfi" >> /root/.bashrc ARG GCC_VERSION=7.3.0 ARG GCC_URL=https://mirrors.ustc.edu.cn/gnu/gcc/gcc-${GCC_VERSION} # install dependencies and build gcc -RUN yum install -y bzip2 wget gcc-c++ libstdc++-static cmake byacc flex automake libtool binutils-devel bison ncurses-devel make mlocate unzip patch which vim-common redhat-lsb-core zip \ +RUN yum install -y bzip2 wget gcc-c++ libstdc++-static byacc flex automake libtool binutils-devel bison ncurses-devel make mlocate unzip patch which vim-common redhat-lsb-core zip \ && updatedb \ && mkdir -p /var/local/gcc \ && curl -fsSL -o /tmp/gcc.tar.gz ${GCC_URL}/gcc-${GCC_VERSION}.tar.gz \ @@ -37,9 +37,21 @@ RUN yum install -y bzip2 wget gcc-c++ libstdc++-static cmake byacc flex automake && sed -i 's/ftp:\/\/gcc.gnu.org\/pub\/gcc\/infrastructure\//http:\/\/mirror.linux-ia64.org\/gnu\/gcc\/infrastructure\//g' contrib/download_prerequisites \ && ./contrib/download_prerequisites \ && ./configure --disable-multilib --enable-languages=c,c++ --prefix=/usr \ - && make -j 4 && make install \ + && make -j$[$(nproc)/4+1] && make install \ && rm -rf /var/local/gcc \ && rm -f /tmp/gcc.tar.gz + +# build cmake +ARG CMAKE_VERSION=3.12.3 +ARG CMAKE_DOWNLOAD_URL=https://cmake.org/files/v3.12/cmake-${CMAKE_VERSION}.tar.gz +RUN mkdir -p /tmp/cmake && curl -fsSL -o /tmp/cmake.tar.gz ${CMAKE_DOWNLOAD_URL} \ + && tar -zxf /tmp/cmake.tar.gz -C /tmp/cmake --strip-components=1 \ + && cd /tmp/cmake \ + && ./bootstrap --prefix=/usr/local \ + && make -j$[$(nproc)/4+1] \ + && make install \ + && rm -rf /tmp/cmake.tar.gz \ + && rm -rf /tmp/cmake # install maven 3.6.0 ARG MAVEN_VERSION=3.6.0 @@ -64,19 +76,16 @@ ARG DORIS_THRIDPARTY_URL=http://doris-opensource.bj.bcebos.com/doris-thirdparty- # clone source code and build third party RUN yum install -y git \ && git clone https://github.com/apache/incubator-doris.git \ - && mkdir -p ${DEFAULT_DIR}/thirdparty/src ${DEFAULT_DIR}/doris-thirdparty \ - && cp -rf ${DEFAULT_DIR}/incubator-doris/thirdparty/* ${DEFAULT_DIR}/thirdparty/ \ + && mkdir -p ${DEFAULT_DIR}/incubator-doris/thirdparty/src ${DEFAULT_DIR}/doris-thirdparty \ && curl -fsSL -o ${DEFAULT_DIR}/doris-thirdparty.tar.gz ${DORIS_THRIDPARTY_URL} \ && tar -zxf ${DEFAULT_DIR}/doris-thirdparty.tar.gz -C ${DEFAULT_DIR}/doris-thirdparty --strip-components=1 \ - && mv ${DEFAULT_DIR}/doris-thirdparty/* ${DEFAULT_DIR}/thirdparty/src/ \ - && /bin/bash thirdparty/build-thirdparty.sh \ - && ln -s ${DEFAULT_DIR}/thirdparty/installed/bin/thrift /usr/bin/thrift \ - && ln -s ${DEFAULT_DIR}/thirdparty/installed/jdk1.8.0_131/bin/java /usr/bin/java \ - && rm -rf ${DEFAULT_DIR}/thirdparty/src \ + && mv ${DEFAULT_DIR}/doris-thirdparty/* ${DEFAULT_DIR}/incubator-doris/thirdparty/src/ \ + && cd ${DEFAULT_DIR}/incubator-doris && /bin/bash thirdparty/build-thirdparty.sh \ + && rm -rf ${DEFAULT_DIR}/incubator-doris/thirdparty/src \ && rm -rf ${DEFAULT_DIR}/doris-thirdparty.tar.gz \ - && rm -rf ${DEFAULT_DIR}/doris-thirdparty - -ENV JAVA_HOME ${DEFAULT_DIR}/thirdparty/installed/jdk1.8.0_131 + && rm -rf ${DEFAULT_DIR}/doris-thirdparty \ + && mkdir -p ${DEFAULT_DIR}/thirdparty \ + && mv ${DEFAULT_DIR}/incubator-doris/thirdparty/installed ${DEFAULT_DIR}/thirdparty/ WORKDIR ${DEFAULT_DIR}/incubator-doris diff --git a/env.sh b/env.sh index 060a1071a5d9a6..ba4cc7ae87a19d 100755 --- a/env.sh +++ b/env.sh @@ -31,23 +31,6 @@ if [[ -z ${DORIS_THIRDPARTY} ]]; then export DORIS_THIRDPARTY=${DORIS_HOME}/thirdparty fi -# check java version -if [[ ! -z ${JAVA_HOME} ]]; then - export JAVA=${JAVA_HOME}/bin/java - JAVA_VER=$(${JAVA} -version 2>&1 | sed 's/.* version "\(.*\)\.\(.*\)\..*"/\1\2/; 1q' | cut -f1 -d " ") - if [[ $JAVA_VER -lt 18 ]]; then - echo "Error: require JAVA with JDK version at least 1.8" - return 1 - fi -fi - -# check maven -export MVN=mvn -if ! ${MVN} --version; then - echo "Error: mvn is not found" - exit 1 -fi - # check python export PYTHON=python if ! ${PYTHON} --version; then