启动容器报错ls: cannot access ‘/docker-entrypoint-initdb.d/‘: Operation not permitted

错误原因分析

  1. SELinux 安全模块限制‌:CentOS 系统默认启用 SELinux,会限制容器对某些目录的访问权限。
  2. Docker 权限不足‌:容器缺少执行初始化脚本所需的权限。

解决方案

方法一:添加特权模式(好使)

docker-compose.yml 中为容器添加 --privileged 参数,赋予容器 root 权限:

复制代码
services:
  your_service:
    image: your_image
    privileged: true  # 添加此行
    volumes:
      - ./initdb.d:/docker-entrypoint-initdb.d

注意‌:使用特权模式存在安全风险,建议仅在测试环境中使用。

方法二:修改 SELinux 配置

临时禁用 SELinux(重启后失效):

复制代码
setenforce 0 

永久禁用 SELinux(需重启系统):

复制代码
vi /etc/selinux/config # 将 SELINUX=enforcing 改为 SELINUX=disabled 
方法三:检查目录权限

确保主机目录权限正确:

复制代码
chmod 755 ./initdb.d 

并在 docker-compose.yml 中正确映射:

复制代码
volumes: - ./initdb.d:/docker-entrypoint-initdb.d:ro # 添加只读权限 

验证步骤

  1. 修改 docker-compose.yml 后,执行 docker-compose down 清理旧容器。
  2. 重新启动服务:docker-compose up -d
  3. 检查日志:docker-compose logs

其他建议

  • 若问题持续,升级 Docker 版本至 20.10.9+(如 CentOS 7)。
  • 确认 docker-entrypoint-initdb.d 目录下文件格式正确(如 .sh.sql)。

优先推荐方法一(添加特权模式),若需长期解决方案,建议方法二(禁用 SELinux)。

相关推荐
风落无尘4 小时前
Stable Diffusion WebUI & ComfyUI 完整安装教程:官方部署+一键整合包+Docker容器化(2026最新)
docker·容器·stable diffusion
CodeMartain9 小时前
Dify Windows 原生部署(无 Docker、纯本地)
运维·docker·容器
万里侯10 小时前
云原生数据备份与恢复:保障数据安全的最佳实践
微服务·容器·k8s
llrraa201010 小时前
配置docker国内镜像源
运维·docker·容器
华为云开发者联盟12 小时前
告别繁琐操作,华为云码道 + Docker重塑远程开发体验
人工智能·学习·docker·华为云·软件开发·华为云码道
m_1368712 小时前
Docker Desktop WSL2 启动失败:ext4.vhdx 拒绝访问(E_ACCESSDENIED)完整解决方案
docker
珂玥c12 小时前
k8s集群ingress碎碎念
云原生·容器·kubernetes
米高梅狮子14 小时前
Ceph 分布式存储 部署
linux·运维·数据库·分布式·ceph·docker·华为云
比特森林探险记14 小时前
context 在 gRPC / Gin / K8s 中的实战
容器·kubernetes·gin
米高梅狮子15 小时前
Redis
数据库·redis·mysql·缓存·docker·容器·github