栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 运维 > Linux

k8s笔记15--配置共享内存

Linux 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

k8s笔记15--配置共享内存

k8s笔记15--配置共享内存
  • 介绍
  • 案例
    • docker 环境
    • k8s 环境
  • 说明

介绍

容器启动后默认会有 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的共享内存。

注意:

  1. k8s 中M 和Mi 的单位是不同的,加i 后是1024 的基数,不加则为1000的基数。
    若设置sizeLimit: 500Mi , 那么大小为500M, 如下图:
  2. k8s 1.22 版本中才比较完整的支持挂载共享内存,即 1.22 及之后的的版本挂载的大小为实际 sizeLimit 的大小, 1.20版本中会出现挂载后实际大小和物理机一样(物理内存一半)的现象。
说明

docs.docker.com/engine/reference/commandline/run/
kubernetes.io/docs/concepts/storage/volumes#emptydir

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/838664.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号