<html>
  <head>
    <meta content="text/html; charset=ISO-8859-1"
      http-equiv="Content-Type">
  </head>
  <body bgcolor="#FFFFFF" text="#000000">
    Update:<br>
    <br>
    I've spent some time trying to find out the behavior of vgextend and
    how to extend an existing LVM pool. After a while I've found this
    link, from the "libvirt-users" mailing list:<br>
    <br>
<a class="moz-txt-link-freetext" href="https://www.redhat.com/archives/libvirt-users/2013-September/msg00136.html">https://www.redhat.com/archives/libvirt-users/2013-September/msg00136.html</a><br>
    <br>
    The interesting part is this:<br>
    <br>
    "
    <meta http-equiv="content-type" content="text/html;
      charset=ISO-8859-1">
    <pre style="color: rgb(0, 0, 0); font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px; margin: 0em;">On 21/09/13 02:15, McEvoy, James wrote:
</pre>
    <blockquote style="color: rgb(0, 0, 0); font-family: 'Times New
      Roman'; font-size: medium; font-style: normal; font-variant:
      normal; font-weight: normal; letter-spacing: normal; line-height:
      normal; orphans: auto; text-align: start; text-indent: 0px;
      text-transform: none; white-space: normal; widows: auto;
      word-spacing: 0px; -webkit-text-stroke-width: 0px;
      border-left-color: rgb(85, 85, 238); border-left-style: solid;
      border-left-width: 0.2em; margin: 0em; padding-left: 0.85em;">
      <pre style="margin: 0em;">I looked around but could not find any info on how to expand a libvirt managed LVM storage pool.  I do not see any virsh command to do it
but I was successful using the vgexpand command to add some more storage once I destroyed the pools and then restarted it.
I'd like to verify that this is the proper way to grow the storage in a libvirt LVM storage pool.
</pre>
    </blockquote>
    <tt style="color: rgb(0, 0, 0); font-style: normal; font-variant:
      normal; font-weight: normal; letter-spacing: normal; line-height:
      normal; orphans: auto; text-align: start; text-indent: 0px;
      text-transform: none; white-space: normal; widows: auto;
      word-spacing: 0px; -webkit-text-stroke-width: 0px;"><br>
      It's not the proper way in principle, but since libvirt doesn't
      support<span class="Apple-converted-space">&nbsp;</span></tt><tt
      style="color: rgb(0, 0, 0); font-style: normal; font-variant:
      normal; font-weight: normal; letter-spacing: normal; line-height:
      normal; orphans: auto; text-align: start; text-indent: 0px;
      text-transform: none; white-space: normal; widows: auto;
      word-spacing: 0px; -webkit-text-stroke-width: 0px;">to extend<span
        class="Apple-converted-space">&nbsp;</span></tt><tt style="color:
      rgb(0, 0, 0); font-style: normal; font-variant: normal;
      font-weight: normal; letter-spacing: normal; line-height: normal;
      orphans: auto; text-align: start; text-indent: 0px;
      text-transform: none; white-space: normal; widows: auto;
      word-spacing: 0px; -webkit-text-stroke-width: 0px;">the volume
      groups for a logical pool yet, it's the only way now. One<span
        class="Apple-converted-space">&nbsp;</span></tt><tt style="color:
      rgb(0, 0, 0); font-style: normal; font-variant: normal;
      font-weight: normal; letter-spacing: normal; line-height: normal;
      orphans: auto; text-align: start; text-indent: 0px;
      text-transform: none; white-space: normal; widows: auto;
      word-spacing: 0px; -webkit-text-stroke-width: 0px;">hint though,<span
        class="Apple-converted-space">&nbsp;</span></tt><tt style="color:
      rgb(0, 0, 0); font-style: normal; font-variant: normal;
      font-weight: normal; letter-spacing: normal; line-height: normal;
      orphans: auto; text-align: start; text-indent: 0px;
      text-transform: none; white-space: normal; widows: auto;
      word-spacing: 0px; -webkit-text-stroke-width: 0px;">you can try to
      refresh the pool by command "virsh pool-refresh" after<span
        class="Apple-converted-space">&nbsp;</span></tt><tt style="color:
      rgb(0, 0, 0); font-style: normal; font-variant: normal;
      font-weight: normal; letter-spacing: normal; line-height: normal;
      orphans: auto; text-align: start; text-indent: 0px;
      text-transform: none; white-space: normal; widows: auto;
      word-spacing: 0px; -webkit-text-stroke-width: 0px;">the volume</tt>
    <pre style="color: rgb(0, 0, 0); font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px; margin: 0em;">group of the pool is extended. I.e, don't have to restart the pool."


