<html>
  <head>
    <meta content="text/html; charset=ISO-8859-1"
      http-equiv="Content-Type">
  </head>
  <body bgcolor="#FFFFFF" text="#000000">
    <div class="moz-cite-prefix">On 7/2/2014 11:06 PM, Sheldon wrote:<br>
    </div>
    <blockquote cite="mid:53B41FF4.6030701@linux.vnet.ibm.com"
      type="cite">
      <meta content="text/html; charset=ISO-8859-1"
        http-equiv="Content-Type">
      <div class="moz-cite-prefix">On 06/27/2014 07:15 PM, Wen Wang
        wrote:<br>
      </div>
      <blockquote cite="mid:53AD524B.6020909@linux.vnet.ibm.com"
        type="cite">
        <meta http-equiv="content-type" content="text/html;
          charset=ISO-8859-1">
        Dear all,<br>
        <b><br>
        </b><b>Problems:</b><br>
        Now our strategy&nbsp; for long time operation is using task which
        the browser needs to check up-to-date task status time by time
        until the task ends. It's time consuming and less efficient.
        Also there exists several problems when locating each task when
        doing debug generating and storage pool as well as some new
        features that might use task strategy in the future. <br>
        <br>
        <b>Solution</b>:<br>
        As talked with Sheldon and Zhengsheng, we came up with a
        solution that avoid browser checking status every 200ms. Also,
        we might need some more labels in each task to provide more
        information when getting the task like we might need to indicate
        which operation triggered certain task. What's in our mind is to
        use the strategy that allow the server inform browser about the
        task information. Our proposal is designed as follows.<br>
        <br>
        1) Browser needs to register to the back end to indicate which
        part the result needs to reply to when the task finished.<br>
        2) The back end use broker to manage message distribution: when
        a task is finished or experiencing an error, back end inform the
        browser certain part of work is finished or error.<br>
        3) Using websocket of cherrypy to accomplish the message
        transfer.<br>
      </blockquote>
      Now let me elaborate above.<br>
      <br>
      For Browser, it can be an event loop worker.<br>
      It can subscribe event message that users care to the back end&nbsp;
      broker.<br>
      listen the events from the broker and take some action for the
      event.<br>
      <br>
      For back:<br>
      The broker should collect and store the events from everywhere. <br>
      The broker should dispatch the message to the client who
      subscribes it. <br>
      For some event, broker should determined whether it should
      dispatch to user.&nbsp; <br>
      Such a VM shutdown event, the broker just send it to the user who
      has the access permission. &#65288;Yu Xing's suggestion&#65289;<br>
      We had better define the event message format.<br>
      <br>
      We had better to find an existing python lib for it. If no we
      should code it for ourself. <br>
      &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; [
      client1
      ]&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
      <br>
      &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; care VM&nbsp; &nbsp;&nbsp; |&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; ^<br>
      libvirt event -------------\&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; shutdown&nbsp; |&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; |&nbsp; VM
      shutdown<br>
      &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; \&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; V
      &nbsp;&nbsp;&nbsp;&nbsp;&nbsp; | &nbsp;&nbsp; &nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <br>
      event 1 -------- --------------------------&gt;[ &nbsp; broker ]&nbsp; <br>
      &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; /&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; ^
      &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; |&nbsp; dispatch<br>
      event 2 &nbsp; &nbsp; &nbsp; ------------/ &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&nbsp; &nbsp; | &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; |
      &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <br>
      &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; subscribe&nbsp;&nbsp; |&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; V&nbsp;
      listen<br>
      &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; [
      client2 ]<br>
      <br>
      <br>
      For websocket:<br>
      There's also an issue about it.&nbsp; <a moz-do-not-send="true"
        class="moz-txt-link-freetext"
        href="https://github.com/kimchi-project/kimchi/issues/22">https://github.com/kimchi-project/kimchi/issues/22</a>
      <br>
      The websocket is the pipe to connect the broker of the UI event
      worker. <br>
      We should support websocket proxying directly from the cherrypy
      server on its given port. <br>
      Zheng Sheng is working on it.&nbsp; It can work on cherrypy. Seems
      something wrong with nginx. <br>
      <br>
    </blockquote>
    Thanks Sheldon, as we discussed yesterday on scrum meeting, it's
    better to use the socket method solve long time task problem. We
    wanted to make this feature a generic one so that every long-time
    task will benefit from it. I think Kimchi should use the user
    information alongside with task type to decide which user(s) we
    should send the message to. It all happen when automatically. I
    don't think we need the message management for users.<br>
    <br>
    Also, do we need to change all the tasks to this socket pattern or
    just for long-time tasks? I recommend long-time tasks. <br>
    <br>
    For the message format, I think we might need the user name, role
    and the url to indicate which kind of task we are running. <br>
    <br>
    As you said , the broker filter the message from the backend and I
    might need to know your design for the message frontend gets. We
    need to have it discussed further more.<br>
    <blockquote cite="mid:53B41FF4.6030701@linux.vnet.ibm.com"
      type="cite"> <br>
      <br>
      <blockquote cite="mid:53AD524B.6020909@linux.vnet.ibm.com"
        type="cite"> <br>
        Best Regards<br>
        <br>
        Wang Wen<br>
        <br>
        <br>
        <br>
        <fieldset class="mimeAttachmentHeader"></fieldset>
        <br>
        <pre wrap="">_______________________________________________
Kimchi-devel mailing list
<a moz-do-not-send="true" class="moz-txt-link-abbreviated" href="mailto:Kimchi-devel@ovirt.org">Kimchi-devel@ovirt.org</a>
<a moz-do-not-send="true" class="moz-txt-link-freetext" href="http://lists.ovirt.org/mailman/listinfo/kimchi-devel">http://lists.ovirt.org/mailman/listinfo/kimchi-devel</a>
</pre>
      </blockquote>
      <br>
      <br>
      <pre class="moz-signature" cols="72">-- 
Thanks and best regards!

Sheldon Feng(&#20911;&#23569;&#21512;)<a moz-do-not-send="true" class="moz-txt-link-rfc2396E" href="mailto:shaohef@linux.vnet.ibm.com">&lt;shaohef@linux.vnet.ibm.com&gt;</a>
IBM Linux Technology Center</pre>
    </blockquote>
    <br>
  </body>
</html>