-
Notifications
You must be signed in to change notification settings - Fork 168
Orchestrator deployment
NOTE: orchestrator
development is now active on https://github.com/github/orchestrator, where Issues and Pull Requests are accepted.
This repository is no longer the upstream and latest version of orchestrator
.
The documentation in this repository is not up-to-date.
This text discusses deployment options for orchestrator.
It is assumed you already know how to install orchestrator on a production machine and how to configure it with a backend database. It is also assumed you have configured your MySQL servers to allow connections from orchestrator. If not, please refer to the installation section
The following hints should clear up some questions:
-
Orchestrator can run as a linux service
- When running as a service, it assumes the role of continuous discovery: a never ending polling of your MySQL topologies
- When running as a service, it also provides HTTP API/Web interface
-
Orchestrator can run in command line mode
- Useful for us CLI geeks who want to have greater control and capture all the lovely debug messages
- Orchestrator uses a MySQL backend.
- The backend database has the state of your topologies. Orchestrator is almost stateless.
- Orchestrator only has state for pending operations (e.g. while a slave is being moved)
- The backend database will have the state of your multiple topologies.
- You can and should have more than one orchestrator running with the same MySQL backend.
- You should not have more than one MySQL backend.
The MySQL backend is a master server, for which you may have slaves for redundancy or otherwise build your favorite HA solution.
The author of orchestrator has deployed it in large environments of thousands of servers, with a single backend database managing them all.
- You can and should have multiple orchestrator services running on different machines, all running on the same backend database.
- When running as a service, orchestrator repeatedly attempts to claim leadership. Should one orchestrator service fail, another one will pick up where it left.
- Only one service will be the leader at any given time.
- The leader is the one polling for servers; doing database cleanup; checking for crash recovery scenarios etc.
- You may choose to have all your orchestrator services load-balanced
- You can and should have as many deployments of orchestrator CLI as you like, on multiple servers, all configured to work with the same backend MySQL
- You may concurrently issue commands from multiple CLIs, as well as working with the Web UI at the same time.
- The (single) MySQL backend has the necessary state for managing concurrent operations.
- Orchestrator has "maintenance locks" which prevent destructive concurrent operations on the same instance. At worst an operation will be rejected due to not being able to acquire maintenance lock.
The author of orchestrator has it deployed on multiple machines as a service, behind a F5 load balancer. On the same setup, CLI is deployed and can be executed from thousands of machines.
In the above four orchestrator services are behind an HTTP load balancer. Only one of them is the leader at any given time; they compete for leadership between themselves and recognize if the leader is non doing its duty.
To the right: the many topologies polled by orchestrator. The leader polls each an every server in those topologies.
On top left: the orchestrator MySQL backend: a master & three slaves. All 4 services use the same backend database.
Not shown in this picture (for clarity purposes), but the orchestrator backend database and its slaves are themselves one of those topologies polled by orchestrator It eats its own dogfood.
On left, bottom: orchestrator CLI is installed on any and all MySQL servers. All these CLI deployments use the very same MySQL backend database.
Not shown in this picture (for clarity purposes), the MySQL servers on these hosts are being polled by orchestrator just as those on the right.
You may choose to install orchestrator on non-MySQL hosts, of course. It has no MySQL dependencies on the deployed host.