[openstack-dev] [Fuel] Plugable solution for running abstract commands on nodes
Dmitriy Shulyak
dshulyak at mirantis.com
Wed Sep 10 15:04:47 UTC 2014
Hi folks,
Some of you may know that there is ongoing work to achieve kindof
data-driven orchestration
for Fuel. If this is new to you, please get familiar with spec:
https://review.openstack.org/#/c/113491/
Knowing that running random command on nodes will be probably most usable
type of
orchestration extension, i want to discuss our solution for this problem.
Plugin writer will need to do two things:
1. Provide custom task.yaml (i am using /etc/puppet/tasks, but this is
completely configurable,
we just need to reach agreement)
/etc/puppet/tasks/echo/task.yaml
with next content:
type: exec
cmd: echo 1
2. Provide control plane with orchestration metadata
/etc/fuel/tasks/echo_task.yaml
controller:
-
task: echo
description: Simple echo for you
priority: 1000
compute:
-
task: echo
description: Simple echo for you
priority: 1000
This is done in order to separate concerns of orchestration logic and tasks.
>From plugin writer perspective it is far more usable to provide exact
command in orchestration metadata itself, like:
/etc/fuel/tasks/echo_task.yaml
controller:
-
task: echo
description: Simple echo for you
priority: 1000
cmd: echo 1
type: exec
compute:
-
task: echo
description: Simple echo for you
priority: 1000
cmd: echo 1
type: exec
I would prefer to stick to the first, because there is benefits of using
one interface between all tasks executors (puppet, exec, maybe chef), which
will improve debuging and development process.
So my question is first - good enough? Or second is essential type of
plugin to support?
If you want additional implementation details check:
https://review.openstack.org/#/c/118311/
https://review.openstack.org/#/c/113226/
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.openstack.org/pipermail/openstack-dev/attachments/20140910/e15f3551/attachment.html>
More information about the OpenStack-dev
mailing list