6. Процессы Web-сервера
1) Master (root, 1 процесс)
– Чтение и валидация конфига
– Открытие сокета (ов)
– Открытие файлов логов
– Запуск и управление дочерними процессами
(worker)
– Graceful restart, Binary updates
7) Worker (www-data, 1+ процессов)
– Обработка входящих запросов
7. Доступ к файлам в UNIX
$ ls -lah server/core.c
-rw-r--r-- 1 nuf users 156K Feb 6 21:15 server/core.c
У файла (или директории) есть:
- пользователь (владелец)
- группа
- права доступа (read/write/execute)
У процесса есть:
- пользователь
- группа
11. Конфигурация Apache
Listen 80
User www
DirectoryIndex index.html
DocumentRoot /www/htdocs
NameVirtualHost *:80
<VirtualHost *:80>
ServerName www.domain.ru
DocumentRoot /www/domain
ErrorLog /var/log/domain/error_log
CustomLog /var/log/domain/access_log
<Directory "/var/www/html">
Options Indexes FollowSymLinks
</Directory>
<Location "/private/">
Order Allow, Deny
Deny from all
</Location>
</VirtualHost>
12. Секции и директивы
<VirtualHost> – конфигурация для домена
<Location /admin> </Location>
<LocationMatch .svn> </LocationMatch>
<Directory /htdocs> </Directory>
<DirectoryMatch /inc/> </DirectoryMatch>
DocumentRoot /www/htdocs
Alias /www/htdocs/
13. Порядок применения
1) VirtualHost – по заголовку Host
2) DocumentRoot / Alias – вычисление пути
3) Directory и .htaccess
4) DirectoryMatch
5) Files и FilesMatch
6) Location и LocationMatch
Приоритеты – в обратном порядке
20. Более 1 клиента ?
1) Многопоточность (threads)
+ экономия памяти
+ быстрый запуск потока
— все библиотеки должны быть thread-safe
2) Дочерние процессы (prefork)
+ простота, не обязательно thread-safe
— потребление памяти
— медленый запуск процессов
3) Комбинированный режим (worker)
22. IO Multiplexing
readsocks = […] # список сокетов для чтения
writesocks = […] # список сокетов для записи
while True:
readables, writeables, exceptions =
select(readsocks, writesocks, [])
for sockobj in readables:
data = sockobj.recv(1024)
if not data:
sockobj.close( )
readsocks.remove(sockobj)
else:
print 'tgot', data, 'on', id(sockobj)
24. Event-Driven programming
1) множество открытых файлов
2) select, kqueue, epoll, aio...
3) последовательное исполнение события→
4) “20 байт из сокета A”, “6 байт из файла B”
+ быстро, никакого сна
+ экономия памяти. 1 клиент – 1 структура
+ большое количество клиентов
— очень тяжело программировать
— блокирующие вызовы запрещены
25. Кто есть Who.
1) Apache – prefork, worker, С
2) ISS, Tomcat, Jetty – threads, Java
3) Starman, Hypnotoad – prefork, языки высокого уровня
4) nginx, lighttpd – асинхронные, С
5) Node.JS, Tornado, POE – асинхронные, языки высокого
уровня
6) Erlang!
7) Для разработки.