A command-line tool and SDK for deploying, managing, and interacting with AI agents
Project description
Secured, reliable AI agent deployment at scale
Run your stack. Let us run your agents.
What is RunAgent?
RunAgent is an agentic ecosystem that enables developers to build AI agents once in Python using any python agentic frameworks like LangGraph, CrewAI, Letta, LlamaIndex, then access them natively from any programming language. The platform features stateful self-learning capabilities with RunAgent Memory (coming soon), allowing agents to retain context and improve it's action memory over time.
RunAgent has multi-language SDK support for seamless integration across TypeScript, JavaScript, Go, and other languages, eliminating the need to rewrite agents for different tech stacks. RunAgent Cloud provides automated deployment with serverless auto-scaling, comprehensive agent security, and real-time monitoring capabilities.
Quick Start
Installation
pip install runagent
Initialize Your First Agent
# The basic
runagent init my-agent # Basic template
# Also you can choose from various frameworks
runagent init my-agent --langgraph # LangGraph template
runagent init my-agent --crewai # CrewAI template
runagent init my-agent --letta # Letta template
Agent Configuration
Every RunAgent project requires a runagent.config.json file that defines your agent's structure and capabilities.
This configuration file specifies basic metadata (name, framework, version), defines entrypoints for either Python functions or external webhooks, and sets environment variables like API keys. The entrypoints array is the core component, allowing you to expose functions from any Python framework (LangGraph, CrewAI, OpenAI) or integrate external services (N8N, Zapier) through a unified interface accessible from any programming language.
Example Configuration
{
"agent_name": "LangGraph Problem Solver",
"description": "Multi-step problem analysis and solution validation agent",
"framework": "langgraph",
"version": "1.0.0",
"agent_architecture": {
"entrypoints": [
{
"file": "agent.py",
"module": "solve_problem",
"tag": "solve_problem"
},
{
"file": "agent.py",
"module": "solve_problem_stream",
"tag": "solve_problem_stream"
}
]
},
"env_vars": {
"OPENAI_API_KEY": "your-api-key"
}
}
Local Development
Deploy and test your agents locally with full debugging capabilities before deploying to RunAgent Cloud.
Deploy Agent Locally
cd my-agent
runagent serve .
This starts a local FastAPI server with:
- Auto-allocated ports to avoid conflicts
- Real-time debugging and logging
- WebSocket support for streaming
- Built-in API documentation at
/docs
Deploy to RunAgent Cloud
Once your agent is tested locally, deploy to production:
# Authenticate (first time only)
runagent setup --api-key <your-api-key>
# Deploy to cloud
runagent deploy --folder .
Your agent will be live globally with automatic scaling, monitoring, and enterprise security. View all your agents and execution metrics in the dashboard.
LangGraph Problem Solver Agent (An Example)
# agent.py
from langgraph.graph import StateGraph
from typing import TypedDict, List
class ProblemState(TypedDict):
query: str
num_solutions: int
constraints: List[dict]
solutions: List[str]
validated: bool
def analyze_problem(state):
# Problem analysis logic
return {"solutions": [...]}
def validate_solutions(state):
# Validation logic
return {"validated": True}
# Build the graph
workflow = StateGraph(ProblemState)
workflow.add_node("analyze", analyze_problem)
workflow.add_node("validate", validate_solutions)
workflow.add_edge("analyze", "validate")
workflow.set_entry_point("analyze")
app = workflow.compile()
def solve_problem(query, num_solutions, constraints):
result = app.invoke({
"query": query,
"num_solutions": num_solutions,
"constraints": constraints
})
return result
async def solve_problem_stream(query, num_solutions, constraints):
async for event in app.astream({
"query": query,
"num_solutions": num_solutions,
"constraints": constraints
}):
yield event
🌐 Access from any language:
RunAgent offers multi-language SDKs : Rust, TypeScript, JavaScript, Go, and beyond—so you can integrate seamlessly without ever rewriting your agents for different stacks.
| Python SDK | JavaScript SDK | Rust SDK | Go SDK |
from runagent import RunAgentClient
client = RunAgentClient(
agent_id="lg-solver-123",
entrypoint_tag="solve_problem",
local=True
)
result = client.run(
query="My laptop is slow",
num_solutions=3,
constraints=[{
"type": "budget",
"value": 100
}]
)
print(result)
# Streaming
for chunk in client.run(
query="Fix my phone",
num_solutions=4
):
print(chunk)
|
import { RunAgentClient } from 'runagent';
const client = new RunAgentClient({
agentId: "lg-solver-123",
entrypointTag: "solve_problem",
local: true
});
await client.initialize();
const result = await client.run({
query: "My laptop is slow",
num_solutions: 3,
constraints: [{
type: "budget",
value: 100
}]
});
console.log(result);
// Streaming
for await (const chunk of client.run({
query: "Fix my phone",
num_solutions: 4
})) {
process.stdout.write(chunk);
}
|
use runagent::client::RunAgentClient;
use serde_json::json;
use futures::StreamExt;
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
let client = RunAgentClient::new(
"lg-solver-123",
"solve_problem",
true
).await?;
let result = client.run(&[
("query", json!("My laptop is slow")),
("num_solutions", json!(3)),
("constraints", json!([{
"type": "budget",
"value": 100
}]))
]).await?;
println!("Result: {}", result);
// Streaming
let mut stream = client.run_stream(&[
("query", json!("Fix my phone")),
("num_solutions", json!(4))
]).await?;
while let Some(chunk) = stream.next().await {
print!("{}", chunk?);
}
Ok(())
}
|
package main
import (
"context"
"fmt"
"github.com/runagent-dev/runagent-go/pkg/client"
)
func main() {
client, _ := client.New(
"lg-solver-123",
"solve_problem",
true
)
defer client.Close()
result, _ := client.Run(
context.Background(),
map[string]interface{}{
"query": "My laptop is slow",
"num_solutions": 3,
"constraints": []map[string]interface{}{
{"type": "budget", "value": 100},
},
}
)
fmt.Printf("Result: %v\n", result)
// Streaming
stream, _ := client.RunStream(
context.Background(),
map[string]interface{}{
"query": "Fix my phone",
"num_solutions": 4,
}
)
defer stream.Close()
for {
chunk, hasMore, _ := stream.Next(context.Background())
if !hasMore { break }
fmt.Print(chunk)
}
}
|
🚀 RunAgent Cloud Deployment
Now Available: Production-Ready Cloud Infrastructure
Deploy to production in seconds with enterprise-grade infrastructure
| Sign Up | Dashboard | Documentation |
Deploy your agents to RunAgent Cloud with enterprise-grade infrastructure and experience the fastest agent deployment. RunAgent Cloud provides serverless auto-scaling, comprehensive security, and real-time monitoring - all managed for you.
Get Started with RunAgent Cloud
- Sign up at app.run-agent.ai
- Generate API Key: After signing in, go to Settings → API Keys → Generate API Key
- Authenticate CLI: Configure your CLI with your API key
- Deploy: Deploy your agents with a single command
# Authenticate with RunAgent Cloud
runagent setup --api-key <your-api-key>
# Deploy your agent
runagent deploy --folder ./my-agent
Fastest Agent Deployment
From zero to production in seconds. RunAgent Cloud automatically selects the optimal VM image based on your agent's requirements, with deployment typically completing in 30-60 seconds for standard images, or up to 2 minutes for specialized configurations.
Security-First Architecture
Every agent runs in its own isolated sandbox environment:
- Complete process isolation
- Network segmentation
- Resource limits and monitoring
- Zero data leakage between agents
Dashboard & Monitoring
The RunAgent Cloud dashboard provides comprehensive insights into your agents:
- Agent Execution Metadata - Detailed information about each execution
- Execution Time Tracking - Monitor performance and optimize accordingly
- Agent Management - View and manage all your deployed agents
- Usage Analytics - Track usage patterns and resource consumption
- Real-time Monitoring - Live status and health checks
- Execution History - Complete audit trail of all agent invocations
Access your dashboard at app.run-agent.ai/dashboard after signing in.
Enterprise-Grade Features
RunAgent Cloud provides:
- Auto-scaling - Automatically scales based on demand
- Global Edge Distribution - Low-latency access worldwide
- Built-in Monitoring - Comprehensive analytics and observability
- Production-Grade Security - Enterprise security and compliance
- Multiple VM Images - Automatic image selection optimized for your agent
- Serverless Infrastructure - Zero infrastructure management
📚 Documentation
- Getting Started - Deploy your first agent in 5 minutes
- CLI Reference - Complete command-line interface guide
- SDK Documentation - Multi-language SDK guides
- Framework Guides - Framework-specific tutorials
- API Reference - REST API documentation
- RunAgent Cloud Guide - Complete cloud deployment guide
🧠 Action Memory System (Coming Soon)
RunAgent is introducing Action Memory - a revolutionary approach to agent reliability that focuses on how to remember rather than what to remember.
How It Will Work
- Action-Centric: Instead of storing raw conversation data, it captures decision patterns and successful action sequences
- Cross-Language: Memory persists across all SDK languages seamlessly
- Reliability Focus: Learns from successful outcomes to improve future decisions
- Ecosystem Integration: Works with any framework - LangGraph, CrewAI, Letta, and more
This will ensure your agents become more reliable over time, regardless of which programming language or framework you use to interact with them.
Community & Support
Ready to build universal AI agents?
🌟 Star us on GitHub • 💬 Join Discord • 📚 Read the Docs
Made with ❤️ by the RunAgent Team
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file runagent-0.1.39.tar.gz.
File metadata
- Download URL: runagent-0.1.39.tar.gz
- Upload date:
- Size: 18.6 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
434ba4c0f11005a99ae58771259858d800e1358e1edeb03c03d487efaab0a269
|
|
| MD5 |
96a9285aa355db9e5e8969b2b25a5648
|
|
| BLAKE2b-256 |
d63bb29710a0d457f491c94b9e7a26f9c068343ffa8cd4b3a579357392f1099e
|
File details
Details for the file runagent-0.1.39-py3-none-any.whl.
File metadata
- Download URL: runagent-0.1.39-py3-none-any.whl
- Upload date:
- Size: 161.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
33b28068f218a245089308deb0fd8d56e6158d65d7da9dee1194f832b690acd9
|
|
| MD5 |
30035701f37e4982b297d15ebf52dab9
|
|
| BLAKE2b-256 |
5ed15022dbf6794445a49cc8eb5c79eaa520ef9f679a8ef015be96cc3ecab8d9
|