<div dir="ltr"><div><br></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Feb 28, 2020 at 12:21 AM <<a href="mailto:Dong.Ding@dell.com">Dong.Ding@dell.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">





<div lang="EN-US">
<div class="gmail-m_135476853295987373WordSection1">
<p class="MsoNormal">Thanks Gotham,<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">We are talking about this feature <b>after U release</b>. <u></u>
<u></u></p>
<p class="MsoNormal">Cannot get it done in recently.<u></u><u></u></p>
<p class="MsoNormal">Just do some prepare first.</p></div></div></blockquote><div><br></div><div>Great, thanks for confirming. We'll hash out the design on the specification, and if necessary, we can work through it during the Open Infra Project Technical Gathering in June [8][9]</div><div><br></div><div>[8] <a href="https://www.openstack.org/ptg/">https://www.openstack.org/ptg/</a></div><div>[9]  <a href="https://etherpad.openstack.org/p/vancouver-ptg-manila-planning">https://etherpad.openstack.org/p/vancouver-ptg-manila-planning</a></div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div lang="EN-US"><div class="gmail-m_135476853295987373WordSection1"><p class="MsoNormal"><u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">BR,<u></u><u></u></p>
<p class="MsoNormal">Ding Dong<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal"><b>From:</b> Goutham Pacha Ravi <<a href="mailto:gouthampravi@gmail.com" target="_blank">gouthampravi@gmail.com</a>> <br>
<b>Sent:</b> Friday, February 28, 2020 7:10 AM<br>
<b>To:</b> Ding, Dong<br>
<b>Cc:</b> OpenStack Discuss<br>
<b>Subject:</b> Re: [manila] share group replication spike/questions<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<div>
<p><span style="color:rgb(206,17,38)">[EXTERNAL EMAIL] <u></u><u></u></span></p>
</div>
<div>
<div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
</div>
<p class="MsoNormal"><u></u> <u></u></p>
<div>
<div>
<p class="MsoNormal">On Tue, Feb 25, 2020 at 12:53 AM <<a href="mailto:Dong.Ding@dell.com" target="_blank">Dong.Ding@dell.com</a>> wrote:<u></u><u></u></p>
</div>
<blockquote style="border-color:currentcolor currentcolor currentcolor rgb(204,204,204);border-style:none none none solid;border-width:medium medium medium 1pt;padding:0in 0in 0in 6pt;margin-left:4.8pt;margin-right:0in">
<div>
<div>
<p class="MsoNormal">Hi, guys,<u></u><u></u></p>
<p class="MsoNormal">As we talked about the topic in a virtual PTG few months ago.<u></u><u></u></p>
<p class="MsoNormal"><a href="https://etherpad.openstack.org/p/shanghai-ptg-manila-virtual" target="_blank">https://etherpad.openstack.org/p/shanghai-ptg-manila-virtual</a> (<b>Support promoting several
 shares in group (DELL EMC: dingdong) </b><u></u><u></u></p>
<p class="MsoNormal"> <u></u><u></u></p>
<p class="MsoNormal">I’m trying to write a manila-spec for it.<u></u><u></u></p>
</div>
</div>
</blockquote>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal">Hi, thank you for working on this, and for submitting a specification [0]. We're targeting this for the Victoria release, correct? I like working on these major changes as soon as possible giving us enough air time for testing and hardening.
<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> <u></u><u></u></p>
</div>
<blockquote style="border-color:currentcolor currentcolor currentcolor rgb(204,204,204);border-style:none none none solid;border-width:medium medium medium 1pt;padding:0in 0in 0in 6pt;margin-left:4.8pt;margin-right:0in">
<div>
<div>
<p class="MsoNormal">It’s my first experience to implement such feature in framework.<u></u><u></u></p>
<p class="MsoNormal">I need to double check with you something, and hope you can give me some guides like:<u></u><u></u></p>
<p class="gmail-m_135476853295987373gmail-m-7980980600882166521msolistparagraph" style="margin-left:0.75in">
1.<span style="font-size:7pt;font-family:"Times New Roman",serif">               
</span>Where is the extra-spec defined for group/group type, it’s in Manila repo, right? (like manila.db.sqlalchemy.models….)  
<u></u><u></u></p>
</div>
</div>
</blockquote>
<div>
<p class="MsoNormal">Group type extra specs are added as storage capabilities first, you begin by modifying the driver interface to report this group type capability. When share drivers report their support for group replication, operators can use the corresponding
 string in their group type extra-specs to schedule appropriately. I suggest taking a look at an existing share group type capability called "consistent_snapshot_support". [1] and [2] are reviews that added it.
