mirror of
https://git.mirrors.martin98.com/https://github.com/langgenius/dify.git
synced 2025-08-12 08:28:57 +08:00
add storage error log (#8556)
This commit is contained in:
parent
d6de96c4b4
commit
d96f5ba1ca
@ -5,6 +5,8 @@ from sentry_sdk.integrations.celery import CeleryIntegration
|
|||||||
from sentry_sdk.integrations.flask import FlaskIntegration
|
from sentry_sdk.integrations.flask import FlaskIntegration
|
||||||
from werkzeug.exceptions import HTTPException
|
from werkzeug.exceptions import HTTPException
|
||||||
|
|
||||||
|
from core.model_runtime.errors.invoke import InvokeRateLimitError
|
||||||
|
|
||||||
|
|
||||||
def before_send(event, hint):
|
def before_send(event, hint):
|
||||||
if "exc_info" in hint:
|
if "exc_info" in hint:
|
||||||
@ -20,7 +22,13 @@ def init_app(app):
|
|||||||
sentry_sdk.init(
|
sentry_sdk.init(
|
||||||
dsn=app.config.get("SENTRY_DSN"),
|
dsn=app.config.get("SENTRY_DSN"),
|
||||||
integrations=[FlaskIntegration(), CeleryIntegration()],
|
integrations=[FlaskIntegration(), CeleryIntegration()],
|
||||||
ignore_errors=[HTTPException, ValueError, openai.APIStatusError, parse_error.defaultErrorResponse],
|
ignore_errors=[
|
||||||
|
HTTPException,
|
||||||
|
ValueError,
|
||||||
|
openai.APIStatusError,
|
||||||
|
InvokeRateLimitError,
|
||||||
|
parse_error.defaultErrorResponse,
|
||||||
|
],
|
||||||
traces_sample_rate=app.config.get("SENTRY_TRACES_SAMPLE_RATE", 1.0),
|
traces_sample_rate=app.config.get("SENTRY_TRACES_SAMPLE_RATE", 1.0),
|
||||||
profiles_sample_rate=app.config.get("SENTRY_PROFILES_SAMPLE_RATE", 1.0),
|
profiles_sample_rate=app.config.get("SENTRY_PROFILES_SAMPLE_RATE", 1.0),
|
||||||
environment=app.config.get("DEPLOY_ENV"),
|
environment=app.config.get("DEPLOY_ENV"),
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
import logging
|
||||||
from collections.abc import Generator
|
from collections.abc import Generator
|
||||||
from typing import Union
|
from typing import Union
|
||||||
|
|
||||||
@ -40,28 +41,56 @@ class Storage:
|
|||||||
self.storage_runner = LocalStorage(app=app)
|
self.storage_runner = LocalStorage(app=app)
|
||||||
|
|
||||||
def save(self, filename, data):
|
def save(self, filename, data):
|
||||||
self.storage_runner.save(filename, data)
|
try:
|
||||||
|
self.storage_runner.save(filename, data)
|
||||||
|
except Exception as e:
|
||||||
|
logging.exception("Failed to save file: %s", e)
|
||||||
|
raise e
|
||||||
|
|
||||||
def load(self, filename: str, stream: bool = False) -> Union[bytes, Generator]:
|
def load(self, filename: str, stream: bool = False) -> Union[bytes, Generator]:
|
||||||
if stream:
|
try:
|
||||||
return self.load_stream(filename)
|
if stream:
|
||||||
else:
|
return self.load_stream(filename)
|
||||||
return self.load_once(filename)
|
else:
|
||||||
|
return self.load_once(filename)
|
||||||
|
except Exception as e:
|
||||||
|
logging.exception("Failed to load file: %s", e)
|
||||||
|
raise e
|
||||||
|
|
||||||
def load_once(self, filename: str) -> bytes:
|
def load_once(self, filename: str) -> bytes:
|
||||||
return self.storage_runner.load_once(filename)
|
try:
|
||||||
|
return self.storage_runner.load_once(filename)
|
||||||
|
except Exception as e:
|
||||||
|
logging.exception("Failed to load_once file: %s", e)
|
||||||
|
raise e
|
||||||
|
|
||||||
def load_stream(self, filename: str) -> Generator:
|
def load_stream(self, filename: str) -> Generator:
|
||||||
return self.storage_runner.load_stream(filename)
|
try:
|
||||||
|
return self.storage_runner.load_stream(filename)
|
||||||
|
except Exception as e:
|
||||||
|
logging.exception("Failed to load_stream file: %s", e)
|
||||||
|
raise e
|
||||||
|
|
||||||
def download(self, filename, target_filepath):
|
def download(self, filename, target_filepath):
|
||||||
self.storage_runner.download(filename, target_filepath)
|
try:
|
||||||
|
self.storage_runner.download(filename, target_filepath)
|
||||||
|
except Exception as e:
|
||||||
|
logging.exception("Failed to download file: %s", e)
|
||||||
|
raise e
|
||||||
|
|
||||||
def exists(self, filename):
|
def exists(self, filename):
|
||||||
return self.storage_runner.exists(filename)
|
try:
|
||||||
|
return self.storage_runner.exists(filename)
|
||||||
|
except Exception as e:
|
||||||
|
logging.exception("Failed to check file exists: %s", e)
|
||||||
|
raise e
|
||||||
|
|
||||||
def delete(self, filename):
|
def delete(self, filename):
|
||||||
return self.storage_runner.delete(filename)
|
try:
|
||||||
|
return self.storage_runner.delete(filename)
|
||||||
|
except Exception as e:
|
||||||
|
logging.exception("Failed to delete file: %s", e)
|
||||||
|
raise e
|
||||||
|
|
||||||
|
|
||||||
storage = Storage()
|
storage = Storage()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user