добавок бекэнд на cluster. Со стороны клиента приходят запросы на изображения под разные размеры, бывает моменты, что некоторые превью битые(не полные).
Логика создания превью такова. Если во временной папке /cache нужной превью по хешу:
- Есть да:
⁃ отдаю как есть.
⁃ Если нет:
⁃ то запрашиваю источник оригинал,
⁃ копирую на жесткий,
⁃ генерирую превью,
⁃ отдаю клиенту превью,
⁃ на заднем фоне удаляю источник оригинал.
Тоже самое может происходит, в соседнем воркере(использую cluster), где может запрашиваться тот же самый превью с другими параметрами(размер побольше или качество сжатия другое).
Кеш хранится долго может месяцами, пока диск не заполнится до какого то момента.
Есть какое то решение, где можно знать, что удалять в данный момент оригинал нельзя, что оно пользуется другим воркером или процессом? Подскажите в какую сторону копать.
Как вариант, ты можешь закидывать что надо удалить в очередь и помечать как удаленное, и через какое-то время удалить его(можно через скедулер) если я правильно понял проблему...
Обсуждают сегодня