Search code examples
redmineswarmpacemaker

Redmine high availability instances


Can anyone provide me with an alternative along with the steps to install Redmine HA instances?

I tried to solve it with Docker swarm, but it seems very sophisticated.


Solution

  • The Redmine application itself is (almost, see below) stateless since all state is kept in the underlying database. You can easily run several instances of Redmine on different servers/VMs, all pointing to a single database (cluster) by specifying the database in database.yml. The only remaining part would be the file attachments stored in files/ within Redmine. You would have to put this on a network share.

    Any loadbalancing capable reverse proxy (e.g. HAProxy) can then be used to distribute requests across your Redmine instances or to implement a failover in case one of them goes down.

    To make your database highly available, you'd have to look into the replication capabilities of your chosen DBMS. For instance, PostgreSQL has a section about HA in its docs.

    It's not black magic but it requires continuous work to make Redmine run fast and reliable at large scale. My company Planio Redmine Hosting does this day in and day out.