我们目前正在将厨师用于生产和开发环境。我喜欢docker的概念,它为不同的服务角色启动隔离的容器。我认为在构建开发环境时它会很有用。我有点不清楚如何在生产环境中使用它(或者我应该在生产环境中使用它?)。
在生产环境中,每个服务都已在其专用服务器实例上运行。我认为在容器内运行它们而不是直接在主机操作系统上运行效率很低。
另一方面,如果我们只在开发环境中使用docker,我们最终会编写2份系统配置,一份在docker中,一份在chef中,这也不是理想的。
任何建议或建议都将不胜感激。
答案 0 :(得分:6)
在生产环境中,每个服务都已在其专用服务器实例上运行。我认为在容器内运行它们效率低,而不是直接在主机操作系统上运行。
docker在生产中的优势在于易于部署。为了保持最佳性能,请在每台生产计算机上安装docker,并让每个docker主机只运行一个容器。这样,您的应用就可以像以前一样访问相同数量的系统资源。
为了减少docker可能产生的开销,有一些技巧:
默认情况下,docker会为您的容器创建一个新的网络堆栈,但如果在运行新容器时使用--net=host选项,则容器将使用docker主机网络堆栈。这将使您的容器在网络性能方面没有任何开销。
另请注意,使用--net=host
时,您不需要使用-p
泊坞窗运行选项发布端口,也不需要公开它们。可以在docker host ip上访问容器进程中的任何侦听端口。
与非分层文件系统相比,docker容器文件系统是Union file system,速度很慢。要保持良好的磁盘性能,请确保容器中运行的进程在docker data volume上执行密集的读/写操作。数据卷不是容器分层文件系统的一部分,具有docker主机文件系统的性能。
答案 1 :(得分:1)
Docker实际上非常高效 - 开销并不大,因为它不像虚拟化层,它只是一个拥有自己的命名空间和FS的容器。将相同的设置部署到生产中有几个优点: