docker的user namespace功能

docker的user namespace功能:

默认情况下:
容器默认是以root账号进入的,即使指定默认账号,用户也可以通过--user 0来切到root账号,容器里的root和宿主机的root是同一性质,-v挂载宿主机任意目录后,可通过容器里的root账号对宿主机数据进行破坏,风险很大

user namespace功能可以规避这一问题,user namespace可以让容器有一个“假”的root用户,它在容器内是root,被映射到容器外一个非root用户,也就是说user namespace实现了host users和container users之间的映射(只能同时支持1个账号,无法同时支持多个账号)。

检查linux操作系统是否支持user namespace:

uname -a

cat /boot/config-xxxxx | grep CONFIG_USER_NS (显示为y即为支持)

Ubuntu 16.04配置docker使用user namespace:

vi /lib/systemd/system/docker.service

ExecStart=/usr/bin/dockerd --userns-remap=default -H fd:// --containerd=/run/containerd/containerd.sock

:wq

注:
--userns-remap=可以写default,default就是dockerremap账号,也可以写具体的账号名

systemctl restart docker

ps -ef | grep dockerd (看到--userns-remap=default即生效了)

vi /etc/subuid

dockremap:1008:65536

:wq

注:
1008为宿主机执行容器的账号uid,可为本地账号uid,也可为nis账号uid

systemctl restart docker

账号启动容器时需使用root账号,可以加--user=0,如果image里没调默认账号也是root,容器里会将宿主机账号的已有数据属主为root,在容器里root生成的数据在宿主机里显示为正常账号权限

转载于:https://blog.51cto.com/yangzhiming/2384688

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Docker使用了Linux的Namespace技术来实现容器的隔离。Namespace是对全局系统资源的一种封装隔离,它可以让不同的Namespace中的进程拥有独立的全局系统资源。这样改变一个Namespace的系统资源只会影响当前Namespace中的进程,对其他Namespace中的资源没有影响。在最新版本的Linux内核中,提供了8种类型的Namespace,而Docker只使用了其中的前6种,分别是Mount Namespace、PID Namespace、Net Namespace、IPC Namespace、UTS NamespaceUser Namespace。通过使用这些NamespaceDocker实现了容器的隔离性和资源的独立性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Docker学习四:资源隔离——Namespace](https://blog.csdn.net/weixin_41402069/article/details/125866261)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [一文彻底搞懂Docker中的namespace](https://blog.csdn.net/songguangfan/article/details/121727435)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值