Providers are a grouping of management systems.
Management systems are at the center of ManageIQ's Provider Integration story.
Manager == ExtManagementSystem
In ManageIQ, managers are the external management systems. This description has changed slightly over time. Originally, providers were external management systems. But, this has rapidly changed as providers became more complex (like OpenStack) and less clearly defined as a manager of a single set of resources. As providers began managing more than one type of main resource, it became clear that providers could be broken down into separate managers.
From a simple point of view, an ExtManagementSystem is a model object representing the details of connecting to and interacting with a provider's manager.
Conceptually, a manager is any system that ManageIQ integrates with for the purpose of collecting data and performing operations.
An example of a manager is Amazon Cloud Manager, known in ManageIQ as Amazon::CloudManager.
ManageIQ currently knows about a few different types of Provider Managers:
- Virtual Infrastructure Manager
- Cloud Manager
- Configuration Manager
- Baremetal Provisioning Manager
- Containers Manager
For each type, we have at least one reference implementation:
- Virtual Infrastructure Manager :: VMWare
- Cloud Manager :: Amazon
- Configuration Manager :: Foreman (Puppet)
- Baremetal Provisioning Manager :: Foreman
- Containers Manager :: Kubernetes / OpenShift
When a new manager is being integrated, it's important to understand whether the new manager is also a new manager type. New manager types take significantly more effort to on-board because it involves understanding what possibly new data models are required for inventory collection, as well as what possibly new event and metrics requirements will crop up.
Integrating with a provider requires looking at six separate areas:
- Inventory
- Event Collection and Handling
- Metric Collection and Handling
- Provisioning and Orchestration
- Lifecycle
- SmartState Analysis
Every manager has an associated inventory. One of the main goals with adding a manager to ManageIQ is to collect the inventory of the manager. Some examples of inventory objects are:
Where inventory collection is essential for understanding what is in a manager, events are essential for understanding what is changing inside the provider over time.
Events can be used to build timelines to view a history of changes over time. Events can also be used to react to those changes by either refreshing the manager's inventory or enforcing policies that apply to the changes witnessed in the events.
Metrics provide details of System Utilization for the manager's inventory objects. For instance, in a Virtual Infrastructure Manager, utilization data can be collected for VMs, Hosts, and Clusters. The utilization data generally comes in the form of one of the following:
- CPU utilization
- Memory utilization
- Disk reads and writes
- Network traffic
These metrics can be used to enforce policies related to capacity planning.
After the metrics are collected, different rollup mechanisms take hold.
Rollups are especially important to understand when implementing a new manager type, because rollups for new manager types may involve infrastructure-based rollups that have not previously exist in ManageIQ.
Provisioning refers to creating new objects in a manager's inventory.
Orchestration is somewhat like provisioning, but on a bigger scale. It can involve provisioning multiple systems in a coordinated effort to accomplish a combined goal.
Orchestration is generally lumped in with provisioning because it tends to share several concepts.
The lifecycle of provider objects can include power operations, retirement, and reconfiguration.
Power operations are the actions that can be performed on existing objects in a manager's inventory. Power operations are separated from provisioning to highlight that the work involved in integrating power operations is generally quite different from the work involved in integrating provisioning capabilities.
Retirement is a manual or scheduled event that runs an automate state machine to decommission a manager's resource. For instance, a user might decide to retire a cloud instance after two weeks.
Reconfiguration allows users to change the settings of a already-running object in a manager's inventory. For instance, reconfiguring a cloud instance might increase the instance's memory or disk space.
SmartState is perhaps the most unique type of manager integration with ManageIQ. SmartState Analysis is the process of examining and collecting details from dormant images and disks.
SmartState integration generally has one main requirement: the appliance running SmartState Analysis needs access to the raw bytes from the images and disks that should be analyzed. Some managers provide this via an API, while other managers provide this with NFS mounts.
When integrating a new manager, it is important to understand two important integration points:
- Data models that represent manager inventory
- Workers that collect data from managers
While the data model is important, the workers are the core to the integration, since they perform all of the tasks for collecting inventory, events, and metrics.
Workers are broken down into three different pieces:
- Model class: app/models/miq_worker.rb
- Worker class: lib/workers/worker_base.rb
- Executable: lib/workers/bin/worker.rb
Workers are all separate processes started and managed by the main server. Worker processes are tracked in the miq_workers
table as instances of the MiqWorker
model object. These records are used by the main server to track the actual worker processes.
An instance of WorkerBase
is where the actual work happens. Each WorkerBase
instance can identify the MiqWorker
record and the MiqWorker
instance can identify its corresponding WorkerBase
class.
Each worker has subclasses that implement specific worker functionality, such as Refresh Workers, Event Catcher Workers, and Metrics Collector Workers.
In many cases, workers are further subclassed by manager to implement manager-specific functionality.
There are three main groups of workers involved in manager integrations:
- Refresh worker, which collects manager inventory
- Event workers, which catch and handle events from managers
- Metrics workers, which collect and process metrics
- Model Class: BaseManager::RefreshWorker
- Worker Class: BaseManager::RefreshWorker::Runner
The Refresh Worker is a queue-based worker, which means that the worker responds to specific messages that appear on the worker queue. Other processes will enqueue a message requesting a refresh of a particular manager.
The Refresh Worker responds to the request to refresh a manager's inventory. These requests can come from several different places:
- Refreshes are triggered for all registered managers when the appliance starts
- Users can initiate a refresh from the Web UI
- Events received from the manager can trigger a refresh
- Refreshes are scheduled to occur once every 24 hours, for all providers, by default
When a refresh request is received by a Refresh Worker, the worker uses the EmsRefresh
module to perform the actual refresh. Each manager implements a refresh process.
Refresh Workers are created for each registered manager. In other words, if you have registered two Amazon Cloud managers, there will be two unique Amazon Refresh Worker processes running.
Amazon Example:
- Model Class:
Amazon::CloudManager::RefreshWorker
- Worker Class:
Amazon::CloudManager::RefreshWorker::Runner
TODO
TODO
- Model Class:
BaseManager::EventCatcher
- Worker Class:
BaseManager::EventCatcher::Runner
Amazon Example:
- Model Class:
Amazon::CloudManager::EventCatcher
- Worker Class:
Amazon::CloudManager::EventCatcher::Runner
The first thing to notice about the EventHandler
is that its parts are still located in the legacy locations with legacy names.
The second thing to notice about the EventHandler
is that there is no manager-specific implementation. All events are handled by the same handler.
- Model Class:
MiqEventHandler
- Worker Class:
EventHandler
TODO
TODO
TODO
- Model Class:
BaseManager::MetricsCollectorWorker
- Worker Class:
BaseManager::MetricsCollectorWorker::Runner
Amazon Example:
- Model Class:
Amazon::CloudManager::MetricsCollectorWorker
- Worker Class:
Amazon::CloudManager::MetricsCollectorWorker::Runner
The MetricsProcessor
worker is similar to the EventHandler
. Its parts are still in the legacy locations, and there is no manager-specific implementation.
- Model Class:
MiqEmsMetricsProcessorWorker
- Worker Class:
EmsMetricsProcessorWorker