Многопоточность в php
Наконец-то реализовал мультипоточность при работе с сокетами.
Выигрыш примерно в 2 раза с быстрыми серверами, соответственно, если сервер медленный, или контент генерируется на лету (напр. flush()), то грузится будет ещё быстрее.
Последний тест:
Дано: нужно загрузить 500 страниц. Проблема в том, что каждая генерируется на чужом сервере и время загрузки каждой примерно 20 сек. Т.е., если загружать все в цикле, то уйдёт около 3-х часов.
Используя многопоточность при 20 одновременных потоках все странички загрузились за 25 минут (<3сек./страница).
При 40 потоках - за 20 минут. В общем прогресс налицо.
Совместимо с php4, позволяет добавлять задачи на лету, используя callback-функцию (onload)
Пример кода, использующего мой класс multi_qrl:
$multi = new multi_qrl;
$multi->max_threads = 20;
$multi->onload = "req_load";
function req_load(&$multi, &$req, $result)
{
echo $req->URL." ".(($result!==false)?"ok":"fail")."\r\n"; flush();
}
$multi->add_request(new qrl, "http://www.yandex.ru/");
$multi->add_request(new qrl, "http://www.rambler.ru/");
$multi->add_request(new qrl, "http://www.google.ru/");
$multi->add_request(new qrl, "http://www.yahoo.com/");
$multi->add_request(new qrl, "http://www.sellme.ru/");
$multi->add_request(new qrl, "http://www.habr.ru/");
$multi->add_request(new qrl, "http://www.moneynews.ru/");
$multi->run();
Класс распостраняется только с моими разработками. Стоимость проектов от $50.
_________________
Для тех, кто не подписался по RSS:
Когда переходить на ООП? I. Зачем использовать классы вместо функций.

ноября 8, 2007 в 07:05
Ну и нахуй это кому нужно без класса?
Хитровыебаный ты слишком
ноября 8, 2007 в 14:44
Чтобы знали что я могу.
Епта, лол, а в инете не поискать. Вот хотя бы.
июля 16, 2008 в 11:37
На чем сделано, сокеты? В консоли работать будет или только под апачем? (столько уже реализаций видел, одна даже с AJAX'ом в браузере, как диспетчером "многозадочности" )
июля 16, 2008 в 17:15
Я же написал, что сокеты. Может когда-нить сделаю на curl_multi, чтобы узнать что быстрее.
А почему php не может работать в косоли:
php -q file.phpПро AJAX видел. Долго смеялся :)
июля 16, 2008 в 18:16
В смысле неблокирующие имелось ввиду и через socket_select()?
А то есть разновидность того же аякса только без джавы (на первом месте в гугле по запросу твоему, например)
июля 17, 2008 в 01:18
Да, неблокирующие (stream_select или socket_select). Для неблокирующего открытия сокета надо будет юзать stream_socket_client или socket_set_nonblock.
Что за аякс без джавы я не понял. На основе браузера - это или AJAX-запросы, или
<iframe-ы, можно даже<img src=thread.php. Думаю понятно, что это бред.Нормальный вариант - это запуск нескольких процессов
phpчерезcron, илиexec().февраля 15, 2010 в 00:08
>Нормальный вариант - это запуск нескольких процессов php через cron, или exec().
Не-не-не, ничего нормального в этом нет! Пример рассмотрен - http://jo-in.ru/articles/post/62 правда через браузер.