|  | 1 개월 전 | |
|---|---|---|
| .. | ||
| .idea | 1 년 전 | |
| .vscode | 1 년 전 | |
| configs | 1 개월 전 | |
| constants | 1 개월 전 | |
| contexts | 5 달 전 | |
| controllers | 1 개월 전 | |
| core | 1 개월 전 | |
| docker | 2 달 전 | |
| events | 1 개월 전 | |
| extensions | 1 개월 전 | |
| factories | 2 달 전 | |
| fields | 1 개월 전 | |
| libs | 1 개월 전 | |
| migrations | 1 개월 전 | |
| models | 1 개월 전 | |
| repositories | 1 개월 전 | |
| schedule | 1 개월 전 | |
| services | 1 개월 전 | |
| tasks | 1 개월 전 | |
| templates | 3 달 전 | |
| tests | 1 개월 전 | |
| .dockerignore | 6 달 전 | |
| .env.example | 2 달 전 | |
| .ruff.toml | 2 달 전 | |
| Dockerfile | 2 달 전 | |
| README.md | 1 개월 전 | |
| app.py | 5 달 전 | |
| app_factory.py | 2 달 전 | |
| commands.py | 1 개월 전 | |
| dify_app.py | 11 달 전 | |
| mypy.ini | 2 달 전 | |
| pyproject.toml | 1 개월 전 | |
| pyrightconfig.json | 1 개월 전 | |
| pytest.ini | 5 달 전 | |
| ty.toml | 1 개월 전 | |
| uv.lock | 1 개월 전 | |
[!IMPORTANT]
In the v1.3.0 release,
poetryhas been replaced withuvas the package manager for Dify API backend service.
The backend require some middleware, including PostgreSQL, Redis, and Weaviate, which can be started together using docker-compose.
   cd ../docker
   cp middleware.env.example middleware.env
   # change the profile to other vector database if you are not using weaviate
   docker compose -f docker-compose.middleware.yaml --profile weaviate -p dify up -d
   cd ../api
.env.example to .env   cp .env.example .env
SECRET_KEY in the .env file.bash for Linux
   sed -i "/^SECRET_KEY=/c\SECRET_KEY=$(openssl rand -base64 42)" .env
bash for Mac
   secret_key=$(openssl rand -base64 42)
   sed -i '' "/^SECRET_KEY=/c\\
   SECRET_KEY=${secret_key}" .env
Dify API service uses UV to manage dependencies. First, you need to add the uv package manager, if you don’t have it already.
   pip install uv
   # Or on macOS
   brew install uv
   uv sync --dev
Before the first launch, migrate the database to the latest version.
   uv run flask db upgrade
   uv run flask run --host 0.0.0.0 --port=5001 --debug
Start Dify web service.
Setup your application by visiting http://localhost:3000.
If you need to handle and debug the async tasks (e.g. dataset importing and documents indexing), please start the worker service.
uv run celery -A app.celery worker -P gevent -c 1 --loglevel INFO -Q dataset,generation,mail,ops_trace,app_deletion,plugin,workflow_storage,conversation
Addition, if you want to debug the celery scheduled tasks, you can use the following command in another terminal:
uv run celery -A app.celery beat
   uv sync --dev
tool.pytest_env section in pyproject.toml, more can check Claude.md   uv run pytest                           # Run all tests
   uv run pytest tests/unit_tests/         # Unit tests only
   uv run pytest tests/integration_tests/  # Integration tests
   # Code quality
   ../dev/reformat               # Run all formatters and linters
   uv run ruff check --fix ./    # Fix linting issues
   uv run ruff format ./         # Format code
   uv run basedpyright .         # Type checking