Dockerfile 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. FROM debian:trixie-slim
  2. # Métadonnées
  3. LABEL maintainer="jmbatto"
  4. LABEL description="Julia 1.10 (Compilé Source) sur Debian Trixie avec PDI/GTK"
  5. # Arguments utilisateur (Conservés comme demandé)
  6. ARG USER_ID=1001
  7. ARG GROUP_ID=1001
  8. ARG USER_NAME=coder
  9. # -----------------------------------------------------------------------------
  10. # 1. Installation des dépendances système (Runtime)
  11. # On installe tout ce qu'il faut pour GTK4, PDI et le dev C
  12. # -----------------------------------------------------------------------------
  13. RUN apt-get update && apt-get install -y --no-install-recommends \
  14. # Outils de base et compilation C/PDI
  15. build-essential cmake git pkg-config \
  16. gfortran \
  17. which \
  18. perl \
  19. gawk \
  20. m4 \
  21. libatomic1 \
  22. nano sudo lsof gawk emacs jq neowofetch curl wget \
  23. gdb valgrind clang-format \
  24. ca-certificates iputils-ping \
  25. xauth \
  26. iputils-ping \
  27. pkg-config \
  28. colordiff \
  29. mpi-default-dev \
  30. # Libs scientifiques PDI
  31. libhdf5-dev libz-dev \
  32. # X11 & Xvfb (Pour ProfileView headless)
  33. libx11-6 libxext6 libxrender1 libxtst6 xauth xvfb \
  34. # OpenGL Logiciel (Indispensable pour GTK4 dans Docker)
  35. libgl1-mesa-dri libgl1 \
  36. # Dépendances GTK4 / Cairo / GDK complètes
  37. libgtk-4-1 libgtk-3-0 \
  38. libglib2.0-0 libcairo2 \
  39. libpango-1.0-0 libharfbuzz0b \
  40. libgdk-pixbuf-2.0-0 libgdk-pixbuf2.0-bin \
  41. libgraphene-1.0-0 librsvg2-common \
  42. shared-mime-info \
  43. adwaita-icon-theme-full hicolor-icon-theme fonts-liberation \
  44. graphviz \
  45. patchelf \
  46. && rm -rf /var/lib/apt/lists/*
  47. # Fix GDK Pixbuf (Cache des loaders pour éviter les erreurs au runtime)
  48. RUN LOADER_PATH=$(find /usr/lib -name gdk-pixbuf-query-loaders | head -n 1) && \
  49. ln -s $LOADER_PATH /usr/bin/gdk-pixbuf-query-loaders && \
  50. gdk-pixbuf-query-loaders --update-cache
  51. # Version cible
  52. # ARG JULIA_VERSION=v1.10.10
  53. ARG JULIA_VERSION=v1.12.4
  54. WORKDIR /tmp/julia-build
  55. # On utilise --depth 1 pour accélérer le téléchargement (évite le timeout)
  56. RUN git clone --depth 1 --branch ${JULIA_VERSION} https://github.com/JuliaLang/julia.git .
  57. RUN echo "prefix=/usr/local/julia" > Make.user && \
  58. echo "MARCH=x86-64" >> Make.user && \
  59. echo "USE_SYSTEM_LIBUNWIND=0" >> Make.user && \
  60. # echo "USE_BINARYBUILDER=0" >> Make.user && \
  61. echo "LDFLAGS=-Wl,-z,noexecstack" >> Make.user && \
  62. echo "CFLAGS=-Wa,--noexecstack -gdwarf-4" >> Make.user && \
  63. echo "CXXFLAGS=-Wa,--noexecstack -gdwarf-4" >> Make.user
  64. # -----------------------------------------------------------------------------
  65. # 2. COMPILATION DE JULIA
  66. # -----------------------------------------------------------------------------
  67. # Mise à jour du PATH
  68. ENV JULIA_PATH=/usr/local/julia
  69. ENV PATH=$JULIA_PATH/bin:$PATH
  70. # Compilation
  71. RUN make -j$(nproc) && \
  72. make install
  73. # -----------------------------------------------------------------------------
  74. # 3. Installation de PDI (Build from source)
  75. # Configuration PDI
  76. # -----------------------------------------------------------------------------
  77. ENV PDI_DIR=/usr/local
  78. ENV LD_LIBRARY_PATH=/usr/local/lib:/usr/lib/x86_64-linux-gnu
  79. ENV CPATH=/usr/local/include
  80. ENV PREFIX=/usr/local
  81. WORKDIR /tmp/pdi-build
  82. RUN git clone --depth 1 https://github.com/pdidev/pdi.git . && \
  83. mkdir build && cd build && \
  84. cmake \
  85. -DBUILD_MPI=OFF \
  86. -DBUILD_DECL_HDF5_PLUGIN=ON \
  87. -DBUILD_SHARED_LIBS=ON \
  88. -DBUILD_FORTRAN=OFF \
  89. -DBUILD_HDF5_PARALLEL=OFF \
  90. -DBUILD_NETCDF_PARALLEL=OFF \
  91. -DCMAKE_INSTALL_PREFIX=/usr/local \
  92. .. && \
  93. make -j$(nproc) && \
  94. make install && \
  95. ldconfig && \
  96. cd / && rm -rf /tmp/pdi-build
  97. # -----------------------------------------------------------------------------
  98. # 4. Pré-installation des paquets Julia
  99. # On utilise xvfb-run pour que ProfileView/Gtk puissent se précompiler sans écran physique.
  100. # -----------------------------------------------------------------------------
  101. #RUN echo "Application du patch 'clear-execstack' sur les librairies Julia..." && \
  102. # find $JULIA_PATH -name "libopenlibm.so" -exec patchelf --clear-execstack {} \; && \
  103. # # On applique aussi sur libjulia-internal par sécurité
  104. # find $JULIA_PATH -name "libjulia-internal.so*" -exec patchelf --clear-execstack {} \; && \
  105. # find $JULIA_PATH -type f -name "*.so*" -exec patchelf --clear-execstack {} \;
  106. ENV GKSwstype=100
  107. ENV JULIA_PKG_PRECOMPILE_AUTO=0
  108. ENV JULIA_PKG_USE_CLI_GIT=true
  109. # RUN julia -e 'import Pkg; \
  110. # Pkg.add([ \
  111. # "HDF5"])'
  112. # RUN xvfb-run --auto-servernum --server-args="-screen 0 1920x1080x24 -nolisten tcp" \
  113. # julia -e 'import Pkg; \
  114. # Pkg.add([ \
  115. # "Plots", \
  116. # "DataFrames", \
  117. # "Gtk4", \
  118. # "Gtk", \
  119. # "ProfileView", \
  120. # "PProf", \
  121. # "Reexport" \
  122. # ])'
  123. # ÉTAPE B : ACTION CORRECTIVE CRITIQUE
  124. # Pkg.add a téléchargé des artifacts (.so) qui violent la sécurité execstack.
  125. # On doit les patcher AVANT que Julia ne tente de les charger pour la précompilation.
  126. #RUN echo "Patching des artifacts téléchargés dans .julia..." && \
  127. # find /root/.julia -name "*.so*" -exec patchelf --clear-execstack {} \;
  128. # ÉTAPE C : Précompilation (Maintenant c'est sûr)
  129. # On utilise xvfb-run car Gtk/ProfileView ont besoin d'un serveur X, même virtuel.
  130. #RUN xvfb-run --auto-servernum --server-args="-screen 0 1920x1080x24 -nolisten tcp" \
  131. # julia -e 'import Pkg; Pkg.precompile()'
  132. # -----------------------------------------------------------------------------
  133. # 5. Création de l'utilisateur (Structure décomposée conservée)
  134. # -----------------------------------------------------------------------------
  135. RUN groupadd -g ${GROUP_ID} ${USER_NAME} && \
  136. useradd -m -u ${USER_ID} -g ${USER_NAME} -s /bin/bash ${USER_NAME} && \
  137. echo "${USER_NAME} ALL=(ALL) NOPASSWD:ALL" >> /etc/sudoers
  138. USER ${USER_NAME}
  139. WORKDIR /home/${USER_NAME}/project
  140. ENV DISPLAY=host.docker.internal:0.0
  141. CMD ["/bin/bash"]