RETIRED, Fuel orchestrator
Go to file
Dmitry Guryanov a47336af9d Don't use oflag=direct while erasing bootloader code
We are erasing 446 bytes of bootloader code before rebooting
node, but you can write only blocks with O_DIRECT, so let's
write 446 bytes without oflag=direct and do sync after dd
instead.

Change-Id: I7b5f9749b170a9b7191991dd02cb867bba0e4c43
Partial-Bug: #1573105
Closes-Bug: #1538587
(cherry picked from commit d25a0004d8)
2017-02-13 18:40:40 +02:00
bin Move from amqp-gem to bunny 2015-11-27 02:38:20 +03:00
debian Bump version to 8.0 2015-08-28 16:46:52 +03:00
docs Replaces sourceless javascript 2015-02-28 00:13:40 +01:00
examples Agreed on naming in config file 2015-02-19 15:06:58 +03:00
lib Prevent unexpected exception if provision fail 2016-05-30 14:17:11 +03:00
mcagents Don't use oflag=direct while erasing bootloader code 2017-02-13 18:40:40 +02:00
spec Use mcollective instead of Cobbler fence_ssh to reboot nodes 2016-01-12 10:30:11 +00:00
specs Align rpm spec with the rest fuel packages 2015-12-12 16:31:02 +02:00
tests Update fuel_deployment to 0.3.0 2015-12-21 21:21:58 +03:00
.gitignore Allow to provide timeout for snapshot generation 2015-03-12 11:21:11 +02:00
.gitreview Update paths due to stackforge migration 2015-10-18 01:05:24 +03:00
.rspec Create group of facts as one big fact in yaml format 2013-09-30 08:06:50 +04:00
.ruby-version Deployment artifacts management for upgrades: 2014-04-14 19:36:44 +04:00
Gemfile Fixed openstack-ci jobs 2015-11-17 17:06:43 +03:00
LICENSE LICENCE added 2014-06-05 00:37:57 +04:00
MAINTAINERS Spec for packages MUST be reviewed by mos packaging team 2015-12-20 20:30:00 +00:00
README.md Update paths due to stackforge migration 2015-10-18 01:05:24 +03:00
Rakefile Allow to run only specified spec tests 2015-05-06 09:56:38 +02:00
astute.gemspec Restrict activesupport gem version 2016-10-17 16:24:25 +03:00
astute.service Update astute package 2015-12-03 12:07:55 +00:00
astute.sysconfig Default log level should be debug 2015-12-09 17:53:21 +03:00
run_tests.sh Support Mac OS X to run tests 2015-07-23 16:20:50 +03:00

README.md

Astute

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

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


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.