modified: Dockerfile
modified: config.py modified: docker-compose.yml
This commit is contained in:
@@ -19,8 +19,8 @@ COPY --from=builder /install /usr/local
|
|||||||
# Copy application code
|
# Copy application code
|
||||||
COPY --chown=appuser:appgroup . .
|
COPY --chown=appuser:appgroup . .
|
||||||
|
|
||||||
# Directories that will be mounted as volumes
|
# Directories that will be mounted as volumes (data = SQLite default location)
|
||||||
RUN mkdir -p uploads vectordb .cache && chown -R appuser:appgroup uploads vectordb .cache
|
RUN mkdir -p uploads vectordb data && chown -R appuser:appgroup uploads vectordb data
|
||||||
|
|
||||||
USER appuser
|
USER appuser
|
||||||
|
|
||||||
@@ -31,14 +31,13 @@ ENV SECRET_KEY=$SECRET_KEY
|
|||||||
ENV AI_PROVIDER=$AI_PROVIDER
|
ENV AI_PROVIDER=$AI_PROVIDER
|
||||||
ENV LM_STUDIO_URL=$LM_STUDIO_URL
|
ENV LM_STUDIO_URL=$LM_STUDIO_URL
|
||||||
ENV LM_STUDIO_MODEL=$LM_STUDIO_MODEL
|
ENV LM_STUDIO_MODEL=$LM_STUDIO_MODEL
|
||||||
|
ENV LM_STUDIO_EMBEDDING_MODEL=$LM_STUDIO_EMBEDDING_MODEL
|
||||||
ENV OPENAI_API_KEY=$OPENAI_API_KEY
|
ENV OPENAI_API_KEY=$OPENAI_API_KEY
|
||||||
ENV OPENAI_MODEL=$OPENAI_MODEL
|
ENV OPENAI_MODEL=$OPENAI_MODEL
|
||||||
ENV DATABASE_URI=$DATABASE_URI
|
ENV DATABASE_URI=$DATABASE_URI
|
||||||
ENV RAG_TOP_K=$RAG_TOP_K
|
ENV RAG_TOP_K=$RAG_TOP_K
|
||||||
ENV RAG_CHUNK_SIZE=$RAG_CHUNK_SIZE
|
ENV RAG_CHUNK_SIZE=$RAG_CHUNK_SIZE
|
||||||
ENV RAG_CHUNK_OVERLAP=$RAG_CHUNK_OVERLAP
|
ENV RAG_CHUNK_OVERLAP=$RAG_CHUNK_OVERLAP
|
||||||
ENV TRANSFORMERS_CACHE=/app/.cache
|
|
||||||
ENV HF_HOME=/app/.cache
|
|
||||||
|
|
||||||
EXPOSE 5000
|
EXPOSE 5000
|
||||||
|
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ BASE_DIR = os.path.abspath(os.path.dirname(__file__))
|
|||||||
class Config:
|
class Config:
|
||||||
SECRET_KEY = os.environ.get("SECRET_KEY", "change-me-in-production")
|
SECRET_KEY = os.environ.get("SECRET_KEY", "change-me-in-production")
|
||||||
_db_uri = os.environ.get("DATABASE_URI", "")
|
_db_uri = os.environ.get("DATABASE_URI", "")
|
||||||
_default_uri = f"sqlite:///{os.path.join(BASE_DIR, 'app.db')}"
|
_default_uri = f"sqlite:///{os.path.join(BASE_DIR, 'data', 'app.db')}"
|
||||||
# Fall back to SQLite if DATABASE_URI is empty or not a valid SQLAlchemy URL
|
# Fall back to SQLite if DATABASE_URI is empty or not a valid SQLAlchemy URL
|
||||||
SQLALCHEMY_DATABASE_URI = (
|
SQLALCHEMY_DATABASE_URI = (
|
||||||
_db_uri if _db_uri and "://" in _db_uri else _default_uri
|
_db_uri if _db_uri and "://" in _db_uri else _default_uri
|
||||||
|
|||||||
@@ -9,6 +9,7 @@ services:
|
|||||||
volumes:
|
volumes:
|
||||||
- uploads:/app/uploads
|
- uploads:/app/uploads
|
||||||
- vectordb:/app/vectordb
|
- vectordb:/app/vectordb
|
||||||
|
- data:/app/data
|
||||||
healthcheck:
|
healthcheck:
|
||||||
test: ["CMD", "python", "-c",
|
test: ["CMD", "python", "-c",
|
||||||
"import urllib.request; urllib.request.urlopen('http://localhost:5000/auth/login')"]
|
"import urllib.request; urllib.request.urlopen('http://localhost:5000/auth/login')"]
|
||||||
@@ -20,3 +21,4 @@ services:
|
|||||||
volumes:
|
volumes:
|
||||||
uploads:
|
uploads:
|
||||||
vectordb:
|
vectordb:
|
||||||
|
data:
|
||||||
|
|||||||
Reference in New Issue
Block a user