</pre>
    In short, the recommended way to do it is using vgextend +
    pool-refresh. I've tried it and it works. But (there's always a
    "but") this process does not update the pool XML. And I'm not sure
    if it's supposed to.<br>
    <br>
    I can submit a v1 patch with this implementation, but it would be
    awesome if a more experienced libvirt user/programmer could shed
    some light in this matter. I'm willing to send an email to
    libvirt-users ML if we do not have such expert here.<br>
    <br>
    Thanks!<br>
    <br>
    <div class="moz-cite-prefix">On 02/03/2014 10:00 AM, Aline Manera
      wrote:<br>
    </div>
    <blockquote cite="mid:52EF84DF.9060601@linux.vnet.ibm.com"
      type="cite">On 01/31/2014 05:13 PM, Daniel H Barboza wrote:
      <br>
      <blockquote type="cite">
        <br>
        On 01/31/2014 04:25 PM, Aline Manera wrote:
        <br>
        <blockquote type="cite">
          <br>
          Hi Daniel,
          <br>
          <br>
          Did you try to edit the pool xml and add a new device for it?
          Instead of doing it manually though vgextend command
          <br>
          <br>
          For example:
          <br>
          <br>
          virsh pool-destroy lvm-pool
          <br>
          <br>
          virsh pool-edit lvm-pool
          <br>
          (add a new device for it)
          <br>
          <br>
          virsh pool-start lvm-pool
          <br>
          <br>
          I don't know if it is possible but we give it a try
          <br>
        </blockquote>
        Haven't tried it. Definitely worth a try.
        <br>
        <br>
        Another question: maybe I could add some remove disk from LVM
        feature as well? If we support adding we should support
        removing... right? There is this caveat where removing a disk
        from a LVM can "corrupt" the data of the remaining pool. One
        solution to that would be to destroy/restart the LVM pool if a
        disk removal happens.
        <br>
        <br>
        HHmmmm perhaps the removal of disks would be very similar to
        simply delete the pool and re-create it with fewer disks, so no
        point in trying to implement a new way to do the same thing ....
        thoughts?
        <br>
        <br>
      </blockquote>
      <br>
      Agree. We should not care about removal disks from a logical
      storage pool.
      <br>
      The best way to do it (from user view) is deleting the pool and
      creating a new one with few disks.
      <br>
      <br>
      <blockquote type="cite">
        <blockquote type="cite">
          <br>
          Regards,
          <br>
          Aline Manera
          <br>
          <br>
          On 01/31/2014 11:42 AM, Daniel H Barboza wrote:
          <br>
          <blockquote type="cite">Hello!
            <br>
            <br>
            I am almost delivering a first version of this feature but
            now I am having doubts in how it might work or not.
            <br>
            <br>
            My implementation would use vgextend and add a disk to an
            existing LVM pool. The question is that, in this process,
            all existing data in the added partition will be deleted. Is
            this ok? We can warn the user about it, of course. But I am
            not sure if this is the intended design.
            <br>
            <br>
            I've spoken with Aline a while ago and she agreed that the
            implementation would function similar to what we have today
            when creating a new LVM pool. We simply "do not care" about
            the potential data loss when adding the disk to an existing
            pool.
            <br>
            <br>
            Any thoughts?
            <br>
            <br>
            <br>
            thanks!
            <br>
            <br>
            _______________________________________________
            <br>
            Kimchi-devel mailing list
            <br>
            <a class="moz-txt-link-abbreviated" href="mailto:Kimchi-devel@ovirt.org">Kimchi-devel@ovirt.org</a>
            <br>
            <a class="moz-txt-link-freetext" href="http://lists.ovirt.org/mailman/listinfo/kimchi-devel">http://lists.ovirt.org/mailman/listinfo/kimchi-devel</a>
            <br>
            <br>
          </blockquote>
          <br>
        </blockquote>
        <br>
      </blockquote>
      <br>
    </blockquote>
    <br>
  </body>
</html>