问下 Linux docker 相关知识

2021-03-07 23:48:05 +08:00
 wszgrcy

事情是这样的,我在研究 openwrt 跑在 docker 的过程中,给实体机挂载了两块硬盘

其中 ext4 分区的都挂载成功

只有 ntfs 的不成功

排查了一晚上后,突然想到是不是给 op 开了特权的原因………结果一登陆果然,因为有特权➕自动挂载脚本,ntfs 分区给我挂载进容器里了……

这里有几个问题

1.为啥 ntfs 不能多挂载?

2.特权模式到底有哪些特权,能不能大佬发个资料让我学习下。因为我对 docker 仅限于普通的使用,没研究那种原理级别的(还有一个因为特权模式导致的主机重启,不知道能不能解决………)

  1. docker 中的 op,如果访问,性能降低多少,之前公司大佬说过,如果纯计算型了,那么接近无损,但是如果有并发量之类了解,损失可能就在 15 左右,不知道是不是
2315 次点击
所在节点    Linux
7 条回复
liuxu
2021-03-08 00:28:51 +08:00
2-1 是个好问题,值得研究一下,得分析下 cgroup 性能各性能衰减,放到我的代办列表里面了,找时间花个两周搞一搞

解决下你的问题,不要用 docker 跑 openwrt,docker 主要用来跑单进程的,openwrt 是整个系统,建议你用 virtualbox,这样你的所有的问题都不需要解决了
wszgrcy
2021-03-08 08:08:42 +08:00
@liuxu 因为是 arm 架构,所以只能用 docker...本来想写 3 的,好像自动格式化格式错了
yolee599
2021-03-08 08:31:32 +08:00
@wszgrcy OpenWrt 有 x86 版本,可以用 vbox 安装的啊
kele1997
2021-03-08 08:39:39 +08:00
docker 的特权模式应该就是宿主机上的 root 用户吧。普通模式的话就是有个 usermap,容器内的 root 对应外部的普通用户
kele1997
2021-03-08 09:21:38 +08:00
15%的损耗是 docker nat 网络转发端口的损耗,你可以试试 -net=host 物理网络试试(估计就算损耗 15%也没啥影响,反正也跑不满)
wszgrcy
2021-03-08 09:32:03 +08:00
@yolee599 我的意思是,设备是 arm 架构的……😭
yanqiyu
2021-03-08 10:20:47 +08:00
@kele1997 docker 的特权模式对应的不是用户,而是 root capabilities 以及 seccomp 的东西。至少在支持 rootless 之前 docker 是这样做的...你可以通过 docker 里面的 root 用户创建文件,外面看所有者还是 root 。但是要是你通过非特权 docker 里面的进程访问设备,就会被 seccomp 拦下来。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/759405

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX