mirror of
https://github.com/aljazceru/IngestRSS.git
synced 2025-12-24 01:14:27 +01:00
Add Docker infrastructure for local services
This commit is contained in:
80
docker-compose.yml
Normal file
80
docker-compose.yml
Normal file
@@ -0,0 +1,80 @@
|
|||||||
|
version: '3.8'
|
||||||
|
services:
|
||||||
|
redis:
|
||||||
|
image: redis:7
|
||||||
|
ports:
|
||||||
|
- "6379:6379"
|
||||||
|
healthcheck:
|
||||||
|
test: ["CMD", "redis-cli", "ping"]
|
||||||
|
interval: 10s
|
||||||
|
timeout: 5s
|
||||||
|
retries: 5
|
||||||
|
mongodb:
|
||||||
|
image: mongo:7
|
||||||
|
ports:
|
||||||
|
- "27017:27017"
|
||||||
|
volumes:
|
||||||
|
- mongo-data:/data/db
|
||||||
|
healthcheck:
|
||||||
|
test: ["CMD", "mongo", "--eval", "db.adminCommand('ping')"]
|
||||||
|
interval: 10s
|
||||||
|
timeout: 5s
|
||||||
|
retries: 5
|
||||||
|
minio:
|
||||||
|
image: minio/minio
|
||||||
|
command: server /data --console-address ":9001"
|
||||||
|
environment:
|
||||||
|
MINIO_ACCESS_KEY: minioadmin
|
||||||
|
MINIO_SECRET_KEY: minioadmin
|
||||||
|
ports:
|
||||||
|
- "9000:9000"
|
||||||
|
- "9001:9001"
|
||||||
|
volumes:
|
||||||
|
- minio-data:/data
|
||||||
|
healthcheck:
|
||||||
|
test: ["CMD", "curl", "-f", "http://localhost:9000/minio/health/live"]
|
||||||
|
interval: 30s
|
||||||
|
timeout: 20s
|
||||||
|
retries: 5
|
||||||
|
worker:
|
||||||
|
build:
|
||||||
|
context: .
|
||||||
|
dockerfile: docker/worker/Dockerfile
|
||||||
|
depends_on:
|
||||||
|
redis:
|
||||||
|
condition: service_healthy
|
||||||
|
mongodb:
|
||||||
|
condition: service_healthy
|
||||||
|
minio:
|
||||||
|
condition: service_healthy
|
||||||
|
environment:
|
||||||
|
REDIS_URL: redis://redis:6379
|
||||||
|
REDIS_QUEUE_NAME: rss-feed-queue
|
||||||
|
MONGODB_URL: mongodb://mongodb:27017
|
||||||
|
MONGODB_DB_NAME: ingestrss
|
||||||
|
MONGODB_COLLECTION_NAME: rss_feeds
|
||||||
|
MINIO_ENDPOINT: http://minio:9000
|
||||||
|
MINIO_ACCESS_KEY: minioadmin
|
||||||
|
MINIO_SECRET_KEY: minioadmin
|
||||||
|
MINIO_BUCKET: ingestrss
|
||||||
|
STORAGE_STRATEGY: s3
|
||||||
|
LOG_LEVEL: INFO
|
||||||
|
scheduler:
|
||||||
|
build:
|
||||||
|
context: .
|
||||||
|
dockerfile: docker/scheduler/Dockerfile
|
||||||
|
depends_on:
|
||||||
|
redis:
|
||||||
|
condition: service_healthy
|
||||||
|
mongodb:
|
||||||
|
condition: service_healthy
|
||||||
|
environment:
|
||||||
|
REDIS_URL: redis://redis:6379
|
||||||
|
REDIS_QUEUE_NAME: rss-feed-queue
|
||||||
|
MONGODB_URL: mongodb://mongodb:27017
|
||||||
|
MONGODB_DB_NAME: ingestrss
|
||||||
|
MONGODB_COLLECTION_NAME: rss_feeds
|
||||||
|
LOG_LEVEL: INFO
|
||||||
|
volumes:
|
||||||
|
mongo-data:
|
||||||
|
minio-data:
|
||||||
6
docker/scheduler/Dockerfile
Normal file
6
docker/scheduler/Dockerfile
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
FROM python:3.12-slim
|
||||||
|
WORKDIR /app
|
||||||
|
COPY requirements.txt ./
|
||||||
|
RUN pip install --no-cache-dir -r requirements.txt
|
||||||
|
COPY . .
|
||||||
|
CMD ["python", "local_services/scheduler.py"]
|
||||||
6
docker/worker/Dockerfile
Normal file
6
docker/worker/Dockerfile
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
FROM python:3.12-slim
|
||||||
|
WORKDIR /app
|
||||||
|
COPY requirements.txt ./
|
||||||
|
RUN pip install --no-cache-dir -r requirements.txt
|
||||||
|
COPY . .
|
||||||
|
CMD ["python", "local_services/worker.py"]
|
||||||
@@ -1,6 +1,7 @@
|
|||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
import json
|
import json
|
||||||
|
import subprocess
|
||||||
import boto3
|
import boto3
|
||||||
from dotenv import load_dotenv
|
from dotenv import load_dotenv
|
||||||
import logging
|
import logging
|
||||||
@@ -28,6 +29,10 @@ from src.infra.lambdas.lambda_utils.update_lambda_env_vars import update_env_var
|
|||||||
from src.feed_management.upload_rss_feeds import upload_rss_feeds
|
from src.feed_management.upload_rss_feeds import upload_rss_feeds
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
|
if "--local" in sys.argv:
|
||||||
|
subprocess.run(["docker", "compose", "up", "-d"], check=False)
|
||||||
|
return
|
||||||
|
|
||||||
# Deploy infrastructure
|
# Deploy infrastructure
|
||||||
deploy_infrastructure()
|
deploy_infrastructure()
|
||||||
logging.info("Finished Deploying Infrastructure")
|
logging.info("Finished Deploying Infrastructure")
|
||||||
|
|||||||
27
local_services/scheduler.py
Normal file
27
local_services/scheduler.py
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
import os
|
||||||
|
import time
|
||||||
|
import logging
|
||||||
|
import importlib
|
||||||
|
|
||||||
|
handler = importlib.import_module(
|
||||||
|
'src.infra.lambdas.RSSQueueFiller.lambda.lambda_function'
|
||||||
|
).handler
|
||||||
|
|
||||||
|
logging.basicConfig(level=os.getenv("LOG_LEVEL", "INFO"))
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
INTERVAL_MINUTES = int(os.getenv("SCHEDULER_INTERVAL_MINUTES", "240"))
|
||||||
|
|
||||||
|
|
||||||
|
def main():
|
||||||
|
logger.info("Starting scheduler loop")
|
||||||
|
while True:
|
||||||
|
try:
|
||||||
|
handler({}, None)
|
||||||
|
except Exception as exc:
|
||||||
|
logger.exception("Scheduler job failed: %s", exc)
|
||||||
|
time.sleep(INTERVAL_MINUTES * 60)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
main()
|
||||||
22
local_services/worker.py
Normal file
22
local_services/worker.py
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
import os
|
||||||
|
import time
|
||||||
|
import logging
|
||||||
|
|
||||||
|
from src.infra.lambdas.RSSFeedProcessorLambda.src.lambda_function import lambda_handler
|
||||||
|
|
||||||
|
logging.basicConfig(level=os.getenv("LOG_LEVEL", "INFO"))
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
SLEEP_SECONDS = int(os.getenv("WORKER_SLEEP_SECONDS", "5"))
|
||||||
|
|
||||||
|
def main():
|
||||||
|
logger.info("Starting worker loop")
|
||||||
|
while True:
|
||||||
|
try:
|
||||||
|
lambda_handler({}, None)
|
||||||
|
except Exception as exc:
|
||||||
|
logger.exception("Worker iteration failed: %s", exc)
|
||||||
|
time.sleep(SLEEP_SECONDS)
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
main()
|
||||||
Reference in New Issue
Block a user