config.py 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. import os
  2. import platform
  3. def get_environment():
  4. """
  5. 获取当前运行环境
  6. 优先级:
  7. 1. 环境变量 FLASK_ENV
  8. 2. 根据操作系统自动判断(Windows -> development, Linux -> production)
  9. """
  10. # 首先检查环境变量
  11. env = os.environ.get('FLASK_ENV')
  12. if env:
  13. return env.lower()
  14. # 根据操作系统判断
  15. system = platform.system().lower()
  16. if system == 'windows':
  17. return 'development'
  18. elif system == 'linux':
  19. return 'production'
  20. else:
  21. return 'development' # 其他系统默认使用开发环境
  22. class BaseConfig:
  23. """基础配置类,包含所有环境共享的配置"""
  24. SECRET_KEY = os.environ.get('SECRET_KEY') or 'you-will-never-guess'
  25. JSON_AS_ASCII = False
  26. # 平台特定配置
  27. PLATFORM = platform.system().lower()
  28. # 文件上传配置
  29. ALLOWED_EXTENSIONS = {'txt', 'pdf', 'png', 'jpg', 'jpeg', 'gif', 'xlsx', 'xls', 'csv'}
  30. # PostgreSQL 基础配置
  31. SQLALCHEMY_ENGINE_OPTIONS = {
  32. 'pool_pre_ping': True,
  33. 'pool_recycle': 300,
  34. 'pool_size': 10,
  35. 'max_overflow': 20
  36. }
  37. # LLM基础配置
  38. LLM_BASE_URL = "https://dashscope.aliyuncs.com/compatible-mode/v1"
  39. LLM_MODEL_NAME = "qwen-turbo"
  40. LLM_API_KEY = os.environ.get('LLM_API_KEY', "sk-86d4622141d74e9a8d7c38ee873c4d91")
  41. class DevelopmentConfig(BaseConfig):
  42. """Windows 开发环境配置"""
  43. FLASK_ENV = 'development'
  44. DEBUG = True
  45. PORT = 5500
  46. # 开发环境 MinIO 配置
  47. MINIO_HOST = '192.168.67.138:9000'
  48. MINIO_USER = 'citu-test'
  49. MINIO_PASSWORD = 'citu-test'
  50. MINIO_SECURE = False
  51. BUCKET_NAME = 'dataops-bucket'
  52. PREFIX = ''
  53. # 开发环境 PostgreSQL 配置
  54. SQLALCHEMY_DATABASE_URI = 'postgresql://postgres:postgres@192.168.67.138:5432/dataops'
  55. # 开发环境 Neo4j 配置
  56. NEO4J_URI = "bolt://192.168.67.138:7687"
  57. NEO4J_HTTP_URI = "http://192.168.67.138:7474"
  58. NEO4J_USER = "neo4j"
  59. NEO4J_PASSWORD = "password"
  60. NEO4J_ENCRYPTED = False
  61. # 开发环境文件路径配置
  62. UPLOAD_BASE_PATH = 'C:\\tmp\\upload'
  63. ARCHIVE_BASE_PATH = 'C:\\tmp\\archive'
  64. class ProductionConfig(BaseConfig):
  65. """Linux 生产环境配置"""
  66. FLASK_ENV = 'production'
  67. DEBUG = False
  68. PORT = 80
  69. # 生产环境 MinIO 配置
  70. MINIO_HOST = os.environ.get('MINIO_HOST', '192.168.3.143:9000')
  71. MINIO_USER = os.environ.get('MINIO_USER', 'citu-dataops-acc-key')
  72. MINIO_PASSWORD = os.environ.get('MINIO_PASSWORD', 'citu-dataops-secret-key')
  73. MINIO_SECURE = False
  74. BUCKET_NAME = 'dataops-bucket'
  75. PREFIX = ''
  76. # 生产环境 PostgreSQL 配置
  77. SQLALCHEMY_DATABASE_URI = os.environ.get('DATABASE_URL', 'postgresql://postgres:dataOps@192.168.3.143:5432/dataops')
  78. # 生产环境 Neo4j 配置
  79. NEO4J_URI = os.environ.get('NEO4J_URI', "bolt://192.168.3.143:7687")
  80. NEO4J_HTTP_URI = os.environ.get('NEO4J_HTTP_URI', "http://192.168.3.143:7474")
  81. NEO4J_USER = os.environ.get('NEO4J_USER', "neo4j")
  82. NEO4J_PASSWORD = os.environ.get('NEO4J_PASSWORD', "cituneo4j")
  83. NEO4J_ENCRYPTED = False
  84. # 生产环境文件路径配置
  85. UPLOAD_BASE_PATH = '/data/upload'
  86. ARCHIVE_BASE_PATH = '/data/archive'
  87. # 配置字典
  88. config = {
  89. 'development': DevelopmentConfig,
  90. 'production': ProductionConfig,
  91. 'default': DevelopmentConfig
  92. }
  93. # 获取当前环境
  94. current_env = get_environment()