Я заметил, что мой номер подключений Redis продолжает расти даже при настройке пула для Redis. Единственный способ их очистить — закрыть приложение (или, в моем случае для Heroku, перезапустить динамик).
Вот пример текущего кода:
Код: Выделить всё
CLOUDAMQP_URL = os.environ.get("CLOUDAMQP_URL") or os.environ.get("RABBITMQ_URL")
HEROKU = os.environ['HEROKU']
if HEROKU == "production":
url = urlparse(os.environ.get('REDISCLOUD_URL'))
backend_url = f"redis://{url.username}:{url.password}@{url.hostname}:{url.port}"
else:
backend_url = "redis://localhost:6379/0"
redis_client = redis.Redis.from_url(backend_url)
broker_url = CLOUDAMQP_URL
app = Celery('chatbot_tasks', broker=broker_url, backend=backend_url)
app.conf.task_serializer = 'json'
app.conf.result_serializer = 'json'
app.conf.broker_pool_limit = 0
Я попробовал настроить пул как таковой:
Код: Выделить всё
backend_url = os.environ['REDIS_URL']
pool = ConnectionPool.from_url(backend_url)
Подробнее здесь: https://stackoverflow.com/questions/761 ... using-pool
Мобильная версия