我正在尝试将ansible
InnoDB 缓冲池大小设置为可用内存的某个百分比。但是ansible_memtotal_mb
并free
报告主机有多少内存。如何计算容器内部有多少可用内存?容器名称事先未知。
UPD我正在运行 debian jessie
,并将cgroup_enable=memory
参数传递给内核。
host
====
# lxc-checkconfig
Kernel configuration not found at /proc/config.gz; searching...
Kernel configuration found at /boot/config-3.16.0-4-amd64
--- Namespaces ---
Namespaces: enabled
Utsname namespace: enabled
Ipc namespace: enabled
Pid namespace: enabled
User namespace: enabled
Network namespace: enabled
Multiple /dev/pts instances: enabled
--- Control groups ---
Cgroup: enabled
Cgroup clone_children flag: enabled
Cgroup device: enabled
Cgroup sched: enabled
Cgroup cpu account: enabled
Cgroup memory controller: enabled
Cgroup cpuset: enabled
--- Misc ---
Veth pair device: enabled
Macvlan: enabled
Vlan: enabled
File capabilities: enabled
Note : Before booting a new kernel, you can check its configuration
usage : CONFIG=/path/to/config /usr/bin/lxc-checkconfig
# grep cgroup /var/lib/lxc/sta/config
lxc.cgroup.memory.limit_in_bytes = 1000M
# mount | grep memory
cgroup on /sys/fs/cgroup/memory type cgroup (rw,nosuid,nodev,noexec,relatime,memory)
# cd /sys/fs/cgroup/memory
# cat memory.limit_in_bytes
18446744073709551615
# cat lxc/sta/memory.limit_in_bytes
1048576000
container
=========
$ cat /proc/self/cgroup
9:perf_event:/lxc/sta
8:blkio:/
7:net_cls,net_prio:/lxc/sta
6:freezer:/lxc/sta
5:devices:/
4:memory:/
3:cpu,cpuacct:/
2:cpuset:/lxc/sta
1:name=systemd:/user.slice/user-0.slice/session-10304.scope/system.slice/ssh.service
# mount | grep memory
cgroup on /sys/fs/cgroup/memory type cgroup (rw,nosuid,nodev,noexec,relatime,memory)
# cd /sys/fs/cgroup/memory
# cat memory.limit_in_bytes
18446744073709551615
# cat lxc/sta/memory.limit_in_bytes
1048576000
答案1
太长了;博士
cat /sys/fs/cgroup/memory$(cat /proc/self/cgroup | grep memory | cut -d: -f3)/memory.limit_in_bytes
或者
cat $(mount | grep cgroup | grep memory | cut -d' ' -f3)$(cat /proc/self/cgroup | grep memory | cut -d: -f3)/memory.limit_in_bytes
如果您的默认容器配置允许来自容器内的主机 cgroup 信息(基于 lxc.mount.auto 设置),您可以简单地解析 cgroup 信息,如下所示
从 /proc/self/cgroup 检查您的 cgroup 信息
root@my-firefox:/# grep memory /proc/self/cgroup
4:memory:/cv/my-firefox
现在根据您的 cgroup 挂载点(可以从 /proc/mounts 找到该挂载点),验证内存限制文件内容
root@my-firefox:/# cd /sys/fs/cgroup/memory/cv/my-firefox/
root@my-firefox:/sys/fs/cgroup/memory/cv/my-firefox# cat memory.limit_in_bytes
268435456
在上面的例子中,cgroup root 被安装在,/sys/fs/cgroup
因此通过该信息和附加路径/memory/cv/my-firefox
,我可以查询为容器设置的所有内存限制
本例限制为256M
PS:free 和 ansible_memtotal_mb 是基于主机的,它们不支持容器。我不知道 ansible,但我认为它会有类似于 puppet 中的事实的东西,您可以在其中编写自定义事实来收集此信息