Dockerfile 5.5 KB

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