ef7cfbb860
Restructuring the Repo to make it clear the difference between classic autogpt and the autogpt platform: * Move the "classic" projects `autogpt`, `forge`, `frontend`, and `benchmark` into a `classic` folder * Also rename `autogpt` to `original_autogpt` for absolute clarity * Rename `rnd/` to `autogpt_platform/` * `rnd/autogpt_builder` -> `autogpt_platform/frontend` * `rnd/autogpt_server` -> `autogpt_platform/backend` * Adjust any paths accordingly |
||
---|---|---|
.. | ||
autogpt_libs | ||
backend | ||
example_files | ||
frontend | ||
infra | ||
market | ||
supabase@4647d50380 | ||
README.md | ||
__init__.py | ||
docker-compose.combined.yml | ||
docker-compose.yml |
README.md
AutoGPT Platform
Welcome to the AutoGPT Platform - a powerful system for creating and running AI agents to solve business problems. This platform enables you to harness the power of artificial intelligence to automate tasks, analyze data, and generate insights for your organization.
Getting Started
Prerequisites
- Docker
- Docker Compose V2 (comes with Docker Desktop, or can be installed separately)
Running the System
To run the AutoGPT Platform, follow these steps:
-
Clone this repository to your local machine.
-
Navigate to autogpt_platform/supabase
-
Run the following command:
git submodule update --init --recursive
-
Navigate back to autogpt_platform (cd ..)
-
Run the following command:
cp supabase/docker/.env.example .env
-
Run the following command:
docker compose -f docker-compose.combined.yml up -d
This command will start all the necessary backend services defined in the
docker-compose.combined.yml
file in detached mode. -
Navigate to autogpt_platform/frontend.
-
Run the following command:
cp .env.example .env.local
-
Run the following command:
yarn dev
Docker Compose Commands
Here are some useful Docker Compose commands for managing your AutoGPT Platform:
docker compose -f docker-compose.combined.yml up -d
: Start the services in detached mode.docker compose -f docker-compose.combined.yml stop
: Stop the running services without removing them.docker compose rm
: Remove stopped service containers.docker compose build
: Build or rebuild services.docker compose down
: Stop and remove containers, networks, and volumes.docker compose watch
: Watch for changes in your services and automatically update them.
Sample Scenarios
Here are some common scenarios where you might use multiple Docker Compose commands:
-
Updating and restarting a specific service:
docker compose build api_srv docker compose up -d --no-deps api_srv
This rebuilds the
api_srv
service and restarts it without affecting other services. -
Viewing logs for troubleshooting:
docker compose logs -f api_srv ws_srv
This shows and follows the logs for both
api_srv
andws_srv
services. -
Scaling a service for increased load:
docker compose up -d --scale executor=3
This scales the
executor
service to 3 instances to handle increased load. -
Stopping the entire system for maintenance:
docker compose stop docker compose rm -f docker compose pull docker compose up -d
This stops all services, removes containers, pulls the latest images, and restarts the system.
-
Developing with live updates:
docker compose watch
This watches for changes in your code and automatically updates the relevant services.
-
Checking the status of services:
docker compose ps
This shows the current status of all services defined in your docker-compose.yml file.
These scenarios demonstrate how to use Docker Compose commands in combination to manage your AutoGPT Platform effectively.
Persisting Data
To persist data for PostgreSQL and Redis, you can modify the docker-compose.yml
file to add volumes. Here's how:
-
Open the
docker-compose.yml
file in a text editor. -
Add volume configurations for PostgreSQL and Redis services:
services: postgres: # ... other configurations ... volumes: - postgres_data:/var/lib/postgresql/data redis: # ... other configurations ... volumes: - redis_data:/data volumes: postgres_data: redis_data:
-
Save the file and run
docker compose up -d
to apply the changes.
This configuration will create named volumes for PostgreSQL and Redis, ensuring that your data persists across container restarts.