Compare commits
3 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 029a7c3b38 | |||
| 5ed95e455c | |||
| 204c1da235 |
+38
-38
@@ -1,38 +1,38 @@
|
|||||||
#cache:
|
cache:
|
||||||
# key: blender-source
|
key: blender-source
|
||||||
# paths:
|
paths:
|
||||||
# - /opt/blender-git/blender # Blender git repository source
|
- /opt/blender-git/blender # Blender git repository source
|
||||||
# - /opt/blender-git/lib # Blender Subversion lib package
|
- /opt/blender-git/lib # Blender Subversion lib package
|
||||||
# policy: pull
|
policy: pull
|
||||||
#
|
|
||||||
#update-cache:
|
update-cache:
|
||||||
# stage: .pre
|
stage: .pre
|
||||||
# cache:
|
cache:
|
||||||
# key: blender-source
|
key: blender-source
|
||||||
# image: stilobique/csv:latest
|
image: stilobique/csv:latest
|
||||||
# script:
|
script:
|
||||||
# - mkdir -p /opt/blender-git/lib
|
- mkdir -p /opt/blender-git/lib
|
||||||
# - cd /opt/blender-git
|
- cd /opt/blender-git
|
||||||
# - git clone https://projects.blender.org/blender/blender.git
|
- git clone https://projects.blender.org/blender/blender.git
|
||||||
# - cd /opt/blender-git/blender
|
- cd /opt/blender-git/blender
|
||||||
# - git submodule update --init --recursive
|
- git submodule update --init --recursive
|
||||||
# - cd /opt/blender-git/lib
|
- cd /opt/blender-git/lib
|
||||||
# - svn checkout https://svn.blender.org/svnroot/bf-blender/trunk/lib/linux_centos7_x86_64
|
- svn checkout https://svn.blender.org/svnroot/bf-blender/trunk/lib/linux_centos7_x86_64
|
||||||
#
|
|
||||||
#build-dockerfile:
|
build-dockerfile:
|
||||||
# image: docker:19.03.12
|
image: docker:19.03.12
|
||||||
# rules:
|
rules:
|
||||||
# - changes:
|
- changes:
|
||||||
# - build.json
|
- build.json
|
||||||
# stage: build
|
stage: build
|
||||||
# services:
|
services:
|
||||||
# - docker:dind
|
- docker:dind
|
||||||
# cache:
|
cache:
|
||||||
# key: blender-source
|
key: blender-source
|
||||||
# script:
|
script:
|
||||||
# - apk add python3
|
- apk add python3
|
||||||
# - apk add py3-pip
|
- apk add py3-pip
|
||||||
# - python3 -m pip install --upgrade pip
|
- python3 -m pip install --upgrade pip
|
||||||
# - python3 -m pip install -r requirement-build.txt
|
- python3 -m pip install -r requirement-build.txt
|
||||||
# - python3 main.py
|
- python3 main.py
|
||||||
# - python3 main.py --tag=latest
|
- python3 main.py --tag=latest
|
||||||
|
|||||||
@@ -1,20 +1,21 @@
|
|||||||
<component name="ProjectRunConfigurationManager">
|
<component name="ProjectRunConfigurationManager">
|
||||||
<configuration default="false" name="Dockerfile" type="docker-deploy" factoryName="dockerfile" server-name="Docker">
|
<configuration default="false" name="Build BlenderDocker" type="docker-deploy" factoryName="dockerfile" server-name="Docker">
|
||||||
<deployment type="dockerfile">
|
<deployment type="dockerfile">
|
||||||
<settings>
|
<settings>
|
||||||
<option name="imageTag" value="stilobique/blender:3.6.12" />
|
<option name="imageTag" value="stilobique/blender:5.1.2" />
|
||||||
<option name="buildArgs">
|
<option name="buildArgs">
|
||||||
<list>
|
<list>
|
||||||
<DockerEnvVarImpl>
|
<DockerEnvVarImpl>
|
||||||
<option name="name" value="b3d_vs_major" />
|
<option name="name" value="b3d_vs_major" />
|
||||||
<option name="value" value="3.6" />
|
<option name="value" value="5.1" />
|
||||||
</DockerEnvVarImpl>
|
</DockerEnvVarImpl>
|
||||||
<DockerEnvVarImpl>
|
<DockerEnvVarImpl>
|
||||||
<option name="name" value="b3d_vs_minor" />
|
<option name="name" value="b3d_vs_minor" />
|
||||||
<option name="value" value="12" />
|
<option name="value" value="2" />
|
||||||
</DockerEnvVarImpl>
|
</DockerEnvVarImpl>
|
||||||
</list>
|
</list>
|
||||||
</option>
|
</option>
|
||||||
|
<option name="buildCliOptions" value="--debug" />
|
||||||
<option name="buildOnly" value="true" />
|
<option name="buildOnly" value="true" />
|
||||||
<option name="containerName" value="blender-latest" />
|
<option name="containerName" value="blender-latest" />
|
||||||
<option name="sourceFilePath" value="Dockerfile" />
|
<option name="sourceFilePath" value="Dockerfile" />
|
||||||
@@ -28,6 +29,7 @@
|
|||||||
</option>
|
</option>
|
||||||
</settings>
|
</settings>
|
||||||
</deployment>
|
</deployment>
|
||||||
|
<EXTENSION ID="com.jetbrains.rider.docker.debug" isFastModeEnabled="true" isSslEnabled="false" />
|
||||||
<method v="2" />
|
<method v="2" />
|
||||||
</configuration>
|
</configuration>
|
||||||
</component>
|
</component>
|
||||||
+68
-62
@@ -1,91 +1,97 @@
|
|||||||
FROM ubuntu:22.04 AS blender
|
FROM ubuntu:25.04 AS b3dock
|
||||||
|
|
||||||
# Setup all software version request
|
# Setup all software version request
|
||||||
ARG b3d_vs_major=3.6
|
ARG b3d_vs_major=5.1
|
||||||
ARG b3d_vs_minor=10
|
ARG b3d_vs_minor=0
|
||||||
ARG version=v${b3d_vs_major}.${b3d_vs_minor}
|
|
||||||
|
|
||||||
LABEL Author="stilobique"
|
LABEL Author="stilobique"
|
||||||
LABEL Title="Blender Docker for Unit Test"
|
LABEL Title="Blender Docker for Unit Test"
|
||||||
|
|
||||||
|
#ENV TZ=Europe/Paris
|
||||||
|
#RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
|
||||||
|
|
||||||
|
## 01. Start First stage to build blender
|
||||||
# Install dependencies
|
# Install dependencies
|
||||||
RUN apt-get update && apt-get install -y build-essential \
|
RUN apt-get update && apt-get install -y \
|
||||||
git \
|
git \
|
||||||
git-lfs \
|
git-lfs \
|
||||||
cmake \
|
|
||||||
python3 \
|
python3 \
|
||||||
python3-dev \
|
build-essential \
|
||||||
cython3 \
|
subversion \
|
||||||
sudo
|
cmake \
|
||||||
|
libx11-dev \
|
||||||
RUN apt-get install -y libx11-dev \
|
|
||||||
libxxf86vm-dev \
|
libxxf86vm-dev \
|
||||||
libxcursor-dev \
|
libxcursor-dev \
|
||||||
libxi-dev \
|
libxi-dev \
|
||||||
libxrandr-dev \
|
libxrandr-dev \
|
||||||
libxinerama-dev \
|
libxinerama-dev \
|
||||||
libxkbcommon-dev \
|
libegl-dev \
|
||||||
libwayland-dev \
|
libwayland-dev \
|
||||||
libdecor-0-dev \
|
|
||||||
wayland-protocols \
|
wayland-protocols \
|
||||||
|
libxkbcommon-dev \
|
||||||
libdbus-1-dev \
|
libdbus-1-dev \
|
||||||
libgl-dev \
|
linux-libc-dev
|
||||||
libegl-dev
|
|
||||||
|
|
||||||
RUN apt-get install -y libjpeg-dev \
|
|
||||||
libpng-dev \
|
|
||||||
libfreetype-dev \
|
|
||||||
libfontconfig-dev \
|
|
||||||
libzstd-dev \
|
|
||||||
libbz2-dev \
|
|
||||||
liblzma-dev \
|
|
||||||
libsdl2-dev \
|
|
||||||
libepoxy-dev \
|
|
||||||
libxml2-dev \
|
|
||||||
libhpdf-dev \
|
|
||||||
libpystring-dev
|
|
||||||
|
|
||||||
RUN apt-get install -y libopenjp2-7-dev \
|
|
||||||
libtiff-dev \
|
|
||||||
libjack-jackd2-dev \
|
|
||||||
libpulse-dev \
|
|
||||||
libopenal-dev \
|
|
||||||
libsndfile1-dev \
|
|
||||||
libjemalloc-dev \
|
|
||||||
libvulkan-dev \
|
|
||||||
libgmp-dev \
|
|
||||||
libpugixml-dev \
|
|
||||||
libfftw3-dev \
|
|
||||||
libpotrace-dev \
|
|
||||||
libyaml-cpp-dev \
|
|
||||||
libdeflate-dev
|
|
||||||
|
|
||||||
# ADD . /opt/blender-git
|
|
||||||
RUN git clone --depth 1 --branch ${version} https://projects.blender.org/blender/blender.git /opt/blender-git
|
|
||||||
|
|
||||||
# Use the local repo has current directory
|
|
||||||
#WORKDIR /opt/blender-git
|
|
||||||
|
|
||||||
# Compile Blender
|
# Compile Blender
|
||||||
RUN cd /opt/blender-git && \
|
RUN git clone --depth 1 --branch v${b3d_vs_major}.${b3d_vs_minor} \
|
||||||
sudo ./build_files/utils/make_update.py --use-linux-libraries
|
https://projects.blender.org/blender/blender.git /opt/blender
|
||||||
RUN cd /opt/blender-git && \
|
|
||||||
make
|
|
||||||
|
|
||||||
|
RUN cd /opt/blender && make update
|
||||||
|
RUN cd /opt/blender && make -j$(nproc)
|
||||||
|
|
||||||
|
|
||||||
|
## 02. Collecte all dependencies
|
||||||
|
FROM b3dock AS collector
|
||||||
|
# Rassemble toutes les .so des precompiled libs dans un dossier plat
|
||||||
|
# -not -type d : ignore les dossiers
|
||||||
|
# cp -P : préserve les symlinks relatifs (libFoo.so -> libFoo.so.1.0)
|
||||||
|
RUN mkdir -p /collected-libs && \
|
||||||
|
find /opt/blender/lib/linux_x64 \
|
||||||
|
-name "*.so*" \
|
||||||
|
-not -type d \
|
||||||
|
-exec cp -P {} /collected-libs/ \;
|
||||||
|
|
||||||
|
|
||||||
|
## 03. Build optimissed image
|
||||||
## Setup a Multistage optimisation
|
## Setup a Multistage optimisation
|
||||||
FROM ubuntu:22.04
|
FROM ubuntu:25.04
|
||||||
COPY --from=blender /opt/build_linux/bin /opt/blender
|
|
||||||
ARG b3d_vs_major
|
|
||||||
ENV B3D_ADDON_PATH "$HOME/.config/blender/${b3d_vs_major}/scripts/addons"
|
|
||||||
|
|
||||||
RUN apt-get update && apt-get install -y \
|
RUN apt-get update && apt-get install -y \
|
||||||
|
libx11-6 \
|
||||||
libxi6 \
|
libxi6 \
|
||||||
libxxf86vm1 \
|
libxxf86vm1 \
|
||||||
|
libxrender1 \
|
||||||
|
libxrandr2 \
|
||||||
|
libxinerama1 \
|
||||||
|
libxcursor1 \
|
||||||
libxfixes3 \
|
libxfixes3 \
|
||||||
libxkbcommon-x11-0 \
|
libxkbcommon0 \
|
||||||
libjack0 \
|
libwayland-client0 \
|
||||||
pulseaudio \
|
libwayland-egl1 \
|
||||||
libgl1-mesa-glx
|
libegl1 \
|
||||||
|
libgl1 \
|
||||||
|
libdbus-1-3 \
|
||||||
|
libxcb1 \
|
||||||
|
libtbb12 \
|
||||||
|
libopenal1 \
|
||||||
|
libsm6 \
|
||||||
|
libice6 \
|
||||||
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
|
RUN useradd -m -s /bin/bash bld
|
||||||
|
|
||||||
|
COPY --from=b3dock /opt/build_linux/bin/blender /usr/local/bin/blender
|
||||||
|
COPY --from=collector /collected-libs /usr/local/lib/blender
|
||||||
|
|
||||||
|
RUN echo "/usr/local/lib/blender" > /etc/ld.so.conf.d/blender.conf \
|
||||||
|
&& ldconfig
|
||||||
|
|
||||||
|
ARG b3d_vs_major
|
||||||
|
ENV B3D_ADDON_PATH="/home/bld/.config/blender/${b3d_vs_major}/scripts/addons"
|
||||||
|
|
||||||
|
USER bld
|
||||||
# Working Directory setup
|
# Working Directory setup
|
||||||
WORKDIR /opt/blender
|
WORKDIR /home/bld
|
||||||
|
|
||||||
|
ENTRYPOINT ["/usr/local/bin/blender"]
|
||||||
|
CMD ["--version"]
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
[](https://www.blender.org/download/)
|
[](https://www.blender.org/download/)
|
||||||
[](https://gitlab.com/stilobique/blender-docker/-/commits/main)
|
[](https://gitlab.com/stilobique/blender-docker/-/commits/main)
|
||||||
|
|
||||||
|
|
||||||
@@ -26,3 +26,8 @@ Call this function with blender inside this container
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
/opt/blender/blender --background --python "install.py"
|
/opt/blender/blender --background --python "install.py"
|
||||||
````
|
````
|
||||||
|
|
||||||
|
# Check Image build
|
||||||
|
```shell
|
||||||
|
docker run --rm stilobique/blender:5.1.2 blender --version
|
||||||
|
```
|
||||||
+23
-15
@@ -1,32 +1,40 @@
|
|||||||
{
|
{
|
||||||
"tags":
|
"tags":
|
||||||
[{
|
[{
|
||||||
"b3d_vs_major": 4.1,
|
"b3d_vs_major": 3.4,
|
||||||
|
"b3d_vs_minor": 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"b3d_vs_major": 3.4,
|
||||||
"b3d_vs_minor": 0
|
"b3d_vs_minor": 0
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"b3d_vs_major": 3.6,
|
"b3d_vs_major": 3.3,
|
||||||
"b3d_vs_minor": 12
|
"b3d_vs_minor": 2
|
||||||
},
|
|
||||||
{
|
|
||||||
"b3d_vs_major": 3.6,
|
|
||||||
"b3d_vs_minor": 11
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"b3d_vs_major": 3.6,
|
|
||||||
"b3d_vs_minor": 10
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"b3d_vs_major": 3.3,
|
"b3d_vs_major": 3.3,
|
||||||
"b3d_vs_minor": 19
|
"b3d_vs_minor": 1
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"b3d_vs_major": 3.3,
|
"b3d_vs_major": 3.3,
|
||||||
"b3d_vs_minor": 18
|
"b3d_vs_minor": 0
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"b3d_vs_major": 3.3,
|
"b3d_vs_major": 3.2,
|
||||||
"b3d_vs_minor": 17
|
"b3d_vs_minor": 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"b3d_vs_major": 3.2,
|
||||||
|
"b3d_vs_minor": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"b3d_vs_major": 3.1,
|
||||||
|
"b3d_vs_minor": 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"b3d_vs_major": 3.1,
|
||||||
|
"b3d_vs_minor": 0
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
set -e
|
||||||
|
|
||||||
|
LIB_PATHS="$(find /opt/blender-libs -type d -name lib | paste -sd: -)"
|
||||||
|
export LD_LIBRARY_PATH="${LIB_PATHS}:${LD_LIBRARY_PATH}"
|
||||||
|
|
||||||
|
exec /usr/local/bin/blender "$@"
|
||||||
Reference in New Issue
Block a user