2017-01-30 1 views
0

컨테이너 내부에서 Grizzly HTTP 서버를 실행하려고합니다.저지 Grizzly HTTP 서버가 컨테이너 고정 장치 내부에서 종료되었습니다.

내 문제는 컨테이너를 실행 중일 때 (docker-compose 사용) 컨테이너가 몇 초 후에 종료된다는 것입니다. 여기

는 Dockerfile 내 서버 입니다 :

FROM alpine:3.5 

MAINTAINER Maybe One <[email protected]> 

# Java Version and other ENV 
ENV JAVA_VERSION_MAJOR=8 \ 
    JAVA_VERSION_MINOR=102 \ 
    JAVA_VERSION_BUILD=14 \ 
    JAVA_PACKAGE=jdk \ 
    JAVA_JCE=standard \ 
    JAVA_HOME=/opt/jdk \ 
    PATH=${PATH}:/opt/jdk/bin \ 
    GLIBC_VERSION=2.23-r3 \ 
    LANG=C.UTF-8 

RUN apk upgrade --update && \ 
    apk add --update libstdc++ curl ca-certificates bash && \ 
    for pkg in glibc-${GLIBC_VERSION} glibc-bin-${GLIBC_VERSION} glibc-i18n-${GLIBC_VERSION}; do curl -sSL https://github.com/andyshinn/alpine-pkg-glibc/releases/download/${GLIBC_VERSION}/${pkg}.apk -o /tmp/${pkg}.apk; done && \ 
    apk add --allow-untrusted /tmp/*.apk && \ 
    rm -v /tmp/*.apk && \ 
    (/usr/glibc-compat/bin/localedef --force --inputfile POSIX --charmap UTF-8 C.UTF-8 || true) && \ 
    echo "export LANG=C.UTF-8" > /etc/profile.d/locale.sh && \ 
    /usr/glibc-compat/sbin/ldconfig /lib /usr/glibc-compat/lib && \ 
    mkdir /opt && \ 
    curl -jksSLH "Cookie: oraclelicense=accept-securebackup-cookie" -o /tmp/java.tar.gz \ 
     http://download.oracle.com/otn-pub/java/jdk/${JAVA_VERSION_MAJOR}u${JAVA_VERSION_MINOR}-b${JAVA_VERSION_BUILD}/${JAVA_PACKAGE}-${JAVA_VERSION_MAJOR}u${JAVA_VERSION_MINOR}-linux-x64.tar.gz && \ 
    gunzip /tmp/java.tar.gz && \ 
    tar -C /opt -xf /tmp/java.tar && \ 
    ln -s /opt/jdk1.${JAVA_VERSION_MAJOR}.0_${JAVA_VERSION_MINOR} /opt/jdk && \ 
    if [ "${JAVA_JCE}" == "unlimited" ]; then echo "Installing Unlimited JCE policy" >&2 && \ 
     curl -jksSLH "Cookie: oraclelicense=accept-securebackup-cookie" -o /tmp/jce_policy-${JAVA_VERSION_MAJOR}.zip \ 
     http://download.oracle.com/otn-pub/java/jce/${JAVA_VERSION_MAJOR}/jce_policy-${JAVA_VERSION_MAJOR}.zip && \ 
     cd /tmp && unzip /tmp/jce_policy-${JAVA_VERSION_MAJOR}.zip && \ 
     cp -v /tmp/UnlimitedJCEPolicyJDK8/*.jar /opt/jdk/jre/lib/security; \ 
    fi && \ 
    sed -i s/#networkaddress.cache.ttl=-1/networkaddress.cache.ttl=30/ $JAVA_HOME/jre/lib/security/java.security && \ 
    apk del curl glibc-i18n && \ 
    rm -rf /opt/jdk/*src.zip \ 
      /opt/jdk/lib/missioncontrol \ 
      /opt/jdk/lib/visualvm \ 
      /opt/jdk/lib/*javafx* \ 
      /opt/jdk/jre/plugin \ 
      /opt/jdk/jre/bin/javaws \ 
      /opt/jdk/jre/bin/jjs \ 
      /opt/jdk/jre/bin/orbd \ 
      /opt/jdk/jre/bin/pack200 \ 
      /opt/jdk/jre/bin/policytool \ 
      /opt/jdk/jre/bin/rmid \ 
      /opt/jdk/jre/bin/rmiregistry \ 
      /opt/jdk/jre/bin/servertool \ 
      /opt/jdk/jre/bin/tnameserv \ 
      /opt/jdk/jre/bin/unpack200 \ 
      /opt/jdk/jre/lib/javaws.jar \ 
      /opt/jdk/jre/lib/deploy* \ 
      /opt/jdk/jre/lib/desktop \ 
      /opt/jdk/jre/lib/*javafx* \ 
      /opt/jdk/jre/lib/*jfx* \ 
      /opt/jdk/jre/lib/amd64/libdecora_sse.so \ 
      /opt/jdk/jre/lib/amd64/libprism_*.so \ 
      /opt/jdk/jre/lib/amd64/libfxplugins.so \ 
      /opt/jdk/jre/lib/amd64/libglass.so \ 
      /opt/jdk/jre/lib/amd64/libgstreamer-lite.so \ 
      /opt/jdk/jre/lib/amd64/libjavafx*.so \ 
      /opt/jdk/jre/lib/amd64/libjfx*.so \ 
      /opt/jdk/jre/lib/ext/jfxrt.jar \ 
      /opt/jdk/jre/lib/ext/nashorn.jar \ 
      /opt/jdk/jre/lib/oblique-fonts \ 
      /opt/jdk/jre/lib/plugin.jar \ 
      /tmp/* /var/cache/apk/* 

# Maven 
ENV MAVEN_VERSION 3.3.9 
ENV MAVEN_HOME /usr/lib/mvn 
ENV PATH $MAVEN_HOME/bin:$PATH 

RUN wget http://ftp.fau.de/apache/maven/maven-3/$MAVEN_VERSION/binaries/apache-maven-$MAVEN_VERSION-bin.tar.gz && \ 
    tar -zxvf apache-maven-$MAVEN_VERSION-bin.tar.gz && \ 
    rm apache-maven-$MAVEN_VERSION-bin.tar.gz && \ 
    mv apache-maven-$MAVEN_VERSION /usr/lib/mvn 

# Workspace 
ENV WORKSPACE /home/app/ 

RUN mkdir -p $WORKSPACE 
WORKDIR $WORKSPACE 

COPY . $WORKSPACE    # Copy Server Project 
RUN mvn clean install -DskipTests 

ENTRYPOINT mvn exec:java 

고정 표시기 - compose.yml

version: '2.1' 
services: 
    server: 
    build: ./server/ 
    ports: 
     - "8080:8080" 

서버 고정 표시기 로그 :

... maven... 
[INFO] --- exec-maven-plugin:1.2.1:java (default-cli) @ restful.littleapp --- 
Jan 30, 2017 2:10:18 PM org.glassfish.grizzly.http.server.NetworkListener start 
INFO: Started listener bound to [0.0.0.0:8080] 
Jan 30, 2017 2:10:18 PM org.glassfish.grizzly.http.server.HttpServer start 
INFO: [HttpServer] Started. 
Jersey app started with WADL available at http://0.0.0.0:8080/littleapp/application.wadl 
Hit enter to stop it... 
[INFO] ------------------------------------------------------------------------ 
[INFO] BUILD SUCCESS 
[INFO] ------------------------------------------------------------------------ 
[INFO] Total time: 5.507 s 
[INFO] Finished at: 2017-01-30T14:10:18+00:00 
Jan 30, 2017 2:10:18 PM org.glassfish.grizzly.http.server.NetworkListener shutdownNow 
INFO: Stopped listener bound to [0.0.0.0:8080] 
[INFO] Final Memory: 37M/90M 
[INFO] ------------------------------------------------------------------------ 

일반적으로 서버는 청취해야합니다 ...

+0

나는 Maven에 익숙하지 않지만 내 생각에'mvn exec : java'는 서버를 시작하지만 포크를 뽑는다. 그리고 호출 한'mvn' 명령이 종료됩니다. 이 경우 초기 프로세스가 종료되면 컨테이너의 모든 항목도 종료되기 때문에 사물이 종료됩니다. 'ENTRYPOINT'를 조정하여 다른 것을 실행해야 할 수도 있습니다. 실행 중이거나 fork/exit하지 않을 것입니다. –

답변

관련 문제