Utilisez 3 fichiers
build.sh
#!/bin/bash
set -e
if [[ $UID == 0 ]]; then
echo "You must not run this as root." 1>&2
exit 1
fi
if !(type docker >/dev/null); then
echo "Docker is not installing on this machine." 1>&2
exit 1
fi
#Cliquez ici pour le traitement à effectuer avant de créer le conteneur Docker
WORKDIR=$(cd $(dirname $0); pwd)
NAME=base-files-11ubuntu4
#Décrit jusqu'à présent
#Création du nom de l'image_deb est réécrit par le fichier deb à construire
#Exemple: build_base-files
sudo docker build -t build_deb ${WORKDIR}
sudo docker run -e NAME=${NAME} -e UGID="${UID}:$(id -u)" -v ${WORKDIR}/out:/deb -it build_deb
Dockerfile
FROM ubuntu:20.04
ARG NAME="base-files-11ubuntu4"
#Décrivez le nom du répertoire à construire
ARG UID=65587
#Avec une grande valeur pour ne pas entrer en conflit
RUN sed -i"" -e 's%http://[^ ]\+%mirror://mirrors.ubuntu.com/mirrors.txt%g' /etc/apt/sources.list \
&& apt-get update \
&& apt-get -y upgrade \
&& apt-get install -y --no-install-recommends build-essential devscripts zstd gawk libc6 libcrypt1 debhelper dh-systemd apt-utils sudo \
&& rm -rf /tmp/* /var/tmp/* \
&& apt-get clean
#Installer les dépendances
RUN echo "root:root" | chpasswd && \
adduser --disabled-password --uid ${UID} --gecos "" docker && \
echo "docker:docker" | chpasswd && \
echo "%docker ALL=(ALL) NOPASSWD: ALL" >> /etc/sudoers.d/docker && \
chmod 0440 /etc/sudoers.d/docker
#Créer un utilisateur que sudo peut utiliser sans entrer de mot de passe
RUN mkdir -p /debuild/build /deb
ADD ./${NAME} /debuild/build/${NAME}
ADD ./debuild.sh /debuild/debuild.sh
RUN chmod +x /debuild/debuild.sh \
&& chown -R docker:docker /debuild
USER ${UID}
WORKDIR /debuild
CMD ["./debuild.sh"]
debuild.sh
#!/bin/bash -e
if [ $UID != 65587 ]; then
echo "You have to run this on Docker" 1>&2
exit 1
fi
#Supprimer l'exécution en dehors du conteneur Docker
export EDITOR=vim
cd /debuild/build/$NAME
#Décrivez le processus avant la construction
debuild -us -uc
#Construire
cd ..
tar cf ${BASE_FILES}serene${VERSION:5}.tar \
base-files-dbgsym_${BASE_FILES:11}serene${VERSION:5}_amd64.ddeb \
base-files_${BASE_FILES:11}serene${VERSION:5}.dsc \
base-files_${BASE_FILES:11}serene${VERSION:5}_amd64.build \
base-files_${BASE_FILES:11}serene${VERSION:5}_amd64.buildinfo \
base-files_${BASE_FILES:11}serene${VERSION:5}_amd64.changes \
base-files_${BASE_FILES:11}serene${VERSION:5}_amd64.deb \
lsb-release-udeb_${BASE_FILES:11}serene${VERSION:5}_all.udeb
zstd ${BASE_FILES}serene${VERSION:5}.tar
sudo mv -f *.xz /deb 2>/dev/null
sudo mv -f *.zst /deb 2>/dev/null
sudo chown -R ${H_UGID} /deb 2>/dev/null
#Tar ce que tu as construit.Compressé en zst, dans un répertoire partagé avec l'hôte avec le paquet source
Recommended Posts