<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<!--[if !mso]><style>v\:* {behavior:url(#default#VML);}
o\:* {behavior:url(#default#VML);}
w\:* {behavior:url(#default#VML);}
.shape {behavior:url(#default#VML);}
</style><![endif]--><style><!--
/* Font Definitions */
@font-face
{font-family:"Cambria Math";
panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
{font-family:Calibri;
panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
{margin:0in;
margin-bottom:.0001pt;
font-size:12.0pt;
font-family:"Times New Roman",serif;}
a:link, span.MsoHyperlink
{mso-style-priority:99;
color:blue;
text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
{mso-style-priority:99;
color:purple;
text-decoration:underline;}
p
{mso-style-priority:99;
mso-margin-top-alt:auto;
margin-right:0in;
mso-margin-bottom-alt:auto;
margin-left:0in;
font-size:12.0pt;
font-family:"Times New Roman",serif;}
tt
{mso-style-priority:99;
font-family:"Courier New";}
span.EmailStyle19
{mso-style-type:personal-reply;
font-family:"Calibri",sans-serif;
color:#1F497D;}
.MsoChpDefault
{mso-style-type:export-only;
font-size:10.0pt;}
@page WordSection1
{size:8.5in 11.0in;
margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
{page:WordSection1;}
/* List Definitions */
@list l0
{mso-list-id:286854710;
mso-list-template-ids:-1296517942;}
@list l0:level1
{mso-level-number-format:bullet;
mso-level-text:\F0B7;
mso-level-tab-stop:.5in;
mso-level-number-position:left;
text-indent:-.25in;
mso-ansi-font-size:10.0pt;
font-family:Symbol;}
@list l0:level2
{mso-level-number-format:bullet;
mso-level-text:\F0B7;
mso-level-tab-stop:1.0in;
mso-level-number-position:left;
text-indent:-.25in;
mso-ansi-font-size:10.0pt;
font-family:Symbol;}
@list l0:level3
{mso-level-number-format:bullet;
mso-level-text:\F0B7;
mso-level-tab-stop:1.5in;
mso-level-number-position:left;
text-indent:-.25in;
mso-ansi-font-size:10.0pt;
font-family:Symbol;}
@list l0:level4
{mso-level-number-format:bullet;
mso-level-text:\F0B7;
mso-level-tab-stop:2.0in;
mso-level-number-position:left;
text-indent:-.25in;
mso-ansi-font-size:10.0pt;
font-family:Symbol;}
@list l0:level5
{mso-level-number-format:bullet;
mso-level-text:\F0B7;
mso-level-tab-stop:2.5in;
mso-level-number-position:left;
text-indent:-.25in;
mso-ansi-font-size:10.0pt;
font-family:Symbol;}
@list l0:level6
{mso-level-number-format:bullet;
mso-level-text:\F0B7;
mso-level-tab-stop:3.0in;
mso-level-number-position:left;
text-indent:-.25in;
mso-ansi-font-size:10.0pt;
font-family:Symbol;}
@list l0:level7
{mso-level-number-format:bullet;
mso-level-text:\F0B7;
mso-level-tab-stop:3.5in;
mso-level-number-position:left;
text-indent:-.25in;
mso-ansi-font-size:10.0pt;
font-family:Symbol;}
@list l0:level8
{mso-level-number-format:bullet;
mso-level-text:\F0B7;
mso-level-tab-stop:4.0in;
mso-level-number-position:left;
text-indent:-.25in;
mso-ansi-font-size:10.0pt;
font-family:Symbol;}
@list l0:level9
{mso-level-number-format:bullet;
mso-level-text:\F0B7;
mso-level-tab-stop:4.5in;
mso-level-number-position:left;
text-indent:-.25in;
mso-ansi-font-size:10.0pt;
font-family:Symbol;}
ol
{margin-bottom:0in;}
ul
{margin-bottom:0in;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="EN-US" link="blue" vlink="purple">
<div class="WordSection1">
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri",sans-serif;color:#1F497D">Thanks for all the information.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri",sans-serif;color:#1F497D"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri",sans-serif;color:#1F497D">Yeah, hope that we can help a session about auto-scaling this summit.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri",sans-serif;color:#1F497D"><o:p> </o:p></span></p>
<div>
<div style="border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0in 0in 0in">
<p class="MsoNormal"><b><span style="font-size:11.0pt;font-family:"Calibri",sans-serif">From:</span></b><span style="font-size:11.0pt;font-family:"Calibri",sans-serif"> Ton Ngo [mailto:ton@us.ibm.com]
<br>
<b>Sent:</b> Friday, August 19, 2016 4:19 AM<br>
<b>To:</b> OpenStack Development Mailing List (not for usage questions) <openstack-dev@lists.openstack.org><br>
<b>Subject:</b> Re: [openstack-dev] [Magnum] Next auto-scaling feature design?<o:p></o:p></span></p>
</div>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
<p>We have had numerous discussion on this topic, including a presentation and a design session
<br>
in Tokyo, but we have not really arrived at a consensus yet. Part of the problem is that auto-scaling
<br>
at the container level is still being developed, so it is still a moving target.<br>
However, a few points did emerge from the discussion (not necessarily consensus):
<o:p></o:p></p>
<ul type="disc">
<li class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;mso-list:l0 level1 lfo1">
It's preferable to have a single point of decision on auto-scaling for both the container and infrastructure level.<br>
One approach is to make this decision at the container orchestration level, so the infrastructure level would just
<br>
provide the service to handle request to scale the infrastructure. This would require coordinating support with
<br>
upstream like Kubernetes. This approach also means that we don't want a major component in Magnum to
<br>
drive auto-scaling. <o:p></o:p></li><li class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;mso-list:l0 level1 lfo1">
It's good to have a policy-driven mechanism for auto-scaling to handle complex scenarios. For this, Senlin
<br>
is a candidate; upstream is another potential choice. <o:p></o:p></li></ul>
<p class="MsoNormal">We may want to revisit this topic as a design session in the next summit.<br>
Ton Ngo,<br>
<br>
<img width="16" height="16" style="width:.1666in;height:.1666in" id="_x0000_i1025" src="cid:image001.gif@01D1FA22.C8D3A280" alt="Inactive hide details for Hongbin Lu ---08/18/2016 12:26:07 PM---> -----Original Message----- > From: hieulq@vn.fujitsu.com [ma"><span style="color:#424282">Hongbin
Lu ---08/18/2016 12:26:07 PM---> -----Original Message----- > From: <a href="mailto:hieulq@vn.fujitsu.com">
hieulq@vn.fujitsu.com</a> [<a href="mailto:hieulq@vn.fujitsu.com">mailto:hieulq@vn.fujitsu.com</a>]</span><br>
<br>
<span style="font-size:10.0pt;color:#5F5F5F">From: </span><span style="font-size:10.0pt">Hongbin Lu <<a href="mailto:hongbin.lu@huawei.com">hongbin.lu@huawei.com</a>></span><br>
<span style="font-size:10.0pt;color:#5F5F5F">To: </span><span style="font-size:10.0pt">"OpenStack Development Mailing List (not for usage questions)" <<a href="mailto:openstack-dev@lists.openstack.org">openstack-dev@lists.openstack.org</a>></span><br>
<span style="font-size:10.0pt;color:#5F5F5F">Date: </span><span style="font-size:10.0pt">08/18/2016 12:26 PM</span><br>
<span style="font-size:10.0pt;color:#5F5F5F">Subject: </span><span style="font-size:10.0pt">Re: [openstack-dev] [Magnum] Next auto-scaling feature design?</span><o:p></o:p></p>
<div class="MsoNormal">
<hr size="2" width="100%" noshade="" style="color:#8091A5" align="left">
</div>
<p class="MsoNormal" style="margin-bottom:12.0pt"><br>
<br>
<br>
<span style="font-size:10.0pt;font-family:"Courier New""><br>
<br>
<tt>> -----Original Message-----</tt><br>
<tt>> From: <a href="mailto:hieulq@vn.fujitsu.com">hieulq@vn.fujitsu.com</a> [<a href="mailto:hieulq@vn.fujitsu.com">mailto:hieulq@vn.fujitsu.com</a>]</tt><br>
<tt>> Sent: August-18-16 3:57 AM</tt><br>
<tt>> To: <a href="mailto:openstack-dev@lists.openstack.org">openstack-dev@lists.openstack.org</a></tt><br>
<tt>> Subject: [openstack-dev] [Magnum] Next auto-scaling feature design?</tt><br>
<tt>> </tt><br>
<tt>> Hi Magnum folks,</tt><br>
<tt>> </tt><br>
<tt>> I have some interests in our auto scaling features and currently</tt><br>
<tt>> testing with some container monitoring solutions such as heapster,</tt><br>
<tt>> telegraf and prometheus. I have seen the PoC session corporate with</tt><br>
<tt>> Senlin in Austin and have some questions regarding of this design:</tt><br>
<tt>> - We have decided to move all container management from Magnum to Zun,</tt><br>
<tt>> so is there only one level of scaling (node) instead of both node and</tt><br>
<tt>> container?</tt><br>
<tt>> - The PoC design show that Magnum (Magnum Scaler) need to depend on</tt><br>
<tt>> Heat/Ceilometer for gathering metrics and do the scaling work based on</tt><br>
<tt>> auto scaling policies, but is Heat/Ceilometer is the best choice for</tt><br>
<tt>> Magnum auto scaling?</tt><br>
<tt>> </tt><br>
<tt>> Currently, I saw that Magnum only send CPU and Memory metric to</tt><br>
<tt>> Ceilometer, and Heat can grab these to decide the right scaling method.</tt><br>
<tt>> IMO, this approach have some problems, please take a look and give</tt><br>
<tt>> feedbacks:</tt><br>
<tt>> - The AutoScaling Policy and AutoScaling Resource of Heat cannot handle</tt><br>
<tt>> complex scaling policies. For example:</tt><br>
<tt>> If CPU > 80% then scale out</tt><br>
<tt>> If Mem < 40% then scale in</tt><br>
<tt>> -> What if CPU = 90% and Mem = 30%, the conflict policy will appear.</tt><br>
<tt>> There are some WIP patch-set of Heat conditional logic in [1]. But IMO,</tt><br>
<tt>> the conditional logic of Heat also cannot resolve the conflict of</tt><br>
<tt>> scaling policies. For example:</tt><br>
<tt>> If CPU > 80% and Mem >70% then scale out If CPU < 30% or Mem < 50% then</tt><br>
<tt>> scale in</tt><br>
<tt>> -> What if CPU = 90% and Mem = 30%.</tt><br>
<tt>> Thus, I think that we need to implement magnum scaler for validating</tt><br>
<tt>> the policy conflicts.</tt><br>
<tt>> - Ceilometer may have troubles if we deploy thousands of COE.</tt><br>
<tt>> </tt><br>
<tt>> I think we need a new design for auto scaling feature, not for Magnum</tt><br>
<tt>> only but also Zun (because the scaling level of container maybe forked</tt><br>
<tt>> to Zun too). Here are some ideas:</tt><br>
<tt>> 1. Add new field enable_monitor to cluster template (ex baymodel) and</tt><br>
<tt>> show the monitoring URL when creating cluster (bay) complete. For</tt><br>
<tt>> example, we can use Prometheus as monitoring container for each cluster.</tt><br>
<tt>> (Heapster is the best choice for k8s, but not good enough for swarm or</tt><br>
<tt>> mesos).</tt><br>
<br>
<tt>[Hongbin Lu] Personally, I think this is a good idea.</tt><br>
<br>
<tt>> 2. Create Magnum scaler manager (maybe a new service):</tt><br>
<tt>> - Monitoring enabled monitor cluster and send metric to ceilometer if</tt><br>
<tt>> need.</tt><br>
<tt>> - Manage user-defined scaling policy: not only cpu and memory but also</tt><br>
<tt>> other metrics like network bw, CCU.</tt><br>
<tt>> - Validate user-defined scaling policy and trigger heat for scaling</tt><br>
<tt>> actions. (can trigger nova-scheduler for more scaling options)</tt><br>
<tt>> - Need highly scalable architecture, first step we can implement simple</tt><br>
<tt>> validator method but in the future, there are some other approach such</tt><br>
<tt>> as using fuzzy logic or AI to make an appropriate decision.</tt><br>
<br>
<tt>[Hongbin Lu] I think this is a valid requirement but I wonder why you want it in Magnum. However, if you have a valid reason to do that, you can create a custom bay driver. You can add logic to the custom driver to retrieve metrics from the monitoring URL
and send them to ceilometers. Users can pass scaling policy via "labels" when they create the bay. The custom driver is responsible to validate the policy and trigger the action based on that. Does it satisfy your requirement?</tt><br>
<br>
<tt>> </tt><br>
<tt>> Some use case for operators:</tt><br>
<tt>> - I want to create a k8s cluster, and if CCU or network bandwidth is</tt><br>
<tt>> high please scale-out X nodes in other regions.</tt><br>
<tt>> - I want to create swarm cluster, and if CPU or memory is too high,</tt><br>
<tt>> please scale-out X nodes to make sure total CPU and memory is about 50%.</tt><br>
<tt>> </tt><br>
<tt>> What do you think about these above ideas/problems?</tt><br>
<tt>> </tt><br>
<tt>> [1]. <a href="https://blueprints.launchpad.net/heat/+spec/support-conditions-">
https://blueprints.launchpad.net/heat/+spec/support-conditions-</a></tt><br>
<tt>> function</tt><br>
<tt>> </tt><br>
<tt>> Thanks,</tt><br>
<tt>> Hieu LE.</tt><br>
<tt>> </tt><br>
<tt>> </tt><br>
<tt>> _______________________________________________________________________</tt><br>
<tt>> ___</tt><br>
<tt>> OpenStack Development Mailing List (not for usage questions)</tt><br>
<tt>> Unsubscribe: OpenStack-dev-</tt><br>
<tt>> <a href="mailto:request@lists.openstack.org?subject:unsubscribe">request@lists.openstack.org?subject:unsubscribe</a></tt><br>
<tt>> <a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev">
http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a></tt><br>
<br>
<tt>__________________________________________________________________________</tt><br>
<tt>OpenStack Development Mailing List (not for usage questions)</tt><br>
<tt>Unsubscribe: <a href="mailto:OpenStack-dev-request@lists.openstack.org?subject:unsubscribe">
OpenStack-dev-request@lists.openstack.org?subject:unsubscribe</a></tt><br>
<tt><a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a></tt><br>
<br>
</span><br>
<br>
<o:p></o:p></p>
</div>
</body>
</html>