Как я могу контролировать использование памяти?

Я использовал top, чтобы увидеть использование памяти на данный момент. Но я хотел бы контролировать использование памяти в течение определенного периода времени. Например, запустите мониторинг, затем выполните несколько команд и, наконец, остановите мониторинг и посмотрите, сколько памяти было использовано за период.

Как я могу сделать это на Ubuntu Server?

Я думаю, я мог бы запускать cronjob примерно каждые 5 секунд и вызывать команду, которая регистрирует текущее использование памяти в текстовом файле. Но какую команду я должен использовать, чтобы получить текущее использование памяти в формате, который легко записать в текстовый файл?

267
задан 26 October 2010 в 22:20

12 ответов

Я рекомендую объединить предыдущие ответы

watch -n 5 free -m

Обратите внимание, что Linux любит использовать любую дополнительную память для кэширования блоков жесткого диска . Так что вы не хотите смотреть только на бесплатное Mem. Вы хотите взглянуть на столбец free строки -/+ buffers/cache:. Это показывает, сколько памяти доступно приложениям. Итак, я просто запустил free -m и получил это:

             total       used       free     shared    buffers     cached
Mem:          3699       2896        802          0        247       1120
-/+ buffers/cache:       1528       2170
Swap:         1905         62       1843

Я знаю, что я использую 1528 МБ и у меня есть 2170 МБ бесплатно.

Примечание: Чтобы остановить этот watch цикл, вы можете просто нажать Ctrl + C .

0
ответ дан 26 October 2010 в 22:20

Я думаю, что htop является лучшим решением.

  • sudo apt-get install htop

Таким образом, вы заметите, какие программы используют больше всего оперативной памяти. и вы можете легко прекратить один, если хотите. Вот скриншот!

0
ответ дан 26 October 2010 в 22:20

Если вам нужна хорошая разбивка памяти, используемой каждым запущенным процессом, я мог бы рекомендовать проверить ps_mem.py (найдено здесь на pixelbeat.org). 112]

Я знаю, что в комментариях выше вы упомянули, что хотите получить снимок из одной строки из free , но я подумал, что другие могут найти это полезным.

Пример вывода:

user@system:~$ sudo ps_mem.py
[sudo] password for user:
 Private  +   Shared  =  RAM used       Program

  4.0 KiB +   7.5 KiB =  11.5 KiB       logger
  4.0 KiB +   8.0 KiB =  12.0 KiB       mysqld_safe
  4.0 KiB +  10.0 KiB =  14.0 KiB       getty
  4.0 KiB +  42.0 KiB =  46.0 KiB       saslauthd (5)
 48.0 KiB +  13.0 KiB =  61.0 KiB       init
 56.0 KiB +  27.5 KiB =  83.5 KiB       memcached
 84.0 KiB +  26.5 KiB = 110.5 KiB       cron
120.0 KiB +  50.0 KiB = 170.0 KiB       master
204.0 KiB + 107.5 KiB = 311.5 KiB       qmgr
396.0 KiB +  94.0 KiB = 490.0 KiB       tlsmgr
460.0 KiB +  65.0 KiB = 525.0 KiB       rsyslogd
384.0 KiB + 171.0 KiB = 555.0 KiB       sudo
476.0 KiB +  83.0 KiB = 559.0 KiB       monit
568.0 KiB +  60.0 KiB = 628.0 KiB       freshclam
552.0 KiB + 259.5 KiB = 811.5 KiB       pickup
  1.1 MiB +  80.0 KiB =   1.2 MiB       bash
  1.4 MiB + 308.5 KiB =   1.7 MiB       fail2ban-server
888.0 KiB +   1.0 MiB =   1.9 MiB       sshd (3)
  1.9 MiB +  32.5 KiB =   1.9 MiB       munin-node
 13.1 MiB +  86.0 KiB =  13.2 MiB       mysqld
147.4 MiB +  36.5 MiB = 183.9 MiB       apache2 (7)
---------------------------------
                        208.1 MiB
=================================

 Private  +   Shared  =  RAM used       Program

Единственная часть, которая мне не нравится, это тот факт, что скрипт утверждает, что требует привилегий root. У меня еще не было возможности точно понять, почему это так.

0
ответ дан 26 October 2010 в 22:20

Однолинейное решение и вывод:

free -m | grep "Mem:"

Вот пример ожидаемого вывода:

Mem:           3944         652         302          18        2990        2930
0
ответ дан 26 October 2010 в 22:20

Вы можете сделать это, используя cat /proc/meminfo.

MemTotal:        4039160 kB
MemFree:          309796 kB
MemAvailable:    3001052 kB
Buffers:          345636 kB
Cached:          2341288 kB
SwapCached:            8 kB
Active:          1725160 kB
Inactive:        1551652 kB
Active(anon):     538404 kB
Inactive(anon):    70076 kB
Active(file):    1186756 kB
Inactive(file):  1481576 kB
Unevictable:          32 kB
Mlocked:              32 kB
SwapTotal:       4194300 kB
SwapFree:        4194044 kB
Dirty:                 0 kB
Writeback:             0 kB
AnonPages:        589988 kB
Mapped:           255972 kB
Shmem:             18596 kB
Slab:             374888 kB
SReclaimable:     310496 kB
SUnreclaim:        64392 kB
KernelStack:        6976 kB
PageTables:        26452 kB
NFS_Unstable:          0 kB
Bounce:                0 kB
WritebackTmp:          0 kB
CommitLimit:     6213880 kB
Committed_AS:    3589736 kB
VmallocTotal:   34359738367 kB
VmallocUsed:           0 kB
VmallocChunk:          0 kB
HardwareCorrupted:     0 kB
AnonHugePages:         0 kB
ShmemHugePages:        0 kB
ShmemPmdMapped:        0 kB
CmaTotal:              0 kB
CmaFree:               0 kB
HugePages_Total:       0
HugePages_Free:        0
HugePages_Rsvd:        0
HugePages_Surp:        0
Hugepagesize:       2048 kB
DirectMap4k:      147392 kB
DirectMap2M:     4046848 kB
0
ответ дан 26 October 2010 в 22:20

