Hello

<subject>: Fixed in 4.2?!

config used for testing:

disk_config disk1

#<type> <mountpoint> <size> <filesystem> <mount_options> <fs_options>
primary -            4G-    -            -

disk_config lvm
vg vg_system disk1.1
vg_system-root     -          1G      - -


first run - no LVM volumes configured
(just to set up the volumes - works without patching)

Starting setup-storage 1.4
Using config file: /var/lib/fai/config/disk_config/DISK_TYPE3_2
Executing: parted -s /dev/sda unit TiB print
Executing: parted -s /dev/sda unit B print free
Executing: parted -s /dev/sda unit chs print free
    Finding all volume groups
  No volume groups found
Executing: mdadm --examine --scan --verbose -c partitions
Executing: parted -s /dev/sda mklabel msdos
Executing: parted -s /dev/sda mkpart primary "" 1048576B 10737418239B
Executing: parted -s /dev/sda set 1 lvm on
Executing: pvcreate -ff -y  /dev/sda1
Executing: vgcreate  vg_system  /dev/sda1
Executing: vgchange -a y vg_system
Executing: lvcreate  -n root -L 1024 vg_system

second run - right after the first one
(this always failed)

Starting setup-storage 1.4
Using config file: /var/lib/fai/config/disk_config/DISK_TYPE3_2
Executing: parted -s /dev/sda unit TiB print
Executing: parted -s /dev/sda unit B print free
Executing: parted -s /dev/sda unit chs print free
    Finding all volume groups
    Finding volume group "vg_system"
    Finding all volume groups
    Finding volume group "vg_system"
    Finding all volume groups
    Finding volume group "vg_system"
    Finding all volume groups
    Finding volume group "vg_system"
Executing: mdadm --examine --scan --verbose -c partitions
Executing: vgchange -a n vg_system
Executing: lvremove -f vg_system/root
Executing: vgremove vg_system
Executing: pvremove  /dev/sda1
Executing: wipefs -a /dev/sda1
Executing: wipefs -a /dev/sda1
Executing: parted -s /dev/sda mklabel msdos
Executing: parted -s /dev/sda mkpart primary "" 1048576B 10737418239B
Executing: parted -s /dev/sda set 1 lvm on
Executing: pvcreate -ff -y  /dev/sda1
Executing: vgcreate  vg_system  /dev/sda1
Executing: vgchange -a y vg_system
Executing: lvcreate  -n root -L 1024 vg_system

Hurray! setup-storage successfully deletes existing logical volumes and volume 
groups! 

There were 2 bugs which prevented this.

a) command stack was built wrongly

'cmd' => 'lvremove -f vg_system/root',
'post' => 'lv_rm_vg_system/root,self_cleared_/dev/vg_system/root',
'pre' => 'wipefs_vg_system/root'

'cmd' => 'true',
'post' => 'self_cleared_VG_vg_system',
'pre' => 'vgchange_a_n_VG_vg_system,[...],self_cleared_root'

'self_cleared_root' is wrong, it should be 'self_cleared_/dev/vg_system/root' 
I think this one is related to the change in LVM 2.02.89.

b) disable volume group, then trying to wipe a logical volume

I don't know where this is coming from, but it's impossible that this could 
have ever worked. As soon as you disable a volume group all related volumes 
are not available any longer. Either wipe-then-disable or just-disable. I 
decided for the latter. 

Patch is attached, it was built against the 4.2 package. I haven't checked 
what happens if you try anything funny. May need some additional adjustments 
(e.g. for preserving volumes).

bye
thomas
diff -Nur vanilla/usr/share/fai/setup-storage/Commands.pm patched/usr/share/fai/setup-storage/Commands.pm
--- vanilla/usr/share/fai/setup-storage/Commands.pm	2013-09-23 00:00:00.000000000 +0200
+++ patched/usr/share/fai/setup-storage/Commands.pm	2014-06-18 16:33:35.066381624 +0200
@@ -664,11 +664,8 @@
           }
         }
 
-        &FAI::push_command( "wipefs -a $vg/$lv",
-          "vgchange_a_n_VG_$vg$pre_deps_cl",
-          "wipefs_$vg/$lv");
-        &FAI::push_command( "lvremove -f $vg/$lv",
-          "wipefs_$vg/$lv",
+        &FAI::push_command( "lvremove -f /dev/$vg/$lv",
+          "vgchange_a_n_VG_$vg",
           "lv_rm_$vg/$lv,self_cleared_/dev/$vg/$lv");
         $vg_setup_pre .= ",lv_rm_$vg/$lv";
       }
@@ -689,11 +686,8 @@
       join(",self_cleared_", @{ $FAI::current_dev_children{"/dev/$vg/$lv"} })
         if (defined($FAI::current_dev_children{"/dev/$vg/$lv"}) &&
           scalar(@{ $FAI::current_dev_children{"/dev/$vg/$lv"} }));
-    &FAI::push_command( "wipefs -a $vg/$lv",
-      "vgchange_a_n_VG_$vg$pre_deps_cl",
-      "wipefs_$vg/$lv");
     &FAI::push_command( "lvremove -f $vg/$lv",
-      "wipefs_$vg/$lv",
+      "vgchange_a_n_VG_$vg",
       "lv_rm_$vg/$lv,self_cleared_/dev/$vg/$lv");
     $vg_destroy_pre .= ",lv_rm_$vg/$lv";
   }
diff -Nur vanilla/usr/share/fai/setup-storage/Volumes.pm patched/usr/share/fai/setup-storage/Volumes.pm
--- vanilla/usr/share/fai/setup-storage/Volumes.pm	2013-09-23 00:00:00.000000000 +0200
+++ patched/usr/share/fai/setup-storage/Volumes.pm	2014-06-18 16:27:48.000000000 +0200
@@ -422,7 +422,8 @@
         &FAI::convert_unit($lv_info{$lv_name}->{lv_size} .
           $lv_info{$lv_name}->{lv_size_unit});
       # add entry in device tree
-      push @{ $FAI::current_dev_children{"VG_$vg"} }, $lv_name;
+      my $device = _make_lv_devicename($vg, $lv_name);
+      push @{ $FAI::current_dev_children{"VG_$vg"} }, $device;
     }
 
     # store the physical volumes
@@ -647,6 +648,22 @@
   }
 }
 
+sub _make_lv_devicename {
+  my $vg = shift;
+  my $lv = shift;
+
+  # LVM 2.02.88 or below: LV Name = /dev/<vg>/<lv>
+  if ($lv =~ m{\A \Q/dev/$vg/$lv\E \z}xms) {
+    return $lv;
+  }
+  # LVM 2.02.89 or higher: LV Name = <lv>, LV Path = /dev/<vg>/<lv>
+  elsif ($lv =~ m{\A \Q$lv\E \z}xms) {
+    return "/dev/$vg/$lv";
+  }
+  else {
+    croak("Unable to generate a device name for '$lv'");
+  }
+}
 
 1;
 

Antwort per Email an