.\" -*- coding: UTF-8 -*- .\" Copyright (c) 2008, Linux Foundation, written by Michael Kerrisk .\" .\" and Copyright 2003,2004 Andi Kleen, SuSE Labs. .\" numa_maps material Copyright (c) 2005 Silicon Graphics Incorporated. .\" Christoph Lameter, . .\" .\" SPDX-License-Identifier: Linux-man-pages-copyleft .\" .\"******************************************************************* .\" .\" This file was generated with po4a. Translate the source file. .\" .\"******************************************************************* .TH numa 7 "3 апреля 2023 г." "Linux man\-pages 6.05.01" .SH ИМЯ numa \- обзор архитектуры с неравномерной памятью (Non\-Uniform Memory Architecture) .SH ОПИСАНИЕ Неравномерный доступ к памяти (NUMA) приписывают микропроцессорным системам, у которых память разделяется на узлы. Время доступа к узлу памяти зависит от относительного расположения обращающегося ЦП к узлу (в этом отличие от симметричных мультипроцессорных систем, в которых время доступа ко всей памяти одинаково для всех ЦП). Обычно, каждый ЦП в системе NUMA имеет свой локальный узел памяти, чьё содержимое можно получить быстрее, чем из памяти локального узла другого ЦП или из памяти шины, которая доступна для всех ЦП. .SS "Системные вызовы NUMA" В ядре Linux реализованы следующие системные вызовы, относящиеся к NUMA: \fBget_mempolicy\fP(2), \fBmbind\fP(2), \fBmigrate_pages\fP(2), \fBmove_pages\fP(2) и \fBset_mempolicy\fP(2). Однако, приложения, обычно, должны использовать интерфейс, предоставляемый библиотекой \fIlibnuma\fP; смотрите «Поддержка в библиотеках» далее. .SS "\fI/proc/\fPpid\fI/numa_maps\fP (начиная с Linux 2.6.14)" .\" See also Changelog-2.6.14 В этом файле содержится информация о политике и выделении памяти NUMA для процесса. .PP Each line contains information about a memory range used by the process, displaying\[em]among other information\[em]the effective memory policy for that memory range and on which nodes the pages have been allocated. .PP \fInuma_maps\fP is a read\-only file. When \fI/proc/\fPpid\fI/numa_maps\fP is read, the kernel will scan the virtual address space of the process and report how memory is used. One line is displayed for each unique memory range of the process. .PP The first field of each line shows the starting address of the memory range. This field allows a correlation with the contents of the \fI/proc/\fPpid\fI/maps\fP file, which contains the end address of the range and other information, such as the access permissions and sharing. .PP Во втором поле показана политика памяти, которая применена к области в настоящее время. Заметим, что применённая политика необязательно является политикой, установленной процессом для этой области памяти. В частности, если для этой области процесс установил политику «default» (по умолчанию), то применяемая политика для этой области будет политикой процесса, которая может совпадать, а может и не совпадать с «default». .PP В оставшейся части строки содержится информация о страницах, выделенных в области памяти: .TP \fIN<узел>=<кол\-во_страниц>\fP Количество страниц, выделенных на \fI<узле>\fP. В \fI<кол\-во_страниц>\fP учитываются только страницы, отображённые процессом в настоящий момент. Перемещение (migration) страниц и возвращение памяти может приводить к временному неотображению страниц, связанных с этой областью памяти. Такие страницы могут появиться снова только после того, как процесс попытается обратиться к ним. Если область памяти считается общей или является отображением файла, то для других процессов в это же время могут быть показаны дополнительные страницы, отображённые в соответствующее адресное пространство. .TP \fIfile=<имя_файла>\fP Файл, отображаемый в область памяти. Если файл отображён как закрытый (private), попытка записи может сгенерировать страницы COW (копирование при записи) в этой области памяти. Эти страницы показываются как анонимные. .TP \fIheap\fP Область памяти, используемая под кучу. .TP \fIstack\fP Область памяти, используемая под стек. .TP \fIhuge\fP Область огромной памяти. Показывает количество огромных страниц, а не страниц обычного размера. .TP \fIanon=<страниц>\fP Количество анонимных страниц в области. .TP \fIdirty=<страниц>\fP Количество грязных (dirty) страниц. .TP \fImapped=<страниц>\fP Общее количество отображённых страниц, если оно отличается от количества страниц \fIdirty\fP и \fIanon\fP. .TP \fImapmax=<количество>\fP Максимальный mapcount (количество процессов, отображающих одну страницу) обнаруженный при сканировании. Может использоваться как индикатор степени совместного использования заданной области памяти. .TP \fIswapcache=<количество>\fP Количество страниц, связанных с участками на устройстве подкачки. .TP \fIactive=<страниц>\fP Количество страниц в активном списке. Это поле показывается только, если его значение отличается от количества страниц в этой области. Это означает, что в области памяти существует несколько неактивных страниц, которые могут быть скоро удалены swapper. .TP \fIwriteback=<страниц>\fP Количество страниц, которые в настоящий момент записываются на диск. .SH СТАНДАРТЫ None. .SH ЗАМЕЧАНИЯ Системные вызовы Linux NUMA и интерфейс \fI/proc\fP доступны только, если ядро было собрано с включённым параметром \fBCONFIG_NUMA\fP. .SS "Поддержка в библиотеках" Выполняйте компоновку с \fI\-lnuma\fP. Библиотека \fIlibnuma\fP и требуемый заголовочный файл \fI\fP доступны в пакете \fInumactl\fP. .PP Однако, приложения не должны использовать эти системные вызовы напрямую. Вместо этого, рекомендуется использовать интерфейс высокого уровня, предоставляемый функциями \fBnuma\fP(3) из пакета \fInumactl\fP. Пакет \fInumactl\fP доступен по адресу .UR ftp://oss.sgi.com\:/www\:/projects\:/libnuma\:/download/ .UE . Пакет также включён в некоторые дистрибутивы Linux. Некоторые дистрибутивы помещают библиотеку для разработки и заголовочные файлы в пакет \fInumactl\-devel\fP. .SH "СМ. ТАКЖЕ" \fBget_mempolicy\fP(2), \fBmbind\fP(2), \fBmove_pages\fP(2), \fBset_mempolicy\fP(2), \fBnuma\fP(3), \fBcpuset\fP(7), \fBnumactl\fP(8) .PP .SH ПЕРЕВОД Русский перевод этой страницы руководства был сделан Alex Nik , Azamat Hackimov , Dmitry Bolkhovskikh , Yuri Kozlov и Иван Павлов . .PP Этот перевод является бесплатной документацией; прочитайте .UR https://www.gnu.org/licenses/gpl-3.0.html Стандартную общественную лицензию GNU версии 3 .UE или более позднюю, чтобы узнать об условиях авторского права. Мы не несем НИКАКОЙ ОТВЕТСТВЕННОСТИ. .PP Если вы обнаружите ошибки в переводе этой страницы руководства, пожалуйста, отправьте электронное письмо на .MT man-pages-ru-talks@lists.sourceforge.net .ME .