Dockerfile 如下:
FROM ubuntu:latest AS build LABEL author="fourstring" ARG NGINX_VER=1.15.7 ARG NGINX_URL=http://nginx.org/download/nginx-${NGINX_VER}.tar.gz ARG OPENSSL_VER=1.1.1a ARG OPENSSL_URL=https://www.openssl.org/source/openssl-${OPENSSL_VER}.tar.gz ARG PCRE_VER=8.42 ARG PCRE_URL=https://ftp.pcre.org/pub/pcre/pcre-${PCRE_VER}.tar.gz ARG ZLIB_VER=1.2.11 ARG ZLIB_URL=https://zlib.net/zlib-${ZLIB_VER}.tar.gz ARG NGINX_BUILD_PARAS='--prefix=/usr/local/nginx --with-cc-opt=-static --with-ld-opt=-static --with-threads --with-file-aio --with-http_ssl_module --with-http_v2_module --with-http_sub_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_stub_status_module --with-openssl=../openssl-${OPENSSL_VER} --with-pcre=../pcre-${PCRE_VER} --with-pcre-jit --with-zlib=../zlib-${ZLIB_VER}' ARG APT_PACKAGES='build-essential wget tar upx' ARG APT_REMOVE_PACKAGES='build-essential upx' ARG MAX_THREADS=3 RUN groupadd -g 50000 www && \ useradd -g 50000 -u 50000 -s /sbin/nologin www RUN apt -y update && \ apt -y install ${APT_PACKAGES} && \ cd /usr/loca/src && \ wget ${ZLIB_URL} && \ wget ${PCRE_URL} && \ wget ${OPENSSL_URL} && \ wget ${NGINX_URL} && \ tar xzf nginx-${NGINX_VER}.tar.gz && \ tar xzf openssl-${OPENSSL_VER}.tar.gz && \ tar xzf zlib-${ZLIB_VER}.tar.gz && \ tar xzf pcre-${PCRE_VER}.tar.gz && \ cd nginx-${NGINX_VER} && \ ./configure ${NGINX_BUILD_PARAS} && \ make -j${MAX_THREADS} && \ make install && \ upx /usr/local/nginx/sbin/nginx && \ mkdir -p /usr/local/nginx/conf/vhost FROM alpine RUN adduser -g 50000 -u 50000 -s /sbin/nologin -D -H www COPY --from=build --chown=www:www /usr/local/nginx /usr/local/nginx COPY nginx.conf /usr/local/nginx/conf COPY xxx.conf /usr/local/nginx/conf/vhost EXPOSE 80 EXPOSE 443 USER www CMD [ "/usr/local/nginx/sbin/nginx","-g","daemon off;" ] 现在遇到了一些诡异的用户问题。
- 如果我不使用最后的
USER www指令,那么会报错getpwnam("www") (No such file or directory),由于一般使用不存在的用户运行 nginx 的报错并不会出现(No such file or directory),我用 Google 搜索后找到一个解释说当使用指定的用户以外的用户运行 nginx 就会出现这个错误,加USER www指令后这个报错确实也消失了 - 但是由于使用低权限运行,nginx 无法使用 80 和 443 端口
- 1.里面提到的那个解释我也表示存疑,因为一般情况下 nginx 主进程需要以高权限开启,并不会报这样的错误
那么请问我应该如何处理这个用户问题?还是我对 Linux 或者 nginx 用户机制的理解有问题呢?谢谢
