Public relays
iroh is configured with a set of public relays provided by The n0 team that are free to use. The public relays rate-limit traffic that flows through the relay. This is to prevent abuse, and ensure the relays are available to everyone. There are no guarantees around uptime or performance when using the public relays. We recommend using the public relays for development and testing, as they are free to use and require no setup. However, for production systems, we recommend using dedicated relays instead.Dedicated relays
For production use, we recommend using dedicated relays. Dedicated relays are relay servers that are either self-hosted or provided as a managed service. Dedicated relays provide better performance, security, and uptime guarantees compared to the public relays. Relay code is open source! You can run your own relay server, or pick a hosting provider.Why this architecture is powerful
This approach makes uptime management significantly easier compared to traditional client-server architectures: Stateless servers, stateful clientsUnlike traditional servers that store your application’s data and state, relay servers are just connection facilitators. All your business logic and data lives in your clients. This means:
- No database synchronization - You don’t need to worry about keeping multiple server databases in sync or handling data replication
- No state migration - When a relay goes down, clients simply reconnect to another relay without any data loss or state transfer
- Simple server management - Relay servers are lightweight and easy to spin up or down. No complex deployment procedures or data migration steps
iroh clients automatically try multiple relays when connecting. If one relay is unavailable, clients seamlessly fall back to another relay in your list without application-level retry logic. Your peers will find each other as long as at least one relay is reachable. Multi-cloud resilience
For even better guarantees, you can distribute relays across multiple cloud providers. If one provider experiences an outage, your application keeps running on relays hosted elsewhere. Since relays don’t store state, you can freely mix providers without worrying about cross-cloud data consistency. Cost-effective scaling
Adding capacity means spinning up more lightweight relay instances, not provisioning databases or managing complex stateful server infrastructure. You can easily scale up for peak usage and scale down during quiet periods. This architecture inverts the traditional model: instead of treating servers as precious stateful resources and clients as disposable, relay-based architectures treat relays as disposable connection facilitators while clients own the application state and logic.