<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Mon, Sep 7, 2015 at 4:25 PM, Igor Kalnitsky <span dir="ltr"><<a href="mailto:ikalnitsky@mirantis.com" target="_blank">ikalnitsky@mirantis.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span>> that said I no sure anchors are sufficient, we still need priorities to<br>
> specify orders for independant and/or optional plugins (they don't know<br>
> each other)<br>
<br>
</span>If you need this, you're probably doing something wrong. Priorities<br>
won't solve your problem here, because plugins will need to know about<br>
priorities in other plugins and that's weird. </blockquote><div>yes that wired, by convention all LMA plugins have priorities well defined between each other. It works well until we manage all related plugins but reaches its limit for other plugins if we don't align them together.</div><div>This kind of workaround was the only solution at this time...</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">The only working<br>
solution here is to make plugin to know about other plugin if it's<br>
important to make deployment precisely after other plugin.<br>
<span><br>
> So I guess this will break things if we reference in 'require' a<br>
> nonexistent plugin-a-task.<br>
<br>
</span>That's true. I think the right case here is to implement some sort of<br>
conditional tasks, so different tasks will be executed in different<br>
cases.<br>
<span><br></span></blockquote><div>conditional tasks sounds good indeed, how can we bootstrap this feature?</div><div>  </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span>
> About tasks.yaml, we must support it until an equivalent 'deployment order'<br>
> is implemented with plugin-custom-role feature. <br></span></blockquote><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span>
</span>This is not about plugin-custom-role, this is about our task<br>
deployment framework. I heard there were some plans on its<br>
improvements.<br>
<br></blockquote><div>from POV of plugins development, priorities did the trick so far even if it doesn't look like so natural..</div><div>I'm just speaking to provide/preserve the same flexibility within next plugin framework releases.</div><div>If this effort can be made on the whole fuel internals and let plugins enjoy it I would be happy.</div><div>do you have any pointers about these rumours, any BP ?</div><div><br></div><div>--</div><div>BR</div><div>Swann</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Regards,<br>
Igor<br>
<div><div><br>
On Mon, Sep 7, 2015 at 3:27 PM, Swann Croiset <<a href="mailto:scroiset@mirantis.com" target="_blank">scroiset@mirantis.com</a>> wrote:<br>
><br>
><br>
> On Mon, Sep 7, 2015 at 11:12 AM, Igor Kalnitsky <<a href="mailto:ikalnitsky@mirantis.com" target="_blank">ikalnitsky@mirantis.com</a>><br>
> wrote:<br>
>><br>
>> Hi Swann,<br>
>><br>
>> > However, we still need deployment order between independent<br>
>> > plugins and it seems impossible to define the priorities<br>
>><br>
>> There's no such things like priorities for now.. perhaps we can<br>
>> introduce some kind of anchors instead of priorities, but that's<br>
>> another story.<br>
><br>
> yes its another story for next release(s), anchors could reuse the actual<br>
> convention of ranges used (disk, network, software, monitoring)<br>
> that said I no sure anchors are sufficient, we still need priorities to<br>
> specify orders for independant and/or optional plugins (they don't know each<br>
> other)<br>
><br>
><br>
>><br>
>> Currently the only way to synchronize two plugins is to make one to<br>
>> know about other one. That means you need to properly setup "requires"<br>
>> field:<br>
>><br>
>>     - id: my-plugin-b-task<br>
>>       type: puppet<br>
>>       role: [my-plugin-b-role]<br>
>>       required_for: [post_deployment_end]<br>
>>       requires: [post_deployment_start, PLUGIN-A-TASK]<br>
>>       parameters:<br>
>>         puppet_manifest: some-puppet.pp<br>
>>         puppet_modules: /etc/puppet/modules<br>
>>         timeout: 3600<br>
>>         cwd: /<br>
>><br>
> We thought about this solution _but_ in our case we cannot because the<br>
> plugin is optional and may not be installed/enabled. So I guess this will<br>
> break things if we reference in 'require' a nonexistent plugin-a-task.<br>
> For example with LMA plugins, the LMA-Collector plugin must be<br>
> deployed/installed before LMA-Infrastructure-Alerting plugin (to avoid false<br>
> alerts UNKNOWN state) but the last may not be enabled for the deployment.<br>
><br>
>> Thanks,<br>
>> Igor<br>
>><br>
><br>
> About tasks.yaml, we must support it until an equivalent 'deployment order'<br>
> is implemented with plugin-custom-role feature.<br>
><br>
>><br>
>> On Mon, Sep 7, 2015 at 11:31 AM, Swann Croiset <<a href="mailto:scroiset@mirantis.com" target="_blank">scroiset@mirantis.com</a>><br>
>> wrote:<br>
>> > Hi fuelers,<br>
>> ><br>
>> > We're currently porting nearly all LMA plugins to the new plugin fwk<br>
>> > 3.0.0<br>
>> > to leverage custom role capabilities.<br>
>> > That brings up a lot of simplifications for node assignment, disk<br>
>> > management, network config, reuse core tasks and so on .. thanks to the<br>
>> > fwk.<br>
>> ><br>
>> > However, we still need deployment order between independent plugins and<br>
>> > it<br>
>> > seems impossible to define the priorities [0] in deployment_tasks.yaml,<br>
>> > The only way to preserve deployment order would be to keep tasks.yaml<br>
>> > too.<br>
>> ><br>
>> > So, I'm wondering if this is the recommended solution to address plugins<br>
>> > order deployment with plugin fwk 3.0.0?<br>
>> > And furthermore if tasks.yaml will still be supported in future by the<br>
>> > plugin fwk or if the fwk shouldn't evolve  by adding priorities<br>
>> > definitions<br>
>> > in deployment_tasks.yaml ?<br>
>> ><br>
>> > Thanks<br>
>> ><br>
>> > [0]<br>
>> > <a href="https://wiki.openstack.org/wiki/Fuel/Plugins#Plugins_deployment_order" rel="noreferrer" target="_blank">https://wiki.openstack.org/wiki/Fuel/Plugins#Plugins_deployment_order</a><br>
>> ><br>
>> ><br>
>> > __________________________________________________________________________<br>
>> > OpenStack Development Mailing List (not for usage questions)<br>
>> > Unsubscribe:<br>
>> > <a href="http://OpenStack-dev-request@lists.openstack.org?subject:unsubscribe" rel="noreferrer" target="_blank">OpenStack-dev-request@lists.openstack.org?subject:unsubscribe</a><br>
>> > <a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" rel="noreferrer" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
>> ><br>
>><br>
>> __________________________________________________________________________<br>
>> OpenStack Development Mailing List (not for usage questions)<br>
>> Unsubscribe: <a href="http://OpenStack-dev-request@lists.openstack.org?subject:unsubscribe" rel="noreferrer" target="_blank">OpenStack-dev-request@lists.openstack.org?subject:unsubscribe</a><br>
>> <a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" rel="noreferrer" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
><br>
><br>
><br>
> __________________________________________________________________________<br>
> OpenStack Development Mailing List (not for usage questions)<br>
> Unsubscribe: <a href="http://OpenStack-dev-request@lists.openstack.org?subject:unsubscribe" rel="noreferrer" target="_blank">OpenStack-dev-request@lists.openstack.org?subject:unsubscribe</a><br>
> <a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" rel="noreferrer" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
><br>
<br>
__________________________________________________________________________<br>
OpenStack Development Mailing List (not for usage questions)<br>
Unsubscribe: <a href="http://OpenStack-dev-request@lists.openstack.org?subject:unsubscribe" rel="noreferrer" target="_blank">OpenStack-dev-request@lists.openstack.org?subject:unsubscribe</a><br>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" rel="noreferrer" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
</div></div></blockquote></div><br></div></div>