Docker使用gosu与USER
Docker总是有一个USER命令来作为一个特定的用户运行一个进程,但是一般来说,很多事情都不得不以ROOT运行. 我看到很多图像,使用一个ENTRYPOINT与gosu来取消提升运行的过程. 我对gosu的需要还有点困惑.用户不应该不够用吗 我在Docker 1.10的安全性方面有所改变,但是我仍然不清楚在Docker容器中运行流程的推荐方法. 有人可以解释何时使用gosu vs. USER? 谢谢 编辑: Docker best practice guide不是很清楚:它说如果进程可以无需运行,可以使用USER,如果需要sudo,可能需要使用gosu. 最佳答案
Docker文件用于创建图像.当您不能再在Docker文件中的运行命令之间更改用户时,我将gosu视为容器初始化的一部分.
图像创建后,像gosu这样的东西可以让您在容器内的entrypoint的末尾删除root权限.您最初可能需要root访问来执行一些初始化步骤(修复uid,主机挂载卷权限等).然后一旦初始化,您运行最终服务没有root权限和pid 1来干净地处理信号. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |