Не удалось получить uid/gid при сборке Node/Docker

Мой Dockerfile использует alpine и глобально устанавливает реагирующие сценарии. Когда он пытается установить его, он терпит неудачу с ошибкой «не удалось получить uid/gid». Я добавил параметр «---unsafe-perm» в команду npm install -g. Контейнер Docker успешно создан, но разрешения в контейнере выдаются для установленных файлов. Я вижу, что имя пользователя и группа установлены на 1000 для всех из них. Я попытался добавить следующую команду в Dockerfile прямо перед установкой, но это не помогло.

RUN npm -g config set user root

Ошибка сборки

Error: could not get uid/gid
[ 'nobody', 0 ]

    at /usr/local/lib/node_modules/npm/node_modules/uid-number/uid-number.js:37:16
    at ChildProcess.exithandler (child_process.js:296:5)
    at ChildProcess.emit (events.js:182:13)
    at maybeClose (internal/child_process.js:961:16)
    at Process.ChildProcess._handle.onexit (internal/child_process.js:250:5)
TypeError: Cannot read property 'get' of undefined
    at errorHandler (/usr/local/lib/node_modules/npm/lib/utils/error-handler.js:205:18)
    at /usr/local/lib/node_modules/npm/bin/npm-cli.js:76:20
    at cb (/usr/local/lib/node_modules/npm/lib/npm.js:228:22)
    at /usr/local/lib/node_modules/npm/lib/npm.js:266:24
    at /usr/local/lib/node_modules/npm/lib/config/core.js:83:7
    at Array.forEach (<anonymous>)
    at /usr/local/lib/node_modules/npm/lib/config/core.js:82:13
    at f (/usr/local/lib/node_modules/npm/node_modules/once/once.js:25:25)
    at afterExtras (/usr/local/lib/node_modules/npm/lib/config/core.js:173:20)
    at Conf.<anonymous> (/usr/local/lib/node_modules/npm/lib/config/core.js:231:22)
/usr/local/lib/node_modules/npm/lib/utils/error-handler.js:205
  if (npm.config.get('json')) {
                 ^

TypeError: Cannot read property 'get' of undefined
    at process.errorHandler (/usr/local/lib/node_modules/npm/lib/utils/error-handler.js:205:18)
    at process.emit (events.js:182:13)
    at process._fatalException (internal/bootstrap/node.js:472:27)
ERROR: Service 'sample-app' failed to build: The command '/bin/sh -c npm install [email protected] -g' returned a non-zero code: 

Докерфайл

/usr/src/app # cat Dockerfile
# build environment
FROM node:10-alpine as builder
RUN mkdir -p /usr/src/app
WORKDIR /usr/src/app
ENV PATH /usr/src/app/node_modules/.bin:$PATH
COPY package.json /usr/src/app/package.json
RUN npm install
RUN npm install [email protected] -g 
COPY . /usr/src/app
RUN npm run build

# production environment
FROM nginx:1.13.9-alpine
COPY --from=builder /usr/src/app/build /usr/share/nginx/html
EXPOSE 80
CMD ["nginx", "-g", "daemon off;"]

person user994165    schedule 06.09.2018    source источник


Ответы (2)


UPD Исправлено в [email protected]?

Проверьте, не связано ли это с nodejs/docker-node issue 813. :

Основная причина, по-видимому, заключается в следующем: размер стека потоков

Размер стека по умолчанию для новых потоков в glibc определяется на основе ограничения ресурсов, определяющего стек основного потока (RLIMIT_STACK).
Обычно он составляет 2–10 МБ.

Есть три возможных решения:

  • Поговорите с командой Alpine, чтобы исправить это. Уже было некоторые обсуждения
  • Исправьте это в образе node docker alpine следующим образом
  • Установите значение по умолчанию npm_config_unsafe_perm=true в образе докера в качестве обходного пути, пока оно не будет исправлено.

Вы уже пробовали третий вариант, но учтите также:

В качестве альтернативы вам следует переключиться на тонкий (Debian) вариант, пока команда Alpine не исправит его.

person VonC    schedule 06.09.2018
comment
RUN npm config set unsafe-perm true в файле докера перед установкой npm - person Nick Roz; 19.03.2019
comment
Я пошел по третьему варианту, он сработал как шарм. Для моего использования любое снижение производительности было незначительным - person jonasbn; 06.02.2020

Я столкнулся с той же проблемой в Docker для образа node-alpine, когда я докеризую свое реагирующее приложение.

Я решил со следующей конфигурацией dockerfile.

FROM node:8.10.0-alpine

# Set a working directory
WORKDIR /usr/src/app

COPY ./build/package.json .
COPY ./build/yarn.lock .

# To handle 'not get uid/gid'
RUN npm config set unsafe-perm true

# Install Node.js dependencies
RUN yarn install --production --no-progress

# Copy application files
COPY ./build .

# Install pm2
RUN npm install -g pm2 --silent


# Run the container under "node" user by default
USER node

CMD ["pm2", "start", "mypm2config.yml", "--no-daemon", "--env", "preprod"]
person Shree Prakash    schedule 08.05.2019