介绍
容器启动后默认会有 64M 的共享内存挂载在/dev/shm 目录,用户可以向访问本地文件系统一样访问该共享内存,如果需要配置更大的内存,那么在docker中需要通过 shm-size 来获取,k8s 中需要通过挂载memory类型的emptyDir来实现。
本文主要介绍如何配置docker 和 k8s 环境的共享内存目录,并加以案例说明。
案例
docker 环境
默认为64M,如下图:
通 shm-size 配置共享内存大小:
docker run -d --name=test --shm-size=500m busybox:1.32 sleep infinity
k8s 环境
配置 emptyDir, medium 为 Memory
apiVersion: v1
kind: Pod
metadata:
name: test-shm
spec:
containers:
- image: busybox:1.32
name: test-container
command: [sh, -c, "sleep infinity" ]
volumeMounts:
- mountPath: /dev/shm
name: cache-volume
volumes:
- name: cache-volume
emptyDir:
medium: Memory
sizeLimit: 500M
如下图,容器中正常申请到了500M的共享内存。
注意:
- k8s 中M 和Mi 的单位是不同的,加i 后是1024 的基数,不加则为1000的基数。
若设置sizeLimit: 500Mi , 那么大小为500M, 如下图:
- k8s 1.22 版本中才比较完整的支持挂载共享内存,即 1.22 及之后的的版本挂载的大小为实际 sizeLimit 的大小, 1.20版本中会出现挂载后实际大小和物理机一样(物理内存一半)的现象。
说明
docs.docker.com/engine/reference/commandline/run/
kubernetes.io/docs/concepts/storage/volumes#emptydir