<div dir="ltr">Anna,<div><br></div><div>It's good to see progress being made on this blueprint.</div><div>I have some comments inline.</div><div><br></div><div>Also, I would recommend keeping in mind the comments Mark had regarding migration generation and plugin configuration in hist post on the email thread I started.</div>
<div><br></div><div>Salvatore<br><div class="gmail_extra"><br><br><div class="gmail_quote">On 30 April 2014 14:16, Anna Kamyshnikova <span dir="ltr"><<a href="mailto:akamyshnikova@mirantis.com" target="_blank">akamyshnikova@mirantis.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div>Hi everyone!</div><div><br></div><div>I'm working on blueprint <a href="https://blueprints.launchpad.net/neutron/+spec/neutron-robust-db-migrations" target="_blank">https://blueprints.launchpad.net/neutron/+spec/neutron-robust-db-migrations</a>. This topic was discussed earlier by Salvatore in ML thread "Migrations, service plugins and Grenade jobs". I'm researching how to make migrations for service plugins run unconditionally. In fact it is enough to change should_run method for migrations - to make it return True if this migration is for service plugin <a href="https://review.openstack.org/#/c/91323/1/neutron/db/migration/__init__.py" target="_blank">https://review.openstack.org/#/c/91323/1/neutron/db/migration/__init__.py</a>. </div>
</div></blockquote><div><br></div><div>I think running migrations unconditionally for service plugins is an advancement but not yet a final solution.<br></div><div>I would insist on the path you've been pursuing of running unconditionally all migrations. We should strive to solve the issues you found there so far</div>
<div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">
<div>It is almost working except for conflicts of VNPaaS service plugin with Brocade and Nuage plugins <a href="http://paste.openstack.org/show/77946/" target="_blank">http://paste.openstack.org/show/77946/</a>. </div><div>
1) Migration for Brocade plugin fails, because 2c4af419145b_l3_support doesn't run (it adds necessary table 'routers') It can be fixed by adding Brocade plugin to list migration_for_plugins in 2c4af419145b_l3_support.</div>
</div></blockquote><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div>2) Migration for Nuage plugin fails, because e766b19a3bb_nuage_initial runs after 52ff27f7567a_support_for_vpnaas, and there is no necessary table 'routers'. It can be fixed by adding Nuage plugin to list migration_for_plugins in 2c4af419145b_l3_support and removing addition of these tables in e766b19a3bb_nuage_initial.</div>
<div><br></div></div></blockquote><div>I noticed that too in the past.</div><div>However there are two aspects to this fix. The one you're mentioning is for fixing migrations in new deployments; on the other hand migrations should be fixed also for existing deployments. This kind of problem seems to me more concerning the work for removing schema auto-generation. Indeed the root problem here is probably that l3 schemas for these two plugins are being created only because of schema auto-generation.</div>
<div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div></div><div>Also I researched opportunity to make all migrations run unconditionally, but this could not be done as there is going to be a lot of conflicts <a href="http://paste.openstack.org/show/77902/" target="_blank">http://paste.openstack.org/show/77902/</a>. Mostly this conflicts take place in initial migrations for core plugins as they create basical tables that was created before. For example, mlnx_initial create tables securitygroups, securitygroupportbindings, networkdhcpagentbindings, portbindingports that were already created in 3cb5d900c5de_securitygroups, 4692d074d587_agent_scheduler, 176a85fc7d79_add_portbindings_db migrations. Besides I was thinking about 'making migrations smart' - to make them check whether all necessary migrations has been run or not, but the main problem about that is we need to store information about applied migrations, so this should have been planned from the very beginning.</div>
<div><br></div></div></blockquote><div><br></div><div>I agree that just changing migrations to run unconditionally is not a viable solution.</div><div>Rather than changing the existing migration path, I was thinking more about adding "corrective" unconditional migrations to make the database state the same regardless of the plugin configuration. The difficult part here is that these migrations would need to be smart enough to understand whether a previous migration was executed or skipped; this might also break offline migrations (but perhaps this might be tolerable).</div>
<div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div></div><div>I look forward for any suggestions or thoughts on this topic.</div><div><br>
</div><div>Regards, Ann</div></div>
<br>_______________________________________________<br>
OpenStack-dev mailing list<br>
<a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
<br></blockquote></div><br></div></div></div>