如何启用Google容器优化操作系统交换限制支持

时间:2018-03-13 19:25:47

标签: docker linux-kernel kubernetes out-of-memory google-container-os

我在GCE实例上的Google Container Optimized OS上运行Kubernetes / Docker。当我运行docker info时,它说

$ docker info
Containers: 116
 Running: 97
 Paused: 0
 Stopped: 19
Images: 8
Server Version: 1.11.2
Storage Driver: overlay
 Backing Filesystem: extfs
Logging Driver: json-file
Cgroup Driver: cgroupfs
Plugins: 
 Volume: local
 Network: null host bridge
Kernel Version: 4.4.21+
Operating System: Container-Optimized OS from Google
OSType: linux
Architecture: x86_64
CPUs: 4
Total Memory: 14.67 GiB
Name: REDACTED
ID: REDACTED
Docker Root Dir: /var/lib/docker
Debug mode (client): false
Debug mode (server): false
Registry: https://index.docker.io/v1/
WARNING: No swap limit support

最后一行表示没有交换限制支持。我无法弄清楚如何启用交换限制支持。我找到了Ubuntu / Debian here的说明。

我的问题是我的docker容器一旦达到内存限制就会获得OOMKilled,而不是尝试交换。我希望容器使用swap作为缓冲区而不是立即死亡。

1 个答案:

答案 0 :(得分:1)

容器优化的OS(COS)实际上是在完全禁用交换的情况下配置的。您可以通过在COS VM中运行cat /proc/meminfo | grep SwapTotal来验证这一点,它将显示它已配置为0 kB。

我不确定在您的环境中启用交换是否是一个好主意,因为如果您频繁使用交换,这可能会引起更多问题(例如,磁盘IO饥饿/减速,内核挂起)。

但是,如果您想尝试一下,这些命令可能会对您有所帮助(以root用户身份运行所有命令):

cos-swap / # sysctl vm.disk_based_swap=1
vm.disk_based_swap = 1
cos-swap / # fallocate -l 1G /var/swapfile
cos-swap / # chmod 600 /var/swapfile
cos-swap / # mkswap /var/swapfile
Setting up swapspace version 1, size = 1024 MiB (1073737728 bytes)
no label, UUID=406d3dfc-3780-44bf-8add-d19a24fdbbbb
cos-swap / # swapon /var/swapfile
cos-swap / # cat /proc/meminfo | grep Swap
SwapCached:            0 kB
SwapTotal:       1048572 kB
SwapFree:        1048572 kB