在容器内部挂载NFS
2020-07-17 19:41
246 查看
最近业务上遇到一个需要在Container内部挂载NFS的需求。
运行一个Centos7 镜像的容器,然后在容器内执行Mount命令报错:
[code]# 启动容器 docker run -itd centos:7 # 在容器内部执行 [root@f1e55cabed84 /]# yum install nfs-utils [root@f1e55cabed84 /]# showmount -e 10.10.10.10 Export list for 10.10.10.10: /nfs-data * [root@f1e55cabed84 /]# mount -t nfs 10.10.10.10:/nfs-data /nfs mount.nfs: rpc.statd is not running but is required for remote locking. mount.nfs: Either use '-o nolock' to keep locks local, or start statd. mount.nfs: an incorrect mount option was specified
最后才知道是因为容器的权限不足导致的,因此可以在启动容器时添加命令 --cap-add sys_admin :
[code]# 启动容器 docker run --cap-add sys_admin -itd centos:7 # 在容器内执行挂载 [root@0147446f5774 /]# yum install -y nfs-utils [root@0147446f5774 /]# mkdir /nfs-data [root@0147446f5774 /]# mount -t nfs 10.10.10.10:/nfs-data /nfs-data [root@0147446f5774 /]# df -h Filesystem Size Used Avail Use% Mounted on overlay 50G 8.9G 42G 18% / tmpfs 64M 0 64M 0% /dev tmpfs 3.9G 0 3.9G 0% /sys/fs/cgroup shm 64M 0 64M 0% /dev/shm /dev/mapper/vg-root 50G 8.9G 42G 18% /etc/hosts tmpfs 3.9G 0 3.9G 0% /proc/acpi tmpfs 3.9G 0 3.9G 0% /proc/scsi tmpfs 3.9G 0 3.9G 0% /sys/firmware 10.10.10.10:/nfs-data 50G 6.2G 44G 13% /nfs-data
如果是Kubernetes环境,需要在Pod中添加securityContext配置
[code]apiVersion: v1 kind: Pod metadata: name: nfs-client spec: containers: - name: centos image: "centos:7" command: ["sleep", "10000"] securityContext: capabilities: add: - SYS_ADMIN
相关文章推荐
- 在以 CentOS7.6 为基础镜像的 Docker 容器中通过 NFS 将内存挂载成高速硬盘使用
- Kubernetes - 创建挂载共享存储的容器(NFS)
- kubernetes 使用NFS挂载共享存储的容器(一)
- kubernetes 使用NFS挂载共享存储的容器(二)
- 开发板挂载NFS
- Ubuntu 中挂载其它NFS服务器的文件系统
- ubuntu下NFS挂载常见错误的解决方法[转载]
- 详解UT6410开发板NFS挂载失败的原因
- nfs挂载错误wrong fs type, bad option, bad superblock
- fedora9.0 NFS挂载文件系统到6410上
- 手动配置 ESXi 主机挂载 NFS 的最大值
- 如何Centos上挂载Synology的一个NFS共享文件夹
- HashMap的内部实现-容器深入研究
- TQ2440的mount挂载NFS过程中出现的问题
- Windows挂载linux系统的NFS无法写文件
- 群晖挂载windows系统共享的nfs文件夹--使用第三方工具hanewin
- 虚拟机ubuntu10.04挂载nfs
- zabbix NFS挂载 监控模板
- Linux_开发板通过NFS挂载到虚拟机的几个错误解决
- 挂载nfs