docker部署nginx因权限问题无法启动

docker run \
-p 83:80 \
--name nginx-xt \
-v /data/nginx-xt/conf/nginx.conf:/etc/nginx/nginx.conf \
-v /data/nginx-xt/conf/conf.d:/etc/nginx/conf.d \
-v /data/nginx-xt/log:/var/log/nginx \
-v /data/nginx-xt/html:/usr/share/nginx/html \
-d nginx:latest  

问题

执行该命令后docker挂掉,报错如下:

nginx: [alert] could not open error log file: open() "/var/log/nginx/error.log" failed (13: Permission denied)
2025/03/06 01:24:29 [emerg] 1#1: open() "/etc/nginx/nginx.conf" failed (13: Permission denied)

问题分析

docker run 命令映射了宿主机上的配置文件和目录:

-v /data/nginx-xt/conf/nginx.conf:/etc/nginx/nginx.conf
-v /data/nginx-xt/log:/var/log/nginx

Nginx 进程默认 nginx 用户(UID:101)运行,但宿主机上的 /data/nginx-xt/conf/nginx.conf/data/nginx-xt/log/ 可能 权限不足,导致 Nginx 无法读取配置文件无法写入日志文件

解决方案

方案一 修改 Nginx 目录和文件的权限

chmod 777 /data/nginx-xt/conf/nginx.conf
chmod 777 /data/nginx-xt/html
chown 777 /data/nginx-xt/log

  docker restart nginx-xt

方案二 检查 SELinux(如果适用)

如果你的服务器运行的是 CentOS 或 RHEL,可能是 SELinux 限制了 Nginx 访问挂载目录:

setenforce 0

然后重新启动容器

docker restart nginx-xt

如果确定是 SELinux 问题,可以永久允许:

chcon -Rt svirt_sandbox_file_t /data/nginx-xt/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值