<u></u><u></u></p>
</div>
<blockquote style="border-color:currentcolor currentcolor currentcolor rgb(204,204,204);border-style:none none none solid;border-width:medium medium medium 1pt;padding:0in 0in 0in 6pt;margin-left:4.8pt;margin-right:0in">
<div>
<div>
<p class="gmail-m_135476853295987373gmail-m-7980980600882166521msolistparagraph" style="margin-left:0.75in">
2.<span style="font-size:7pt;font-family:"Times New Roman",serif">               
</span>The command cli should be implemented for ‘python-manilaclinet’ repo, right?  (I have never touched this repo before)<u></u><u></u></p>
</div>
</div>
</blockquote>
<div>
<p class="MsoNormal">Yes. python-manilaclient encompasses<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">  - a python SDK to version 2 of the manila API<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">  - two shell implementations: manila and openstack client (actively being developed)<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal">Group type extra-specs are passed transparently through the SDK and CLI, you may probably add some documentation or shell hint text (like [3] if needed).
<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal"> <u></u><u></u></p>
</div>
<blockquote style="border-color:currentcolor currentcolor currentcolor rgb(204,204,204);border-style:none none none solid;border-width:medium medium medium 1pt;padding:0in 0in 0in 6pt;margin-left:4.8pt;margin-right:0in">
<div>
<div>
<p class="gmail-m_135476853295987373gmail-m-7980980600882166521msolistparagraph" style="margin-left:0.75in">
3.<span style="font-size:7pt;font-family:"Times New Roman",serif">               
</span>Where is the rest-api should be implemented?   <u></u><u></u></p>
</div>
</div>
</blockquote>
<div>
<p class="MsoNormal">The rest API is in the openstack/manila repository. [4][5] contain some documentation regarding how to change the manila API.<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> <u></u><u></u></p>
</div>
<blockquote style="border-color:currentcolor currentcolor currentcolor rgb(204,204,204);border-style:none none none solid;border-width:medium medium medium 1pt;padding:0in 0in 0in 6pt;margin-left:4.8pt;margin-right:0in">
<div>
<div>
<p class="gmail-m_135476853295987373gmail-m-7980980600882166521msolistparagraph" style="margin-left:0.75in">
4.<span style="font-size:7pt;font-family:"Times New Roman",serif">               
</span>And more tips you have? like any other related project should be changed?<u></u><u></u></p>
</div>
</div>
</blockquote>
<div>
<p class="MsoNormal">For any new feature, we need these additional things besides working code:<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">- A first party driver implementation where possible so we can test this feature in the upstream CI (if no first party driver can support this feature, you'll need to make the best approximation of this feature through the Dummy/Fake driver
 [6])<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">- The feature must be tested with adequate test cases in manila-tempest-plugin<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">- Documentation must be added to the manila documentation [7]<u></u><u></u></p>
</div>
<blockquote style="border-color:currentcolor currentcolor currentcolor rgb(204,204,204);border-style:none none none solid;border-width:medium medium medium 1pt;padding:0in 0in 0in 6pt;margin-left:4.8pt;margin-right:0in">
<div>
<div>
<p class="MsoNormal">Just list what I know, and more details questions will be raised when implementing, I think.<u></u><u></u></p>
<p class="MsoNormal">FYI<u></u><u></u></p>
<p class="MsoNormal">Thanks,<u></u><u></u></p>
<p class="MsoNormal">Ding Dong<u></u><u></u></p>
</div>
</div>
</blockquote>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal">Happy to answer any more questions, here or on your specification [0]<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal">Thanks, <u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">Goutham<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal">[0] <a href="https://review.opendev.org/#/c/710166/" target="_blank">https://review.opendev.org/#/c/710166/</a><u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">[1] <a href="https://review.opendev.org/#/c/446044/" target="_blank">https://review.opendev.org/#/c/446044/</a><u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">[2] <a href="https://review.opendev.org/#/c/447474/" target="_blank">https://review.opendev.org/#/c/447474/</a><u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">[3] <a href="https://opendev.org/openstack/python-manilaclient/src/commit/ac5ca461e8c8dd11fe737de7b90ab5c33366ab35/manilaclient/v2/shell.py#L4543" target="_blank">
https://opendev.org/openstack/python-manilaclient/src/commit/ac5ca461e8c8dd11fe737de7b90ab5c33366ab35/manilaclient/v2/shell.py#L4543</a><u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">[4] <a href="https://docs.openstack.org/manila/latest/contributor/addmethod.openstackapi.html" target="_blank">
https://docs.openstack.org/manila/latest/contributor/addmethod.openstackapi.html</a><u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">[5] <a href="https://docs.openstack.org/manila/latest/contributor/api_microversion_dev.html" target="_blank">
https://docs.openstack.org/manila/latest/contributor/api_microversion_dev.html</a><u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">[6] <a href="https://opendev.org/openstack/manila/src/commit/68a18f49472ac7686ceab15e9788dcef05764822/manila/tests/share/drivers/dummy.py" target="_blank">
https://opendev.org/openstack/manila/src/commit/68a18f49472ac7686ceab15e9788dcef05764822/manila/tests/share/drivers/dummy.py</a><u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">[7] <a href="https://docs.openstack.org/manila/latest/contributor/documenting_your_work.html" target="_blank">
https://docs.openstack.org/manila/latest/contributor/documenting_your_work.html</a><u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
</div>
</div>
</div>
</div>

</blockquote></div></div>