• Runtime constraints on CPU and memory

    Runtime constraints on CPU and memory

    目前相关资料还没有收齐,还在学习之中

    下面的参数可以用来调整container内的性能参数。

    参数 描述
    -m, —memory=”” Memory limit (format: [], where unit = b, k, m or g)
    —memory-swap=”” Total memory limit (memory + swap, format: [], where unit = b, k, m or g)
    -c, —cpu-shares=0 CPU shares (relative weight)
    —cpu-period=0 Limit the CPU CFS (Completely Fair Scheduler) period
    —cpuset-cpus=”” CPUs in which to allow execution (0-3, 0,1)
    —cpuset-mems=”” Memory nodes (MEMs) in which to allow execution (0-3, 0,1). Only effective on NUMA systems.
    —cpu-quota=0 Limit the CPU CFS (Completely Fair Scheduler) quota
    —blkio-weight=0 Block IO weight (relative weight) accepts a weight value between 10 and 1000.
    —oom-kill-disable=false Whether to disable OOM Killer for the container or not.
    —memory-swappiness=”” Tune a container’s memory swappiness behavior. Accepts an integer between 0 and 100.

    通过docker run -m 可以很方便的调整container所使用的内存资源。如果host支持swap内存,那么使用-m可以设定比host物理内存还大的值。

    同样,通过-c 可以调整container的cpu优先级。默认情况下,所有的container享有相同的cpu优先级和cpu调度周期。但你可以通过Docker来通知内核给予某个或某几个container更多的cpu计算周期。

    默认情况下,使用-c或者—cpu-shares 参数值为0,可以赋予当前活动container 1024个cpu共享周期。这个0值可以针对活动的container进行修改来调整不同的cpu循环周期。

    比如,我们使用-c或者—cpu-shares =0启动了C0,C1,C2三个container,使用-c/—cpu-shares=512启动了C3.这时,C0,C1,C2可以100%的使用CPU资源(1024),但C3只能使用50%的CPU资源(512)。如果这个host的OS是时序调度类型的,每个CPU时间片是100微秒,那么C0,C1,C2将完全使用掉这100微秒,而C3只能使用50微秒。