пакет удаляется при добавлении новой зависимости? - PullRequest
0 голосов
/ 09 января 2020

В сценарии точки входа для docker на основе alpine linux - у меня есть следующие строки:

#!/bin/sh
echo "============== START ============"
echo $@
NOLOAD=0
FILE=""

RET=1

if [ !  -f /initialized ]; then
  echo "not initialized"
  apk add --virtual .init-deps bash
  echo "bash installed"
  echo "Building from server"
  apk add --virtual .init-deps git
  echo "git installed"
  bash load_git.sh "${GIT_SERVER}" "${GIT_USERNAME}" "${GIT_PASSWORD}" "${GIT_BRANCH}"
  RET=$?
  echo cloning done
fi
echo "just before purging all dependencies"
apk --purge del .init-deps

Я ожидаю установки bash, а также git и запустите скрипт load_git.sh, используя bash. Я веду литературную запись каждой другой строки, но получаю некоторые странные результаты - до того, как сценарий load_git.sh даже запустится:

============== START ============

not initialized
(1/6) Installing ncurses-terminfo-base (6.1_p20191130-r0)
(2/6) Installing ncurses-terminfo (6.1_p20191130-r0)
(3/6) Installing ncurses-libs (6.1_p20191130-r0)
(4/6) Installing readline (8.0.1-r0)
(5/6) Installing bash (5.0.11-r1)
Executing bash-5.0.11-r1.post-install
(6/6) Installing .init-deps (20200109.202215)
Executing busybox-1.31.1-r8.trigger
OK: 18 MiB in 24 packages
bash installed
Building from server
(1/12) Installing ca-certificates (20191127-r0)
(2/12) Installing nghttp2-libs (1.40.0-r0)
(3/12) Installing libcurl (7.67.0-r0)
(4/12) Installing expat (2.2.9-r1)
(5/12) Installing pcre2 (10.34-r1)
(6/12) Installing git (2.24.1-r0)
(7/12) Upgrading .init-deps (20200109.202215 -> 20200109.202216)
(8/12) Purging bash (5.0.11-r1)
Executing bash-5.0.11-r1.pre-deinstall
(9/12) Purging readline (8.0.1-r0)
(10/12) Purging ncurses-libs (6.1_p20191130-r0)
(11/12) Purging ncurses-terminfo (6.1_p20191130-r0)
(12/12) Purging ncurses-terminfo-base (6.1_p20191130-r0)
Executing busybox-1.31.1-r8.trigger
Executing ca-certificates-20191127-r0.trigger
OK: 25 MiB in 25 packages
git installed
/init.sh: line 17: bash: not found
cloning done
outside if statement to get source
just before purging all dependencies
Build failed, starting shell

Я не могу понять, что после установки git он также очищает bash, в этом нет никакого смысла.

EDIT: это происходит только при запуске docker через соединение s sh в синологии nas , когда используя локальное docker изображение и запуская его локально, он прекрасно работает.

Ответы [ 2 ]

1 голос
/ 10 января 2020

Похоже, что здесь происходит то, что опция apk add --virtual .init-deps создает виртуальный пакет и делает его зависимым от других пакетов, которые только что были установлены. Когда вы делаете это второй раз, он создает новый виртуальный пакет, который зависит (только) от второго набора пакетов, и обновляет виртуальный пакет до новой версии; когда вы это делаете, первый набор пакетов автоматически удаляется.

Здесь есть два простых обходных пути: либо уберите эту опцию --virtual .init-deps из обеих строк, либо объедините все ваши установки в одну apk add line.

(Как правило, загрузка пакетов при запуске контейнера обычно не является хорошей практикой, особенно потому, что удаление и воссоздание контейнеров является довольно обычной операцией. Лучше было бы сделать это один раз в Dockerfile образа

RUN apk add bash git

, но также подумайте, нужен ли вам какой-либо из этих инструментов для запуска приложения, упакованного в образ.)

0 голосов
/ 10 января 2020

Я попытался воспроизвести это и справился с помощью приведенного ниже сценария на удаленной машине:

#!/bin/sh
if [ !  -f /initialized ]; then
  apk add --virtual .init-deps bash
  apk add --virtual .init-deps git
  bash -c "bash works"
fi

Но последовательные запуски имеют разные результаты:

ubuntu@dev:~$ docker run c81a2d3a5f6b
fetch http://dl-cdn.alpinelinux.org/alpine/v3.11/main/x86_64/APKINDEX.tar.gz
fetch http://dl-cdn.alpinelinux.org/alpine/v3.11/community/x86_64/APKINDEX.tar.gz
(1/6) Installing ncurses-terminfo-base (6.1_p20191130-r0)
(2/6) Installing ncurses-terminfo (6.1_p20191130-r0)
(3/6) Installing ncurses-libs (6.1_p20191130-r0)
(4/6) Installing readline (8.0.1-r0)
(5/6) Installing bash (5.0.11-r1)
Executing bash-5.0.11-r1.post-install
(6/6) Installing .init-deps (20200109.224208)
Executing busybox-1.31.1-r8.trigger
OK: 15 MiB in 20 packages
(1/12) Installing ca-certificates (20191127-r0)
(2/12) Installing nghttp2-libs (1.40.0-r0)
(3/12) Installing libcurl (7.67.0-r0)
(4/12) Installing expat (2.2.9-r1)
(5/12) Installing pcre2 (10.34-r1)
(6/12) Installing git (2.24.1-r0)
(7/12) Upgrading .init-deps (20200109.224208 -> 20200109.224209)
(8/12) Purging bash (5.0.11-r1)
Executing bash-5.0.11-r1.pre-deinstall
(9/12) Purging readline (8.0.1-r0)
(10/12) Purging ncurses-libs (6.1_p20191130-r0)
(11/12) Purging ncurses-terminfo (6.1_p20191130-r0)
(12/12) Purging ncurses-terminfo-base (6.1_p20191130-r0)
Executing busybox-1.31.1-r8.trigger
Executing ca-certificates-20191127-r0.trigger
OK: 22 MiB in 21 packages
/test.sh: line 5: bash: not found

ubuntu@dev:~$ docker run c81a2d3a5f6b
fetch http://dl-cdn.alpinelinux.org/alpine/v3.11/main/x86_64/APKINDEX.tar.gz
fetch http://dl-cdn.alpinelinux.org/alpine/v3.11/community/x86_64/APKINDEX.tar.gz
(1/6) Installing ncurses-terminfo-base (6.1_p20191130-r0)
(2/6) Installing ncurses-terminfo (6.1_p20191130-r0)
(3/6) Installing ncurses-libs (6.1_p20191130-r0)
(4/6) Installing readline (8.0.1-r0)
(5/6) Installing bash (5.0.11-r1)
Executing bash-5.0.11-r1.post-install
(6/6) Installing .init-deps (20200109.224207)
Executing busybox-1.31.1-r8.trigger
OK: 15 MiB in 20 packages
OK: 15 MiB in 20 packages
bash works

Итак Я думаю, что это проблема синхронизации в АПК

...