7d69504cf6
This patch adds the team's and repository's badges to the README file. The motivation behind this is to communicate the project status and features at first glance. For more information about this effort, please read this email thread: http://lists.openstack.org/pipermail/openstack-dev/2016-October/105562.html To see an example of how this would look like check: https://gist.github.com/de41bea42a0fcac0e9d5ab669ec130dc Change-Id: I2f52299e68ed5151ac2016e8ceccf064028f19be
76 lines
2.8 KiB
Markdown
76 lines
2.8 KiB
Markdown
#Astute
|
|
[![Team and repository tags](http://governance.openstack.org/badges/fuel-astute.svg)](http://governance.openstack.org/reference/tags/index.html)
|
|
<!-- Change things from this point on -->
|
|
|
|
Astute is orchestrator, which is using data about nodes and deployment settings performs two things:
|
|
- provision
|
|
- deploy
|
|
|
|
Provision
|
|
-----
|
|
|
|
OS installation on selected nodes.
|
|
|
|
Provisioning is done using Cobbler. Astute orchestrator collects data about nodes and creates corresponding Cobbler systems using parameters specified in engine section of provision data. After the systems are created, it connects to Cobbler engine and reboots nodes according to the power management parameters of the node.
|
|
|
|
Deploy
|
|
-----
|
|
|
|
OpenStack installation in the desired configuration on the selected nodes.
|
|
|
|
Astute uses data about nodes and deployment settings and recalculates parameters needed for deployment. Calculated parameters are passed to the nodes being deployed by use of nailyfact MCollective agent that uploads these attributes to `/etc/astute.yaml` file of the node. Then puppet parses this file using Facter plugin and uploads these facts into puppet. These facts are used during catalog compilation phase by puppet. Finally catalog is executed and Astute orchestrator passes to the next node in deployment sequence. Fuel Library provides puppet modules for Astute.
|
|
|
|
Using as library
|
|
-----
|
|
|
|
```ruby
|
|
require 'astute'
|
|
|
|
class ConsoleReporter
|
|
def report(msg)
|
|
puts msg.inspect
|
|
end
|
|
end
|
|
|
|
reporter = ConsoleReporter.new
|
|
|
|
orchestrator = Astute::Orchestrator.new(log_parsing=false)
|
|
|
|
# Add systems to cobbler, reboot and start installation process.
|
|
orchestrator.provision(reporter, environment['engine'], environment['nodes'])
|
|
|
|
# Observation OS installation
|
|
orchestrator.watch_provision_progress(reporter, environment['task_uuid'], environment['nodes'])
|
|
|
|
# Deploy OpenStack
|
|
orchestrator.deploy(reporter, environment['task_uuid'], environment['nodes'])
|
|
|
|
```
|
|
Example of using Astute as library: lib/astute/server/dispatcher.rb
|
|
|
|
|
|
Using as CLI
|
|
-----
|
|
|
|
CLI interface in Astute no longer supported. Please use new Fuel-CLI. More details you can get by link: https://github.com/openstack/fuel-docs/blob/master/pages/user-guide/cli.rst
|
|
|
|
-----
|
|
|
|
- ISO, other materials: http://fuel.mirantis.com/
|
|
- User guide: http://docs.mirantis.com/
|
|
- Development documentation: http://docs.mirantis.com/fuel-dev/
|
|
|
|
|
|
License
|
|
------
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
not use this file except in compliance with the License. You may obtain
|
|
a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
License for the specific language governing permissions and limitations
|
|
under the License.
|