Может быть полезна команда watch . Попробуйте watch -n 5 free отслеживать использование памяти с обновлениями каждые пять секунд.

0
ответ дан 26 October 2010 в 22:20

Для визуального мониторинга общего использования оперативной памяти, если вы используете Byobu , он будет хранить ваше использование памяти в правом нижнем углу терминала и будет работать, пока вы находитесь в любом терминальном сеансе. [ 112]

Как вы можете видеть из скриншота, моя виртуальная машина имеет время безотказной работы 1х3 м, нагрузку 0,00, 2,8 ГГц (виртуальный) процессор и 994 МБ (21%) оперативной памяти, доступной в системе.

Byobu in use

0
ответ дан 26 October 2010 в 22:20

Я бы использовал Кактусы . Это будет отображать график использования памяти и т. Д. За определенный период времени, и вы сможете проверить использование с помощью своего веб-браузера.

0
ответ дан 26 October 2010 в 22:20

Мониторинг использования памяти

Я больше согласен с одним из предыдущих постов, которые упоминали Cacti как отличный способ контролировать использование памяти. Однако, поскольку кажется, что кактусы больше не популярны в мейнстриме, есть альтернативное графическое приложение под названием Graphite.

Графит относительно легко установить на сервере Ubuntu, и для его установки вы можете проверить эту ссылку , чтобы узнать о простых процедурах установки.

После того, как графит был установлен, теперь вы можете отправлять ему метрики памяти с любым интервалом, который пожелаете; каждые 5 секунд, каждую минуту, каждый час ... и т. д.

Для отображения метрик памяти, как уже предлагалось в предыдущих статьях, вы можете написать свой собственный скрипт, используя системные инструменты для сбора необходимой информации о памяти. Или вы можете использовать заранее написанный плагин snmp, который сделает всю работу за вас.

Если вы хотите написать свой собственный скрипт памяти, будет разумно обеспечить учет буферизованной и кэшированной памяти при расчете используемой памяти, в противном случае вы в конечном итоге соберете ложные данные.

Если вы хотите вместо этого использовать плагин snmp, который уже выполняет все необходимые вычисления, вот ссылка на тот, который работает довольно хорошо: checkMemoryviaSNMP .

Плюсы SNMP:

У меня установлен snmp на всех удаленных узлах, которые я наблюдаю. Это позволяет мне контролировать все мои системы с одного центрального сервера (ов) , без необходимости копировать или устанавливать плагин на удаленных узлах.

Минусы SNMP:

Необходимо убедиться, что агент snmp установлен на каждом из удаленных узлов, которые вы хотите контролировать память на. Тем не менее, эта установка будет разовой. Если в вашей среде вы используете инструменты автоматизации, такие как «повар», «марионетка» или аналогичные, тогда это не проблема.

Конфигурация агента SNMP на удаленном узле (ах):

После установки агента snmp просто скопируйте файл /etc/snmpd/snmpd.conf и добавьте эта строка к нему:

rocommunity  (specify-a-community-string-aka-password-here)

Затем перезапустите агент snmpd с помощью:

/etc/init.d/snmpd restart

Затем, на вашем центральном сервере, с которого вы вместо этого будете контролировать все остальные ваши серверы, вы может выполнить следующую команду:

$ time ./checkMemoryviaSNMP -v2 public gearman001.phs.blah.com 30 90 graphite,10.10.10.10,2003,typical
WARNING: Used = [ 3.26154 GB ], Installed = [ 5.71509 GB ], PCT.Used = [ 57.069% ], Available.Memory = [ 2.00291 GB ]. Buffer = [ 137.594 MB ], Cached = [ 1.3849 GB ]. Thresholds: [ W=(30%) / C=(90%) ].  System Information = [ Linux gearman001.phs.blah.com 2.6.32-504.30.3.el6.x86_64 #1 SMP Thu Jul 9 15:20:47 EDT 2015 x86_64 ].

real    0m0.23s
user    0m0.03s
sys     0m0.02s
0
ответ дан 26 October 2010 в 22:20

Используйте команду free . Например, это вывод free -m:

             total       used       free     shared    buffers     cached
Mem:          2012       1666        345          0        101        616
-/+ buffers/cache:        947       1064
Swap:         7624          0       7624

free -m | grep /+ вернет только вторую строку:

-/+ buffers/cache:        947       1064
0
ответ дан 26 October 2010 в 22:20

взгляды - еще один прекрасный вариант, который стоит попробовать. Просто установите pip Glances или загрузите с здесь

0
ответ дан 20 March 2020 в 08:36

Я только что нашел это решение, и оно работает очень хорошо, создавая графический интерфейс через CLI:

# fixed link
git clone https://github.com/aristocratos/bashtop
cd bashtop
bash bashtop

Screenshot

5
ответ дан 26 April 2020 в 23:52

Другие вопросы по тегам:

Похожие вопросы: