Configure Load Balancing
AIStor’s distributed architecture allows any node to handle any request. While clients can connect directly to individual nodes, a load balancer provides a single endpoint that simplifies client configuration and automatically routes traffic to healthy nodes.
Load balancers also centralize SSL/TLS certificate management and can terminate encryption at the network edge, reducing computational overhead on AIStor nodes.
Prerequisites
Your load balancer configuration must support these AIStor requirements:
- Dual-service routing: Configure separate routes for the S3 API (port 9000) and Console UI (port 9001).
- Streaming uploads: Allow unlimited request body size and disable request buffering to support uploading objects of any size.
- Streaming downloads: Disable response buffering to support downloading large objects.
Example configurations
These examples show how to implement the prerequisites for common reverse proxies.
Configuration requirements
Configure AIStor with the appropriate environment variable and DNS settings to ensure proper communication through your load balancer.
For detailed information about the MINIO_BROWSER_REDIRECT_URL environment variable and additional console configuration options, see Console Environment Variables.
Verify your configuration
After configuring your load balancer, verify it works correctly using the load balancer’s client-facing IP or hostname before updating production DNS.
-
Test the health endpoint through your load balancer:
curl https://LOAD_BALANCER_IP_OR_HOSTNAME/minio/health/liveExpected response:
200 OKwith bodyOKReplace
LOAD_BALANCER_IP_OR_HOSTNAMEwith your load balancer’s client-facing IP or hostname.For comprehensive health check documentation, see Health Check Probes.
-
Configure and test the AIStor Client connection using your load balancer’s client-facing IP or hostname:
mc alias set myaistor https://LOAD_BALANCER_IP_OR_HOSTNAME ACCESS_KEY SECRET_KEY mc ping myaistor mc ready myaistorReplace
LOAD_BALANCER_IP_OR_HOSTNAMEwith your load balancer’s client-facing IP or hostname, andACCESS_KEYandSECRET_KEYwith appropriate credentials. -
Verify Console UI access by opening
https://LOAD_BALANCER_IP_OR_HOSTNAMEin your web browser, logging in, and browsing objects.Replace
LOAD_BALANCER_IP_OR_HOSTNAMEwith your load balancer’s client-facing IP or hostname.
Update DNS for production
After successfully verifying your load balancer configuration, update your DNS records to point your production endpoints to the load balancer.
Once DNS propagates, clients can access AIStor through the configured domain names.