Читаем Linux API. Исчерпывающее руководство полностью

• Результаты открытия файла в режиме O_RDONLY зависят от того, какой флаг был указан при вызове mmap() — MAP_PRIVATE или MAP_SHARED. В первом случае mmap() поддерживает любые комбинации защиты памяти, поскольку изменения приватной страницы все равно никогда не записываются в исходный файл. Во втором случае с режимом O_RDONLY совместима только защита PROT_READ (PROT_READ | PROT_EXEC). Это логично, ведь защита PROT_WRITE позволяет обновлять отображенный файл.

45.5. Синхронизация отображенного участка памяти: msync()

Ядро автоматически возвращает изменения содержимого отображения типа MAP_SHARED обратно в исходный файл, но по умолчанию нет никаких гарантий относительно того, когда именно произойдет такая синхронизация (стандарт SUSv3 этого не требует).

Системный вызов msync() предоставляет приложению возможность самостоятельно синхронизировать разделяемое отображение с отображенным файлом. Это может пригодиться в разнообразных ситуациях. Например, чтобы гарантировать целостность информации, база данных может сбрасывать изменения на диск с помощью msync(). Выполняя данный вызов, мы делаем обновления изменяемого отображения видимыми для других процессов, которые считывают исходный файл.

#include

int msync(void *addr, size_t length, int flags);

Возвращает 0 при успешном завершении или -1 при ошибке

Аргументы addr и length вызова msync() обозначают начальный адрес и размер участка памяти, который нужно синхронизировать. Адрес должен быть выровнен по странице, а длина округлена до следующего кратного размеру страницы в системе (в стандарте SUSv3 требование к выравниванию является обязательным; в SUSv4 всего лишь предусмотрена такая возможность).

Аргумент flags может принимать одно из следующих значений:

• MS_SYNC — выполняет синхронную запись в файл. Вызов блокируется, пока все измененные страницы участка памяти не будут записаны на диск;

• MS_ASYNC — выполняет асинхронную запись в файл. Измененные страницы участка памяти записываются на диск не сразу, но немедленно становятся видимыми для других процессов, выполняющих операцию read() для соответствующего участка файла.

Различия между этими двумя значениями можно сформулировать иначе: после операции MS_SYNC участок памяти синхронизирован с диском, тогда как после MS_ASYNC — только с кэшем буфера ядра.

Если после операции MS_ASYNC не предпринять никаких дополнительных действий, то измененные страницы на участке памяти в какой-то момент будут автоматически сброшены на диск потоком выполнения ядра pdflush (в Linux 2.4 и более ранних версиях он назывался kupdated). В Linux существует два (нестандартных) метода ускорить вывод. Вслед за msync() можно сделать вызов fsync() (или fdatasync()), указав дескриптор соответствующего отображения. Данный вызов блокируется до тех пор, пока кэш буфера не будет синхронизирован с диском. Как вариант можно инициировать асинхронную запись страниц с помощью операции posix_fadvise() POSIX_FADV_DONTNEED (в Linux эти два случая имеют некоторые особенности, не описанные в стандарте SUSv3).

В аргументе flags можно указать еще одно дополнительное значение. MS_INVALIDATE — удаляет кэшированные копии отображенных данных. После сброса на диск любых измененных страниц участка памяти те из них, что не соответствуют исходному файлу, помечаются как недействительные. При следующем обращении в них будут скопированы соответствующие участки файла. Как следствие, любые изменения, внесенные в файл другим процессом, становятся доступными на участке памяти.

Как и многие другие современные реализации UNIX, Linux предоставляет так называемую систему унифицированной виртуальной памяти. Это значит, что по возможности отображения и блоки буферного кэша разделяют одни и те же страницы физической памяти. Таким образом обеспечивается связность данных, получаемых через отображение и системные вызовы ввода/вывода (read(), write() и т. д.), а msync() используется только для принудительного сброса содержимого отображенного участка на диск.

Однако система унифицированной виртуальной памяти не предусмотрена стандартом SUSv3 и присутствует не во всех UNIX-системах. В таких реализациях, чтобы сделать видимыми изменения содержимого отображения для других процессов, читающих файл, необходимо выполнить вызов msync(). И наоборот, чтобы запись в файл, выполненная другим процессом, стала доступной на отображенном участке памяти, необходимо использовать флаг MS_INVALIDATE. Многопроцессные приложения, в которых для работы с одним и тем же файлом применяются как mmap(), так и системные вызовы ввода/вывода, должны корректно выполнять операцию msync(), иначе их нельзя будет перенести в системы, не поддерживающие систему унифицированной виртуальной памяти.

45.6. Дополнительные флаги вызова mmap()
Перейти на страницу:

Похожие книги

1С: Бухгалтерия 8 с нуля
1С: Бухгалтерия 8 с нуля

Книга содержит полное описание приемов и методов работы с программой 1С:Бухгалтерия 8. Рассматривается автоматизация всех основных участков бухгалтерии: учет наличных и безналичных денежных средств, основных средств и НМА, прихода и расхода товарно-материальных ценностей, зарплаты, производства. Описано, как вводить исходные данные, заполнять справочники и каталоги, работать с первичными документами, проводить их по учету, формировать разнообразные отчеты, выводить данные на печать, настраивать программу и использовать ее сервисные функции. Каждый урок содержит подробное описание рассматриваемой темы с детальным разбором и иллюстрированием всех этапов.Для широкого круга пользователей.

Алексей Анатольевич Гладкий

Программирование, программы, базы данных / Программное обеспечение / Бухучет и аудит / Финансы и бизнес / Книги по IT / Словари и Энциклопедии
1С: Управление торговлей 8.2
1С: Управление торговлей 8.2

Современные торговые предприятия предлагают своим клиентам широчайший ассортимент товаров, который исчисляется тысячами и десятками тысяч наименований. Причем многие позиции могут реализовываться на разных условиях: предоплата, отсрочка платежи, скидка, наценка, объем партии, и т.д. Клиенты зачастую делятся на категории – VIP-клиент, обычный клиент, постоянный клиент, мелкооптовый клиент, и т.д. Товарные позиции могут комплектоваться и разукомплектовываться, многие товары подлежат обязательной сертификации и гигиеническим исследованиям, некондиционные позиции необходимо списывать, на складах периодически должна проводиться инвентаризация, каждая компания должна иметь свою маркетинговую политику и т.д., вообщем – современное торговое предприятие представляет живой организм, находящийся в постоянном движении.Очевидно, что вся эта кипучая деятельность требует автоматизации. Для решения этой задачи существуют специальные программные средства, и в этой книге мы познакомим вам с самым популярным продуктом, предназначенным для автоматизации деятельности торгового предприятия – «1С Управление торговлей», которое реализовано на новейшей технологической платформе версии 1С 8.2.

Алексей Анатольевич Гладкий

Финансы / Программирование, программы, базы данных