docker/server/server.dockerfile
changeset 130 5eeebcbdee22
parent 129 f6b392c37e10
--- a/docker/server/server.dockerfile	Tue Jul 23 23:18:21 2024 +0200
+++ b/docker/server/server.dockerfile	Sat Jul 27 00:57:57 2024 +0200
@@ -14,6 +14,11 @@
 
 # copy the dependencies file to the working directory
 COPY docker/server/requirements.txt .
+COPY docker/server/ivysettings.xml .
+COPY virtualenv/res/src/django-extensions-0.8.tar.gz .
+COPY virtualenv/res/src/django-piston-7c90898072ce-modifed.tar.gz .
+COPY virtualenv/res/src/omab-django-social-auth-v0.3.10-modified.tar.gz .
+COPY virtualenv/res/src/Django-1.4.tar.gz .
 
 ENV JCC_JDK=/usr/lib/jvm/java-11-openjdk
 ENV JCC_LFLAGS="-L/usr/lib/jvm/java-11-openjdk/jre/lib -ljava -L/usr/lib/jvm/java-11-openjdk/jre/lib/server -ljvm"
@@ -24,37 +29,50 @@
 
 RUN \
  apk add --no-cache postgresql-client postgresql-libs libxml2 libxslt libmemcached openjdk11 apache-ant bash jpeg-dev zlib-dev freetype-dev lcms2-dev openjpeg-dev tiff-dev tk-dev tcl-dev && \
- apk add --no-cache --virtual .build-deps build-base postgresql-dev libxml2-dev libxslt-dev linux-headers sed wget patchelf git jpeg-dev zlib-dev freetype-dev lcms2-dev openjpeg-dev tiff-dev tk-dev tcl-dev && \
- wget https://dlcdn.apache.org/lucene/pylucene/pylucene-7.7.1-src.tar.gz && \
- tar zxvf pylucene-7.7.1-src.tar.gz && \
- cd pylucene-7.7.1 && \
- cd jcc && \
- python setup.py install && \
- cd .. && \
- sed -i '1s/^/PREFIX_PYTHON=\/opt\/venv\nANT=JAVA_HOME=\/usr\/lib\/jvm\/java-11-openjdk \/usr\/bin\/ant\nPYTHON=$(PREFIX_PYTHON)\/bin\/python\nJCC=$(PYTHON) -m jcc --shared\nNUM_FILES=8\n/' Makefile && \
- sed -i 's/http:\/\/repo1\.maven\.org\/maven2/https:\/\/repo1.maven.org\/maven2/' lucene-java-7.7.1/lucene/common-build.xml && \
- patchelf --add-needed libjvm.so /opt/venv/lib/python2.7/site-packages/JCC-3.5-py2.7-linux-x86_64.egg/jcc/_jcc2.so && \
- patchelf --add-needed libjvm.so /opt/venv/lib/python2.7/site-packages/JCC-3.5-py2.7-linux-x86_64.egg/libjcc2.so && \
+ apk add --no-cache --virtual .build-deps build-base postgresql-dev libxml2-dev libxslt-dev linux-headers sed wget patchelf git jpeg-dev zlib-dev freetype-dev lcms2-dev openjpeg-dev tiff-dev tk-dev tcl-dev tar && \
+ wget https://archive.apache.org/dist/lucene/pylucene/pylucene-3.6.2-1-src.tar.gz && \
+ tar zxvf pylucene-3.6.2-1-src.tar.gz && \
+ cd pylucene-3.6.2-1 && \
+ pip install jcc && \
+ #cd jcc && \
+ #python setup.py install && \
+ #cd .. && \
+ sed -i '1s/^/PREFIX_PYTHON=\/opt\/venv\nANT=JAVA_HOME=\/usr\/lib\/jvm\/java-11-openjdk \/usr\/bin\/ant\nPYTHON=$(PREFIX_PYTHON)\/bin\/python\nJCC=$(PYTHON) -m jcc --shared --package java.util.function\nNUM_FILES=8\n/' Makefile && \
+ sed -i 's/http:\/\/repo1\.maven\.org\/maven2/https:\/\/repo1.maven.org\/maven2/' lucene-java-3.6.2/lucene/common-build.xml && \
+ sed -i 's/<property name="javac\.source" value="1\.5"\/>/<property name="javac\.source" value="1.6"\/>/' lucene-java-3.6.2/lucene/common-build.xml && \
+ sed -i 's/<property name="javac\.target" value="1\.5"\/>/<property name="javac\.target" value="1.6"\/>/' lucene-java-3.6.2/lucene/common-build.xml && \
+ sed -i 's/<property name="javac\.source\.backwards" value="1\.5"\/>/<property name="javac.source.backwards" value="1.6"\/>/' lucene-java-3.6.2/lucene/common-build.xml && \
+ sed -i 's/<property name="javac\.target\.backwards" value="1\.5"\/>/<property name="javac.target.backwards" value="1.6"\/>/' lucene-java-3.6.2/lucene/common-build.xml && \
+ make ivy && \
+ sed -i 's/^<\/project>/  <ivy:settings file="\/code\/ivysettings.xml"\/>\n<\/project>/' lucene-java-3.6.2/lucene/common-build.xml && \
+ patchelf --add-needed libjvm.so /opt/venv/lib/python2.7/site-packages/jcc/_jcc2.so && \
+ patchelf --add-needed libjvm.so /opt/venv/lib/python2.7/site-packages/libjcc2.so && \
  make && \
  make install && \
  cd /code && \
  wget https://hg.dev.iri-research.org/platform/archive/V01.11.tar.gz && \
  tar zxvf V01.11.tar.gz && \
