Fix redis ssl issues 2
This commit is contained in:
@@ -40,6 +40,7 @@ class ProductionScheduler:
|
||||
|
||||
# Leader election
|
||||
self._leader_election = None
|
||||
self._redis_manager = None
|
||||
self._redis_client = None
|
||||
self._scheduler_started = False
|
||||
|
||||
@@ -65,17 +66,12 @@ class ProductionScheduler:
|
||||
|
||||
async def _setup_leader_election(self):
|
||||
"""Setup Redis-based leader election"""
|
||||
import ssl
|
||||
from shared.leader_election import LeaderElectionService
|
||||
import redis.asyncio as redis
|
||||
from shared.redis_utils import RedisConnectionManager
|
||||
|
||||
# Handle SSL/TLS for self-signed certificates
|
||||
connection_kwargs = {"decode_responses": False}
|
||||
if self.redis_url and self.redis_url.startswith("rediss://"):
|
||||
connection_kwargs["ssl_cert_reqs"] = ssl.CERT_NONE
|
||||
|
||||
self._redis_client = redis.from_url(self.redis_url, **connection_kwargs)
|
||||
await self._redis_client.ping()
|
||||
# Create Redis connection using shared manager (handles SSL, pooling, health checks)
|
||||
self._redis_manager = await RedisConnectionManager.create(self.redis_url, decode_responses=False)
|
||||
self._redis_client = self._redis_manager.get_client()
|
||||
|
||||
self._leader_election = LeaderElectionService(
|
||||
self._redis_client,
|
||||
@@ -137,8 +133,9 @@ class ProductionScheduler:
|
||||
|
||||
await self._stop_scheduler()
|
||||
|
||||
if self._redis_client:
|
||||
await self._redis_client.close()
|
||||
# Close Redis manager (handles client and pool cleanup)
|
||||
if self._redis_manager:
|
||||
await self._redis_manager.close()
|
||||
|
||||
@property
|
||||
def is_leader(self) -> bool:
|
||||
|
||||
Reference in New Issue
Block a user