Как вы записываете, сколько памяти приложение использует в OS X

Я на Mac Mini с OS X 10.8.2. Я разработчик приложений, но в этом случае я создаю приложение на C++, поэтому я не могу использовать Xcode для этого вопроса. Я хотел бы отследить, сколько памяти использует мое приложение, но я не хочу записывать его вручную. Как мне это сделать.

ДОПОЛНИТЕЛЬНАЯ ИНФОРМАЦИЯ: Я хочу записывать это весь день. Приложение будет работать весь день, чтобы я мог сравнивать пики в памяти. Я не против сторонних приложений, если они надежны. Благодарю.

1 ответ

Решение

Вы должны быть в состоянии сделать это, используя стандартные ps команда. От man ps:

%mem        %MEM      ratio of the process's resident set size  to the physical
                      memory on the machine, expressed as a percentage.  

rss         RSS       resident set size, the non-swapped physical memory that 
                      a task has used (inkiloBytes). 

vsz         VSZ       virtual memory size of the process in KiB (1024byte units).
                      Device mappings are currently excluded; this is subject
                      to change. 

Единственное, что вам нужно, это PID вашего процесса. Итак, если ваше приложение называется myApp, вы можете получить PID следующим образом:

ps x | grep myApp

Который печатает список как это:

15909 pts/3    S      0:37 myApp
22583 pts/6    S+     0:00 grep --color myApp

Первый столбец - это идентификатор процесса (PID). Теперь, если вы хотите автоматизировать это, вам нужно пропустить строку, содержащую команду grep, и сохранить вывод в переменной BASH:

pid=$(ps x | grep myApp | grep -v grep | awk '{print $1}')

awk part заставляет команду печатать только 1-е поле, PID.


Вы можете объединить все это в один слой, который каждую минуту будет экономить использование памяти вашего приложения, в файл с именем memlog.txt:

while sleep 60; do \
    pid=$(ps x | grep myApp | grep -v grep | awk '{print $1}') && \
    ps xo pid,rss,vsz,%mem | grep "$pid" >> memlog.txt ; \
done 
  • while sleep 60 заставляет bash работать в бесконечном цикле, ожидая 60 сек между циклами
  • sleep 60 говорит ему подождать 60 секунд. Измените это значение, если оно требуется для более частого обновления.

Результирующий вывод представляет собой файл (memlog.txt) с 4 столбцами: PID вашего приложения, размер резидентного набора, размер виртуальной памяти и процент памяти. Например:

4166 25240 633028  0.3
4166 25240 633028  0.3
4166 25240 633028  0.3

Это может быть легко расширено, чтобы включить использование процессора и время для каждого измерения. Например, чтобы включить время:

while sleep 60; do \
    date=$(date +%D" "%H:%M:%S);
    echo -n "$date : " >> memlog.txt;
    pid=$(ps x | grep myApp | grep -v grep | awk '{print $1}') && \
    ps xo pid,rss,vsz,%mem | grep "$pid" >> memlog.txt; \
done 
Другие вопросы по тегам