在容器内部挂载NFS

最近业务上遇到一个需要在Container内部挂载NFS的需求。

运行一个Centos7 镜像的容器,然后在容器内执行Mount命令报错:

# 启动容器
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 :

# 启动容器
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配置

apiVersion: v1
kind: Pod
metadata:
  name: nfs-client
spec:
  containers:
  - name: centos
    image: "centos:7"
    command: ["sleep", "10000"]
    securityContext:
      capabilities:
        add:
        - SYS_ADMIN

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值