CentOS7中Docker文件挂载的权限

本文介绍了解决CentOS7中Docker容器挂载本地目录无执行权限的方法,包括赋予容器特权、临时关闭selinux及添加selinux规则等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

【转自oschina.net,作者runescape,微改】

CentOS7中,挂载的本地目录在容器中没有执行权限,原因是CentOS7安全模块selinux把权限禁掉了,至少有以下三种方式解决挂载的目录没有权限的问题:

1,在运行容器的时候,给容器加特权:

示例:docker run -i -t --privileged=true -v /docker/data1:/data --name eureka1 centos:7.5.1804

2,临时关闭selinux:

示例:su -c "setenforce 0"

之后执行:docker run -i -t -v /docker/data1:/data --name eureka1 centos:7.5.1804

注意:之后要记得重新开启selinux,命令:su -c "setenforce 1"

3,添加selinux规则,将要挂载的目录添加到白名单:

示例:chcon -Rt svirt_sandbox_file_t /docker/data1

之后执行:docker run -i -t -v /docker/data1:/data --name eureka1 centos:7.5.1804

CentOS 6/7系列安装Docker http://www.linuxidc.com/Linux/2014-07/104768.htm

Docker的搭建Gitlab CI 全过程详解 http://www.linuxidc.com/Linux/2013-12/93537.htm

Docker安装应用(CentOS 6.5_x64) http://www.linuxidc.com/Linux/2014-07/104595.htm

在 Docker 中使用 MySQL http://www.linuxidc.com/Linux/2014-01/95354.htm

Ubuntu Trusty 14.04 (LTS) (64-bit)安装Docker http://www.linuxidc.com/Linux/2014-10/108184.htm

Docker安装应用(CentOS 6.5_x64) http://www.linuxidc.com/Linux/2014-07/104595.htm

Ubuntu 14.04安装Docker  http://www.linuxidc.com/linux/2014-08/105656.htm

阿里云CentOS 6.5 模板上安装 Docker http://www.linuxidc.com/Linux/2014-11/109107.htm

Docker 的详细介绍请点这里
Docker 的下载地址请点这里

<think>好的,我现在需要帮用户在CentOS 7上通过Docker安装MySQL。首先,我得回忆一下Docker的基本操作步骤。用户可能不太熟悉Docker,所以步骤要详细一点。 首先,安装Docker本身是前提。CentOS 7默认的仓库里可能有旧版本的Docker,所以应该先添加Docker的官方仓库,然后安装。记得启动Docker服务,并设置开机启动,这样下次重启后Docker会自动运行。 接下来是拉取MySQL镜像。用户可能想要特定版本,比如5.7,所以需要指定标签。不过用户示例中的引用提到可以使用`centos/mysql-57-centos7`,或者官方的MySQL镜像。可能得确认一下哪个更合适。不过官方镜像通常更新更及时,所以建议使用`mysql:5.7`。 然后是运行容器。这里需要注意端口映射和数据卷。用户可能需要将MySQL的3306端口映射到宿主机的端口,比如默认的3306,但如果有冲突的话,可能需要调整。数据持久化是关键,所以要用-v参数把容器里的数据目录挂载到宿主机,防止容器删除后数据丢失。设置root密码也是必须的,通过环境变量MYSQL_ROOT_PASSWORD来配置。 还有,用户可能需要远程访问MySQL,所以需要检查MySQL的配置,确保允许远程连接。可能需要进入容器修改用户权限,或者创建新用户并授权。引用中提到的进入容器的方法是用docker exec,这步可能需要指导用户如何操作。 另外,用户可能会遇到安装失败的情况,比如已有的MySQL服务冲突,或者权限问题。需要提醒用户检查是否宿主机已经安装了MySQL,如果有的话需要先停止或卸载,否则端口冲突会导致容器无法启动。还有,如果拉取镜像失败,可能需要检查网络,或者换一个镜像源。 最后,测试连接部分,用户可能需要使用命令行或者客户端工具,比如mysql命令或者Navicat。要确保防火墙开放了对应的端口,CentOS 7的firewalld需要配置,或者直接关闭防火墙测试。 总的来说,步骤大概是:安装Docker -> 拉取镜像 -> 运行容器 -> 配置远程访问 -> 测试连接。需要按顺序写清楚每个步骤的命令和注意事项,同时引用相关的参考资料,比如引用1、2、5关于拉取镜像和运行容器,引用3进入容器的方法,引用4处理安装失败的情况。</think>### 在CentOS 7中使用Docker安装MySQL的步骤 #### 1. **安装Docker** - 若未安装Docker,需先安装并启动服务: ```bash # 安装依赖包 sudo yum install -y yum-utils device-mapper-persistent-data lvm2 # 添加Docker仓库 sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo # 安装Docker引擎 sudo yum install -y docker-ce docker-ce-cli containerd.io # 启动Docker并设置开机自启 sudo systemctl start docker sudo systemctl enable docker ``` #### 2. **拉取MySQL镜像** - 以MySQL 5.7为例,拉取官方镜像[^5]: ```bash docker pull mysql:5.7 ``` - 或使用CentOS兼容的镜像[^1]: ```bash docker pull centos/mysql-57-centos7 ``` #### 3. **创建并运行MySQL容器** - 使用以下命令启动容器: ```bash docker run -d \ --name mysql \ -p 3306:3306 \ -e MYSQL_ROOT_PASSWORD=your_password \ -v /宿主机数据目录:/var/lib/mysql \ mysql:5.7 ``` - `-p 3306:3306`:将容器端口映射到宿主机[^3] - `-v`:挂载数据卷实现持久化存储[^2] - `-e MYSQL_ROOT_PASSWORD`:设置root用户密码[^5] #### 4. **配置远程访问(可选)** - 进入容器并修改权限: ```bash docker exec -it mysql /bin/bash # 进入容器 mysql -u root -p # 输入密码登录 ``` - 执行SQL命令允许远程连接: ```sql ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'your_password'; FLUSH PRIVILEGES; ``` #### 5. **验证安装** - 查看容器运行状态: ```bash docker ps ``` - 测试连接: ```bash mysql -h 127.0.0.1 -P 3306 -u root -p ``` #### 常见问题处理 1. **端口冲突** - 若宿主机已安装MySQL,需先停止服务或修改映射端口(如`-p 3307:3306`)[^4]。 2. **容器启动失败** - 检查日志定位问题: ```bash docker logs mysql ``` 3. **权限问题** - 确保数据目录权限正确: ```bash chmod -R 755 /宿主机数据目录 ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值