如何使作曲家在容器中创建非root用户拥有的文件?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何使作曲家在容器中创建非root用户拥有的文件?相关的知识,希望对你有一定的参考价值。

我想在Dockerfile中执行composer install

FROM php:7.3-fpm-alpine AS base

ARG UNAME=www-data
ARG UID=1000
ARG GID=1000

# Create a non root user
RUN set -ex; 
    addgroup -g "${GID}" -S ${UNAME}; 
    adduser -u "${UID}" -D -S -s /bin/sh -G ${UNAME} ${UNAME}; 
    adduser ${UNAME} www-data; 
    sed -i '/^${UNAME}/s/!/*/' /etc/shadow;
RUN chown ${UNAME}:${UNAME} /var/www/html

COPY --from=composer:1.9.3 /usr/bin/composer /usr/bin/composer

USER ${UNAME}

COPY --chown=${UID}:${GID} docker/test/composer.json composer.json
RUN composer install

但是在vendor /中创建的文件归root所有。

如何使composer以非root用户身份创建文件,在我的情况下为www-data

答案

执行chown 之后编写完成,或者根据您的选择作为用户运行。

以上是关于如何使作曲家在容器中创建非root用户拥有的文件?的主要内容,如果未能解决你的问题,请参考以下文章

如何在 Visual Studio 2019 C++ 中创建非虚拟文件夹

在不使用 sudo 的情况下更改 root 用户拥有的文件的权限

如何在 docker 中以非 root 用户身份写入卷容器?

在docker挂载卷中管理nginx vhost文件权限

如何在 Create Table 中创建非聚集索引?

在 XIB 文件中创建非视图对象的指南