UNIX: разработка сетевых приложений
UNIX: разработка сетевых приложений читать книгу онлайн
Новое издание книги, посвященной созданию веб-серверов, клиент-серверных приложений или любого другого сетевого программного обеспечения в операционной системе UNIX, — классическое руководство по сетевым программным интерфейсам, в частности сокетам. Оно основано на трудах Уильяма Стивенса и полностью переработано и обновлено двумя ведущими экспертами по сетевому программированию. В книгу включено описание ключевых современных стандартов, реализаций и методов, она содержит большое количество иллюстрирующих примеров и может использоваться как учебник по программированию в сетях, так и в качестве справочника для опытных программистов.
Внимание! Книга может содержать контент только для совершеннолетних. Для несовершеннолетних чтение данного контента СТРОГО ЗАПРЕЩЕНО! Если в книге присутствует наличие пропаганды ЛГБТ и другого, запрещенного контента - просьба написать на почту [email protected] для удаления материала
30.8. Сервер TCP с предварительным порождением процессов и защитой вызова accept при помощи взаимного исключения
Как мы уже говорили, существует несколько способов синхронизации процессов путем блокирования. Блокировка файла по стандарту POSIX, рассмотренная в предыдущем разделе, переносится на все POSIX-совместимые системы, но она подразумевает некоторые операции с файловой системой, которые могут потребовать времени. В этом разделе мы будем использовать блокировку при помощи взаимного исключения, обладающую тем преимуществом, что ее можно применять для синхронизации не только потоков внутри одного процесса, но и потоков, относящихся к различным процессам.
Функция
mainchild_makechild_mainТребуется также, чтобы библиотека потоков поддерживала атрибут PTHREAD_PROCESS_SHARED.
Существует несколько способов разделения памяти между различными процессами, что мы подробно описываем во втором томе [2] данной серии. В этом примере мы используем функцию
mmap/dev/zeromy_lock_initЛистинг 30.14. Функция my_lock_init: использование взаимного исключения потоками, относящимися к различным процессам (технология Pthread)
//server/lock_pthread.c 1 #include "unpthread.h" 2 #include <sys/mman.h> 3 static pthread_mutex_t *mptr; /* фактически взаимное исключение будет в совместно используемой памяти */ 4 void 5 my_lock_init(char *pathname) 6 { 7 int fd; 8 pthread_mutexattr_t mattr; 9 fd = Open("/dev/zero", O_RDWR, 0);10 mptr = Mmap(0, sizeof(pthread_mutex_t), PROT_READ | PROT_WRITE,11 MAP_SHARED, fd, 0);12 Close(fd);13 Pthread_mutexattr_init(&mattr);14 Pthread_mutexattr_setpshared(&mattr, PTHREAD_PROCESS_SHARED);15 Pthread_mutex_init(mptr, &mattr);16 }9-12open/dev/zerommappthread_mutex_t13-15PTHREAD_MUTEX_INITIALIZERpthread_mutexattr_tPTHREAD_PROCESS_SHAREDPTHREAD_PROCESS_PRIVATEpthread_mutex_initВ листинге 30.15 показаны только функции
my_lock_waitmy_lock_releaseЛистинг 30.15. Функции my_lock_wait и my_lock_release: использование блокировок Pthread
//server/lock_pthread.c17 void18 my_lock_wait()19 {20 Pthread_mutex_lock(mptr),21 }22 void23 my_lock_release()24 {25 Pthread_mutex_unlock(mptr);26 }Сравнивая строки 3 и 4 табл. 30.1, можно заметить, что версия, использующая синхронизацию процессов при помощи взаимного исключения, характеризуется более высоким быстродействием, чем версия с блокировкой файла.
30.9. Сервер TCP с предварительным порождением процессов: передача дескриптора
Последней модификацией нашего сервера с предварительным порождением процессов является версия, в которой только родительский процесс вызывает функцию
acceptacceptВ предыдущих примерах сервера с предварительным порождением процессов родительскому процессу не приходилось беспокоиться о том, какой дочерний процесс принимает соединение с клиентом. Этим занималась операционная система, организуя вызов функции
accept
