несколько потоков.. общий список пользователей я держу в Редисе.... для работы с ним использую Redis Cache Adapter (Symfony). В сокет сервере есть события, onMessage, onConnect, onClose в каждое из этих событий мне нужен доступ ко всем пользователям всех потоков..
как лучше организовать работу с Редисом)
1. В каждом событии создавать новый объект для работы с кешем.
$testItem = $this->cache->getItem('test1');
$result1 = $testItem->isHit() ? $testItem->get() : [];
2. Или лучше вынести создание объекта кеша $testItem = $this->cache->getItem('test1');
в событие onWokerStart (старт потока) а потом просто этот объект передавать от события к событию через ссылки.. и в событиях просто делать get set save.
По факту работает и тот и тот вариант)) по использованию памяти вроде тоже не заметна разница... просто в первом случае у нас в событии создался объект а после завершения события все стерлось)) а во втором случае будет один объект всеми методами использоваться..
мне просто интересно стало кто как делает))
простите, а причем тут кэш?
Я, конечно, нуб, но не вижу ничего плохого использовать второй вариат, если сильно повлиять на объект из воркера невозможно.
Обсуждают сегодня