- cd platform-V01.11/src/ldt && \
- python setup.py sdist && \
- pip install dist/ldt-1.11.tar.gz && \
- cd /code && \
- pip install -r requirements.txt
+ #cd platform-V01.11/src/ldt && \
+ #python setup.py sdist && \
+ #pip install dist/ldt-1.11.tar.gz && \
+ #cd /code && \
+ tar zxvf Django-1.4.tar.gz --strip-components=1 Django-1.4/django && \
+ tar zxvf django-extensions-0.8.tar.gz --strip-components=1 django-extensions-django-extensions-0f498ff/django_extensions && \
+ tar zxvf django-piston-7c90898072ce-modifed.tar.gz --strip-components=1 jespern-django-piston-7c90898072ce/piston && \
+ tar zxvf omab-django-social-auth-v0.3.10-modified.tar.gz --strip-components=1 omab-django-social-auth-db55201/social_auth && \
+ pip install -r requirements.txt && \
+ echo "DONE"
 
-
-FROM docker.io/python:2.7-alpine 
+FROM docker.io/python:2.7-alpine as run_base
 
 COPY --from=builder /opt/venv /opt/venv
-COPY web/tralalere /code/tralalere
+COPY --from=builder /code/django /code/django
+COPY --from=builder /code/social_auth /code/social_auth
+COPY --from=builder /code/platform-V01.11/src/ldt/ldt /code/ldt
+COPY --from=builder /code/piston /code/piston
+COPY --from=builder /code/django_extensions /code/django_extensions
 COPY web/manage.py /code/
 
-
-
 ENV BASEDIR="/code"
 ENV PATH="/opt/venv/bin:$BASEDIR:$PATH"
 
@@ -79,6 +97,10 @@
 ENV PATH="/usr/lib/jvm/java-11-openjdk/jre/bin:$PATH"
 ENV LD_LIBRARY_PATH="/usr/lib/jvm/java-11-openjdk/jre/lib:/usr/lib/jvm/java-11-openjdk/jre/lib/server"
 
+FROM run_base as prod
+
+COPY web/tralalere /code/tralalere
+
 EXPOSE 8000
 
 ENTRYPOINT ["/entrypoint.sh"]