在OpenVZ VPS上安装Docker

我有一个OpenVZ VPS,操作系统是CentOS 6,我尝试安装Docker,但是Docker启动错误.

Starting cgconfig service: Error: cannot mount cpuset to /cgroup/cpuset: Invalid argument
/sbin/cgconfigparser; error loading /etc/cgconfig.conf: Cgroup mounting failed
Failed to parse /etc/cgconfig.conf or /etc/cgconfig.d      [FAILED]
Starting docker:                                           [  OK  ]
2016年12月更新.我尽量不复制@Alien Life Form答案,但添加了更多细节.

简短回答:

在大多数情况下,OpenVZ托管将使用OpenVZ 6与过时的内核,这与Docker不兼容.

Docker仅支持OpenVZ 7(基于3.x内核,参见https://openvz.org/Docker_inside_CT_vz7)或OpenVZ 6支持内核版本042stab105.4或更新版本(参见https://openvz.org/Docker_inside_CT).

答案很长:

Docker需要Linux内核的两个功能才能运行:控制组和命名空间.所以你需要一个具有这些功能的内核.

使用OpenVZ,您无法控制内核,只有托管公司才能控制您的内核.大多数托管公司都不会协作和更新内核,所以如果内核变得不兼容,你通常会运气不好.

OpenVZ 7基于3.10内核,支持开箱即用的Docker,但我还没有看到OpenVZ 7托管 – KVM似乎是最受欢迎的虚拟化,新的低成本提供商进入市场.

OpenVZ 6在较旧的提供程序中更常见,并且基于2.6内核,通常与Docker不兼容.但是,OpenVZ内核不是普通的2.6内核,而是从3.x内核向后移植的功能很少.所以事实上内核042stab105.4及更高版本支持Docker根据官方OpenVZ wiki所需的功能(参见@Alien Life Form答案).

以下文本仅适用于OpenVZ版本6.

如果uname -a显示内核042stab105.4或更高版本 – 您可以使用Docker进行一些调整来安装所需的特殊文件系统.

如果它更老并且公司愿意合作,他们就无法安装主线内核,因为它与OpenVZ不兼容.他们必须在https://openvz.org/Download/kernel安装一个包含OpenVZ补丁的特殊内核.最好是最新的稳定版本(写入时为042stab120.11),但至少为042stab105.4.相比之下,我见过的所有OpenVZ主机都有类似2.6.32-042stab075.2的东西,它不仅与Docker不兼容,而且容易受到攻击.所以你可以尝试使用漏洞参数来强制支持升级:)

另一个显而易见但并不总是适用的解决方案是使用其他虚拟化技术(如Xen或KVM)从OpenVZ转移到托管.但是,主线CentOS 6内核可能没有必要的功能,因此当使用非库存补丁内核运行时,CentOS 6只能与Docker兼容.所以你也可以考虑转移到CentOS 7.

转载注明原文:在OpenVZ VPS上安装Docker - 代码日志