Форум сайта python.su
Daevaornвот кусок конфига:o7412369815963Нет.
получается все фреймворки которые подключены через mod_wsgi: Django, TurboGears, Pylons и др. - работают в однопоточном режиме.
Вы так и не привели настройки mpm апача и не написали как вы тестировали.
Пока очевидно, что вы не понимаете что вы хотете сделать и как apache+mod_wsgi работают в принципе.
ServerLimit 16
StartServers 2
MaxClients 150
MinSpareThreads 25
MaxSpareThreads 75
ThreadsPerChild 25
Отредактировано (Июль 27, 2010 13:40:12)
Офлайн
o7412369815963Это в какой секции?
вот кусок конфига:
Офлайн
Lexanderсекция <IfModule mpm_worker_module>o7412369815963Это в какой секции?
вот кусок конфига:
Попробуй еще вместо
ServerName localhost
написать
ServerName main
Если ты описываешь WSGIDaemonProcess внутри виртуального хоста, то имя должно совпадать.
Офлайн
Весь день не заходил на форум, ща глянул - жесть! Давайo7412369815963 , я за тебя тоже буду болеть, завтра попробую подключится.
Только непонятно у всех остальных нормально? У меня в чистом WSGI пример выше с обычным sleep отдаёт ответы одновременно.
Офлайн
вот я касяк.
оказывается дело в браузере, если открывать один url в пределах одного браузера то он сам делает загрузку по очереди.
Офлайн
o7412369815963Это не методика. Сделайте тест правильно – автоматизированный.
с 3-х браузеров одновременно подключался к серверу. резуьтат получал поочередно каждые 5 сек.
например: в первом браузере 15 - 20, второй: 20 - 25, 3-ий: 25 - 30,
Офлайн
сейчас выяснил что кол-во процессов которые указываются в “<IfModule mpm_worker_module> StartServers 1”
не влияют на на “WSGIDaemonProcess main user=www-data group=www-data processes=2 threads=5”
они работают параллельно, т.е. если StartServers = 3, и processes = 5, то всего будет 3+5+ (2 родительских) = 10 (или около того)
Офлайн
> (2 родительских)
сейчас пересчитал, StartServers уже учитывает кол-во родительских.
Офлайн
Daevaornвот автоматизированный. processes=5 threads=5 = 25 потоковo7412369815963Это не методика. Сделайте тест правильно – автоматизированный.
с 3-х браузеров одновременно подключался к серверу. резуьтат получал поочередно каждые 5 сек.
например: в первом браузере 15 - 20, второй: 20 - 25, 3-ий: 25 - 30,
$ ab -n 25 -c 25 http://localhost/
Concurrency Level: 25
Time taken for tests: 5.010 seconds
Complete requests: 25
Time per request: 5009.800 [ms] (mean)
Time per request: 200.392 [ms] (mean, across all concurrent requests)
min mean[+/-sd] median max
Total: 5004 5007 1.9 5009 5009
$ ab -n 50 -c 50 http://localhost/
Concurrency Level: 50
Time taken for tests: 10.018 seconds
Complete requests: 50
Time per request: 10017.541 [ms] (mean)
Time per request: 200.351 [ms] (mean, across all concurrent requests)
min mean[+/-sd] median max
Total: 5005 7511 2526.9 10008 10016
Отредактировано (Июль 27, 2010 17:15:13)
Офлайн
o7412369815963 О! респект и уважуха что разобрался, а теперь ответь на вопрос пожалуйста, если не sleep а поиск из массива вставить, ну как из предыдущего примера, то второй клиент зависнет или нет?
Офлайн