Docker + Custom Domain
OpenAlgo Docker Installation Script
Quick Start
This script provides a simplified, automated installation of OpenAlgo using Docker on Ubuntu/Debian systems with custom domain and SSL.
One-Line Installation
wget https://raw.githubusercontent.com/marketcalls/openalgo/refs/heads/main/install/install-docker.sh && chmod +x install-docker.sh && ./install-docker.shPrerequisites
Fresh Ubuntu 20.04+ or Debian 11+ server
Root access OR non-root user with sudo privileges
Domain name pointed to your server IP
Server with at least 1GB RAM (2GB recommended)
Installation Steps
Option 1: As Non-Root User (Recommended)
Option 2: As Root User
Note: While the script works as root, using a non-root user is recommended for better security in production environments.
Follow the Prompts
The script will ask you for:
Domain name (e.g., demo.openalgo.in)
Broker name from the supported list
Broker API credentials (key and secret)
Market data credentials (for XTS brokers only)
Email for SSL certificate notifications
Confirmation to proceed
What the Script Does
✅ Updates system packages
✅ Installs Docker & Docker Compose
✅ Installs Nginx web server
✅ Installs Certbot for SSL
✅ Clones OpenAlgo repository to
/opt/openalgo✅ Configures environment variables
✅ Sets up firewall (UFW)
✅ Obtains SSL certificate from Let's Encrypt
✅ Configures Nginx with SSL and WebSocket support
✅ Builds and starts Docker container
✅ Creates management helper scripts
Installation typically takes 5-10 minutes.
After Installation
Visit
https://yourdomain.comin your browserCreate your admin account
Login to OpenAlgo
Complete broker authentication using OAuth
Management Commands
The installation creates these helper commands:
Docker Commands
File Locations
Installation
/opt/openalgo
Configuration
/opt/openalgo/.env
Database
Docker volume openalgo_db
Application Logs
/opt/openalgo/log
Broker Logs
/opt/openalgo/logs
Nginx Config
/etc/nginx/sites-available/yourdomain.com
SSL Certificates
/etc/letsencrypt/live/yourdomain.com/
Backups
/opt/openalgo-backups/
Updating OpenAlgo
Troubleshooting
Container not starting:
Permission errors with logs:
WebSocket connection issues:
Nginx issues:
SSL certificate issues:
Docker issues:
Firewall Configuration
The script automatically configures UFW:
Port 22 (SSH) - Open
Port 80 (HTTP) - Open (for SSL renewal)
Port 443 (HTTPS) - Open
Ports 5000, 8765 - Only accessible via localhost (Docker ports)
Security Best Practices
Change default credentials immediately after first login
Keep system updated:
Monitor logs regularly:
Setup automated backups: Create a cron job
Use strong passwords for your OpenAlgo account
Never share broker credentials with anyone
Review firewall rules periodically:
Cloudflare Setup (Optional)
For additional security and CDN benefits:
Add domain to Cloudflare
Sign up at cloudflare.com
Add your domain
Update DNS
In Cloudflare DNS settings:
Create A record pointing to your server IP
Enable proxy (orange cloud icon)
Configure SSL/TLS
Go to SSL/TLS settings
Set mode to "Full (strict)"
Enable "Always Use HTTPS"
Enable WebSockets
Go to Network settings
Enable "WebSockets"
Enable "HTTP/2"
Security Settings (Optional)
Enable "Under Attack Mode" if needed
Set up Page Rules for caching
Configure Firewall Rules
Backup and Restore
Create Backup:
Backups are stored in /opt/openalgo-backups/ and include:
Database
Configuration (.env file)
Strategy files
Last 7 backups are kept automatically
Restore from Backup:
Complete Uninstallation
Getting Help
Documentation: https://docs.openalgo.in
Discord Community: https://discord.com/invite/UPh7QPsNhP
GitHub Issues: https://github.com/marketcalls/openalgo/issues
YouTube Tutorials: https://youtube.com/@openalgoHQ
Website: https://openalgo.in
Supported Brokers
5paisa
fivepaisa
No
5paisa XTS
fivepaisaxts
Yes
AliceBlue
aliceblue
No
Angel One
angel
No
Compositedge
compositedge
Yes
Definedge
definedge
No
Dhan
dhan
No
Dhan Sandbox
dhan_sandbox
No
Firstock
firstock
No
Flattrade
flattrade
No
Fyers
fyers
No
Groww
groww
No
IBulls
ibulls
Yes
IIFL
iifl
Yes
IndMoney
indmoney
No
Kotak
kotak
No
Motilal Oswal
motilal
No
Paytm Money
paytm
No
Pocketful
pocketful
No
Shoonya
shoonya
No
Tradejini
tradejini
No
Upstox
upstox
No
Wisdom Capital
wisdom
Yes
Zebu
zebu
No
Zerodha
zerodha
No
Note: XTS API brokers require additional market data API credentials during installation.
System Requirements
Minimum:
1 vCPU
1GB RAM
10GB disk space
Ubuntu 20.04+ or Debian 11+
Internet connection
Recommended:
2 vCPU
2GB RAM
20GB SSD storage
Ubuntu 22.04 LTS
Stable internet connection
Architecture
FAQ
Q: Can I use this on a server with existing Nginx? A: Yes, but you may need to manually merge configurations to avoid conflicts.
Q: Can I use a different port instead of 443? A: Yes, but you'll need to modify the Nginx configuration manually.
Q: Will this work with a subdomain? A: Yes, the script supports both root domains and subdomains.
Q: Can I run multiple OpenAlgo instances? A: Not with this script. Each installation assumes it's the only instance.
Q: How do I change my broker after installation? A: Edit /opt/openalgo/.env, update broker credentials, then run sudo docker compose restart.
Q: Is my broker data secure? A: Yes, all data is encrypted in transit (HTTPS/WSS) and stored locally on your server.
Q: Can I use this in production? A: Yes, this script is designed for production use with SSL, security headers, and proper firewall configuration.
Q: What if my domain doesn't have an A record yet? A: Wait for DNS propagation (usually 5-60 minutes) before running the script.
Changelog
Version 1.1.0 (October 19, 2024)
Added support for running as root user (with warning)
Fixed permission issues with docker-compose.yaml creation
Improved error handling
Enhanced management scripts
Version 1.0.0 (Initial Release)
Complete automated installation
SSL certificate automation
Docker containerization
Management helper scripts
License
OpenAlgo is released under the AGPL V3.0 License.
Contributing
Contributions are welcome! Please see our Contributing Guide.
Note: This script is designed for fresh server installations. If you have an existing OpenAlgo installation or other applications on the server, please review the script and make necessary adjustments to avoid conflicts.
For production deployments, we strongly recommend:
Using a non-root user
Setting up automated backups
Monitoring logs regularly
Keeping the system updated
Using Cloudflare or similar CDN/DDoS protection
Last updated
Was this helpful?