Литмир - Электронная Библиотека
Содержание  
A
A

 return(1);

}

5. Для сохранения совместимости с файлом pipe_imp.c необходимо объявить четыре дополнительные функции. Но в вашей программе они будут пустыми. Операции, которые они реализовывали в случае применения каналов, больше не нужны.

int start_resp_to_client(const message_db_t mess_to_send) {

 return(1);

}

void end_resp_to_client(void) {}

int start_resp_from_server(void) {

 return(1);

}

void end_resp_from_server(void) {}

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

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

Команды состояния IPC

Несмотря на то, что для соответствия требованиям X/Open этого не требуется, большинство систем Linux предоставляет набор команд, обеспечивающих доступ к данным IPC в режиме командной строки и удаление потерянных средств IPC. Существуют команды

ipcs
и
ipcrm
, очень полезные при разработке программ.

Один из досадных недостатков средств IPC состоит в том, что плохо написанная программа или программа, по какой-либо причине завершившаяся аварийно, может оставить свои ресурсы IPC (например, данные в очереди сообщений) еще долго блуждающими в системе без определенной цели после завершения программы. Такое поведение может привести к аварийному завершению нового запуска программы, поскольку она рассчитывает начать выполнение в очищенной системе, а на самом деле находит эти блуждающие ресурсы. Команды состояния (

ipcs
) и удаления (
ipcrm
) позволяют проверить систему и очистить ее от ненужных средств IPC.

Отображение состояния семафора

Для проверки состояния семафоров в системе примените команду

ipcs -s
. Если какие-то семафоры присутствуют, вывод команды будет выглядеть следующим образом:

$ <b>ipcs -s</b>

------ Semaphore Arrays ------

key        semid owner perms nsems

0x4d00df1a 768   rick  666   1

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

ipcrm
. Для удаления только что отображенного семафора примените (в Linux) следующую команду:

$ <b>ipcrm -s 768</b>

В некоторых более старых системах Linux используется несколько иной синтаксис команды:

$ <b>ipcrm sem 768</b>

Но этот устаревший стиль редко встречается в наше время. Формат, подходящий для вашей конкретной системы, ищите на страницах интерактивного справочного руководства.

Отображение состояния совместно используемой памяти

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

ipcs -m
и
ipcrm -m &lt;<i>id</i>&gt;
(или
ipcrm shm &lt;<i>id</i>&gt;
).

Далее приведен пример вывода команды

ipcs -m
:

$ <b>ipcs -m</b>

------ Shared Memory Segments ------

key        shmid owner perms bytes nattch status

0x00000000 384   rick  666   4096  2      dest

Здесь показан единственный сегмент совместно используемой памяти объемом 4 Кбайт, присоединенный к двум процессам.

Команда

ipcrm -m &lt;<i>id</i>&gt;
позволяет удалить совместно используемую память. Она бывает полезной, когда программа завершается аварийно при попытке убрать такую память.

Отображение состояния очереди сообщений

Для очередей сообщений предназначены команды

ipcs -q
и
ipcrm -q &lt;<i>id</i>
> (или
ipcrm msg &lt;<i>id</i>&gt;
).

Далее приведен пример вывода команды

ipcs -q
:

$ <b>ipcs -q</b>

------ Message Queues ------

key        msqid owner perms used-bytes messages

0x000004d2 3384  rick  666   2048       2

В нем показаны в очереди сообщений два сообщения общим объемом 2048 байтов. Команда

ipcrm -q &lt;<i>id</i>&gt;
позволяет удалить очередь сообщений.

Резюме

В этой главе вы познакомились с тремя разновидностями средств взаимосвязи процессов, которые стали широко применяться в ОС UNIX System V.2 и были доступны в системе Linux, начиная с ранних версий ее дистрибутивов. Вы рассмотрели предлагаемые ими сложные функциональные возможности и, после того как поняли принципы их функционирования, оценили обеспечиваемое ими эффективное решение для удовлетворения многих потребностей межпроцессного взаимодействия. 

Глава 15

Сокеты

В этой главе вы познакомитесь с еще одним способом взаимодействия процессов, существенно отличающимся от тех, которые мы обсуждали в главах 13 и 14. До настоящего момента все рассматриваемые нами средства основывались на совместно используемых ресурсах одного компьютера. Ресурсы могли быть разными: областью файловой системы, сегментами совместно используемой памяти или очередями сообщений, но использовать их могли только процессы, выполняющиеся на одной машине.

В версию ОС Berkeley UNIX было включено новое средство коммуникации — интерфейс сокетов, — являющееся расширением концепции канала, обсуждавшейся в главе 13. В системах Linux также есть интерфейсы сокетов.

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

Кроме того, интерфейс сокетов стал доступен в ОС Windows благодаря общедоступной спецификации Windows Sockets или WinSock. Сервисы сокетов в ОС Windows предоставляются системным файлом Winsock.dll. Стало быть, программы под управлением Windows могут взаимодействовать по сети с компьютерами под управлением Linux и UNIX и наоборот, реализуя, таким образом, клиент-серверные системы. Несмотря на то, что программный интерфейс для WinSock не совпадает полностью с интерфейсом сокетов в UNIX, в основе его лежат те же сокеты.

261
{"b":"285844","o":1}