/[vz-tools]/trunk/vz-clone.pl
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /trunk/vz-clone.pl

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 27 by dpavlin, Thu Oct 4 23:42:24 2007 UTC revision 30 by dpavlin, Fri Oct 5 01:09:12 2007 UTC
# Line 12  my ( $action, $VEID ) = @ARGV; Line 12  my ( $action, $VEID ) = @ARGV;
12    
13  my $use_snapshot = 0;  my $use_snapshot = 0;
14    
15  my $valid_actions = 'create|umount|destroy';  my $valid_actions = 'create|mount|umount|destroy';
16    
17  die "Usage: $0 ($valid_actions) VEID\n\n",vzlist unless $VEID && $action && $action =~ m/($valid_actions)/;  die "Usage: $0 ($valid_actions) VEID\n\n",vzlist unless $VEID && $action && $action =~ m/($valid_actions)/;
18    
# Line 27  sub vzctl_stop { Line 27  sub vzctl_stop {
27          }          }
28  }  }
29    
   
30  if ( $action eq 'create' ) {  if ( $action eq 'create' ) {
31          vzctl_stop( $CVEID );          vzctl_stop( $CVEID );
32  } elsif ( $action eq 'destroy' ) {  } elsif ( $action eq 'destroy' ) {
# Line 35  if ( $action eq 'create' ) { Line 34  if ( $action eq 'create' ) {
34  }  }
35    
36    
37  if ( 1 || $action =~ m/(umount|destroy)/ ) {  if ( $action =~ m/(create|umount|destroy)/ ) {
38          my $clone;          my $clone;
39          open(my $m, '-|', 'mount') || die "can't open mount: $!";          open(my $m, '-|', 'mount') || die "can't open mount: $!";
40          while(<$m>) {          while(<$m>) {
41                  my @v = split(/\s+/,$_);                  my @v = split(/\s+/,$_);
42                  if ( $v[2] =~ m!/(private|root)/$VEID$! && $v[5] =~ m/bind/ ) {                  if ( $v[2] =~ m!/(private|root)/$CVEID$! && $v[5] =~ m/bind/ ) {
43                          umount( $v[2] );                          umount( $v[2] );
44                  } elsif ( $v[2] =~ m!vz-clone-$VEID$! ) {                  } elsif ( $v[2] =~ m!vz-clone-$CVEID$! ) {
45                          $clone = $v[2];                          $clone = $v[2];
46                  }                  }
47          }          }
48          umount( $clone ) if $clone;          umount( $clone ) if $clone;
49    
50            exit if $action eq 'umount';
51  }  }
52    
 #die "unknown action: $action" unless $action eq 'create';  
 exit unless $action eq 'create';  
53    
54  my $orig_conf = "/etc/vz/conf/$VEID.conf";  my $orig_conf = "/etc/vz/conf/$VEID.conf";
55    
# Line 84  sub fs_quota { Line 83  sub fs_quota {
83    
84  sub copy_files {  sub copy_files {
85          my ( $from, $to ) = @_;          my ( $from, $to ) = @_;
86            return if $action ne 'create';
87          warn "rsync $from -> $to\n";          warn "rsync $from -> $to\n";
88          rsync('-raSHAD', "$from/", "$to/" );          rsync('-raSHAD', "$from/", "$to/" );
89  }  }
# Line 125  if ( $vz_lv ) { Line 125  if ( $vz_lv ) {
125                    
126          }          }
127    
         my $clone_size = fs_quota( $VEID ) . 'k';  
128          my $vg_name = $1 if ( $vz_lv_path =~ m!/([^/]+)/*$! );          my $vg_name = $1 if ( $vz_lv_path =~ m!/([^/]+)/*$! );
129    
130          if ( lvdisplay( "$vz_lv_path/$clone" ) ) {          if ( lvdisplay( "$vz_lv_path/$clone" ) ) {
131                  warn "using existing $vz_lv_path/$clone\n";                  warn "using existing $vz_lv_path/$clone\n";
132          } else {          } else {
133                    my $clone_size = fs_quota( $VEID ) . 'k';
134                  print "Creating LV $clone ($clone_size bytes) in VG $vg_name for $VEID clone filesystem\n";                  print "Creating LV $clone ($clone_size bytes) in VG $vg_name for $VEID clone filesystem\n";
135                  lvcreate( '--size', $clone_size, '--name', $clone, $vg_name );                  lvcreate( '--size', $clone_size, '--name', $clone, $vg_name );
136                  mke2fs( '-m', 0, '-j', "$vz_lv_path/$clone" );                  mke2fs( '-m', 0, '-j', "$vz_lv_path/$clone" );
# Line 146  if ( $vz_lv ) { Line 146  if ( $vz_lv ) {
146    
147          if ( $use_snapshot ) {          if ( $use_snapshot ) {
148    
149                  copy_files( "/tmp/$snap/private/$VEID", "$vz/private/$CVEID" );                  copy_files( "/tmp/$snap/private/$VEID", "/tmp/$clone/private" );
150    
151                  print "Cleanup\n";                  print "Cleanup\n";
152    
# Line 156  if ( $vz_lv ) { Line 156  if ( $vz_lv ) {
156                  lvremove( '-f', "$vz_lv_path/$snap" );                  lvremove( '-f', "$vz_lv_path/$snap" );
157    
158          } else {          } else {
159                  copy_files( "$vz/private/$VEID", "$vz/private/$CVEID" );                  copy_files( "$vz/private/$VEID", "/tmp/$clone/private" );
160    
161          }          }
162    
# Line 165  if ( $vz_lv ) { Line 165  if ( $vz_lv ) {
165          copy_files( "$vz/private/$VEID", "$vz/private/$CVEID" );          copy_files( "$vz/private/$VEID", "$vz/private/$CVEID" );
166  }  }
167    
168    exit if $action eq 'mount';
169    
170  my $note = "# modified by $0\n";  my $note = "# modified by $0\n";
171    
172  sub fix_ip {  sub fix_ip {

Legend:
Removed from v.27  
changed lines
  Added in v.30

  ViewVC Help
Powered by ViewVC 1.1.26