Verwenden Sie 3 Dateien
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
#Klicken Sie hier, um die Verarbeitung durchzuführen, bevor Sie den Docker-Container erstellen
WORKDIR=$(cd $(dirname $0); pwd)
NAME=base-files-11ubuntu4
#Bisher beschrieben
#Bildname erstellen_deb wird von der zu erstellenden deb-Datei neu geschrieben
#Beispiel: 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"
#Beschreiben Sie den Namen des zu erstellenden Verzeichnisses
ARG UID=65587
#Mit einem großen Wert, um keine Konflikte zu verursachen
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
#Abhängigkeiten installieren
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
#Erstellen eines Benutzers, den sudo ohne Eingabe eines Passworts verwenden kann
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
#Unterdrücken Sie das Ausführen außerhalb des Docker-Containers
export EDITOR=vim
cd /debuild/build/$NAME
#Beschreiben Sie den Prozess vor dem Erstellen
debuild -us -uc
#Bauen
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
#Teer was du gebaut hast.In zst komprimiert, in ein freigegebenes Verzeichnis mit Host mit Quellpaket
Recommended Posts