FreeBSD является многозадачной операционной системой. Это означает, что одновременно
может быть запущена более чем одна программа. Каждая программа, работающая в некоторый
момент времени, называется процессом. Каждая команда, которую вы
запускаете, порождает хотя бы один процесс. Есть несколько системных процессов,
запущенных все время и поддерживающих функциональность системы.
У каждого процесса есть уникальный номер, называемый process
ID, или PID, и, как и у файлов, у каждого процесса есть
владелец и группа. Информация о владельце и группе процесса используется для определения
того, какие файлы и устройства могут быть открыты процессом с учетом прав на файлы, о
которых говорилось ранее. Также у большинства процессов есть родительский процесс.
Например, при запуске команд из оболочки, оболочка является процессом и любая запущенная
команда также является процессом. Для каждого запущенного таким путем процесса оболочка
будет являться родительским процессом. Исключением из этого правила является специальный
процесс, называемый init(8). init всегда первый процесс, его PID всегда 1. init запускается автоматически ядром во время загрузки FreeBSD.
Две команды очень полезны для просмотра работающих в системе процессов, это ps(1) и top(1). Команда ps используется для получения списка запущенных процессов и может
показать их PID, сколько памяти они используют, команду которой они были запущены и т.д.
Команда top показывает запущенные процессы и обновляет экран
каждые несколько секунд, что позволяет наблюдать за работой компьютера в реальном
времени.
По умолчанию, ps показывает только принадлежащие вам
процессы. Например:
% ps
PID TT STAT TIME COMMAND
298 p0 Ss 0:01.10 tcsh
7078 p0 S 2:40.88 xemacs mdoc.xsl (xemacs-21.1.14)
37393 p0 I 0:03.11 xemacs freebsd.dsl (xemacs-21.1.14)
48630 p0 S 2:50.89 /usr/local/lib/netscape-linux/
navigator-linux-4.77.bi
48730 p0 IW 0:00.00 (dns helper) (navigator-linux-)
72210 p0 R+ 0:00.00 ps
390 p1 Is 0:01.14 tcsh
7059 p2 Is+ 1:36.18 /usr/local/bin/mutt -y
6688 p3 IWs 0:00.00 tcsh
10735 p4 IWs 0:00.00 tcsh
20256 p5 IWs 0:00.00 tcsh
262 v0 IWs 0:00.00 -tcsh (tcsh)
270 v0 IW+ 0:00.00 /bin/sh /usr/X11R6/bin/startx -- -bpp 16
280 v0 IW+ 0:00.00 xinit /home/nik/.xinitrc -- -bpp 16
284 v0 IW 0:00.00 /bin/sh /home/nik/.xinitrc
285 v0 S 0:38.45 /usr/X11R6/bin/sawfish
Как вы можете видеть в данном примере, вывод ps(1) организован в
несколько колонок. Идентификатор процесса PID обсуждался
ранее. PID назначаются с 1 до 99999 и опять с начала, если последнее число будет
превышено. Колонка TT показывает терминал (tty), на котором
запущена программа (можете пока забыть про это). STAT
показывает состояние программы и опять же может быть пока проигнорирован. TIME это количество времени центрального процессора, использованное
программой -- это обычно не время, прошедшее с запуска программы, поскольку большинство
программы проводят много времени в в ожидании некоторого события перед тем, как занять
время процессора. Наконец, COMMAND это команда, которой
программа была запущена.
У ps(1) есть множество
различных опций, влияющих на выводимую информацию. Один из наиболее полезных наборов
опций это auxww. a позволяет
показать информацию о всех запущенных процессах, а не только тех, которыми вы владеете.
u показывает имя пользователя, владеющего процессом, и
информацию об используемой памяти. x показывает информацию о
процессах-даемонах и ww указывает ps(1) показать всю
командную строку, вместо обрезания ее, когда она станет слишком длинной, чтобы уместиться
на экран.
Вывод top(1) похож на только
что описанный. Обычно он выглядит так:
% top
last pid: 72257; load averages: 0.13, 0.09, 0.03
up 0+13:38:33 22:39:10
47 processes: 1 running, 46 sleeping
CPU states: 12.6% user, 0.0% nice, 7.8% system, 0.0% interrupt, 79.7% idle
Mem: 36M Active, 5256K Inact, 13M Wired, 6312K Cache, 15M Buf, 408K Free
Swap: 256M Total, 38M Used, 217M Free, 15% Inuse
PID USERNAME PRI NICE SIZE RES STATE TIME WCPU CPU COMMAND
72257 nik 28 0 1960K 1044K RUN 0:00 14.86% 1.42% top
7078 nik 2 0 15280K 10960K select 2:54 0.88% 0.88% xemacs-21.1.14
281 nik 2 0 18636K 7112K select 5:36 0.73% 0.73% XF86_SVGA
296 nik 2 0 3240K 1644K select 0:12 0.05% 0.05% xterm
48630 nik 2 0 29816K 9148K select 3:18 0.00% 0.00% navigator-linu
175 root 2 0 924K 252K select 1:41 0.00% 0.00% syslogd
7059 nik 2 0 7260K 4644K poll 1:38 0.00% 0.00% mutt
...
Вывод разбит на два раздела. Заголовок (первые пять строк) показывает PID последнего
запущенного процесса, среднее значение загрузки системы (которое показывает насколько
система занята), время работы системы с последней перезагрузки и текущее время. Другие
цифры заголовка относятся к количеству запущенных процессов (в данном примере 47),
количеству занятой памяти и подкачки и время, занимаемое различными состояниями
процессора.
Ниже идут несколько колонок, содержащих похожую на вывод ps(1) информацию. Как
и раньше, это PID, время процессора, командная строка. top(1) показывает
также величину занятой процессом памяти. Это значение разбито на две колонки, одна для
общего объема, а другая для резидентного -- общий объем показывает сколько всего памяти
нужно приложению, а резидентный показывает количество памяти, используемой в данный
момент. Из этого примера видно, что Netscape® требует почти 30 MB памяти, но в данный
момент использует только 9 MB.
top(1) автоматически
обновляет экран каждые две секунды; это значение можно изменить опцией s.