/[pxelator]/lib/PXElator/config.pm
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 /lib/PXElator/config.pm

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

revision 270 by dpavlin, Wed Aug 19 18:10:37 2009 UTC revision 348 by dpavlin, Sat Aug 29 18:07:49 2009 UTC
# Line 7  use autodie; Line 7  use autodie;
7  use server;  use server;
8  use pxelinux;  use pxelinux;
9  use client;  use client;
10    use file;
11    use ssh;
12    
13  use File::Slurp;  use File::Slurp;
14    
15  sub available { qw/debian_live webconverger debirf tinycore nfsroot/ };  our $mounted;
16    
17    sub available { qw/debian_live webconverger debirf tinycore nfsroot openvz_host openvz_container printer wrt/ };
18    
19  sub debian_live {  sub debian_live {
20          my ($ip) = @_;          my ($ip) = @_;
# Line 46  L<http://webconverger.org/> Line 51  L<http://webconverger.org/>
51  sub webconverger {  sub webconverger {
52          my ($ip) = @_;          my ($ip) = @_;
53    
54          upstream::iso( 'http://download.webconverger.com/webc-5.2.iso' );          $mounted->{"webconverger/$ip"} ||= upstream::iso( 'http://download.webconverger.com/webc-5.2.iso' );
55    
56          my $homepage = client::conf( $ip => 'homepage', default => "http://${server::ip}:7777/client" );          my $homepage = client::conf( $ip => 'homepage', default => "http://${server::ip}:7777/client" );
57          my $hostname = client::conf( $ip => 'hostname' ) || 'webconverger';          my $hostname = client::conf( $ip => 'hostname' ) || 'webconverger';
# Line 98  label linux Line 103  label linux
103          });          });
104  }  }
105    
106    sub in_chroot {
107            my ( $dir, $command ) = @_;
108            write_file "$dir/tmp/inside.sh", $command;
109            system "sudo chroot $dir sh -x /tmp/inside.sh";
110    }
111    
112  sub nfsroot {  sub nfsroot {
113          my $ip = shift;          my $ip = shift || die "no ip?";
114    
115          my $nfsroot = "$server::base_dir/tftp/nfsroot";          my $nfsroot = "$server::base_dir/tftp/nfsroot";
116          my $debian_mirror = server::conf_default( 'debian_mirror', 'http://ftp.debian.org/debian' );          my $debian_mirror = server::conf_default( 'debian_mirror', 'http://ftp.debian.org/debian' );
117    
118          if ( ! -e $nfsroot ) {          if ( ! -e $nfsroot ) {
119                  system "apt-get install nfs-kernel-server debootstrap";                  system "sudo apt-get install nfs-kernel-server debootstrap aufs-modules-`uname -r` aufs-tools";
120                    mkdir $nfsroot;
121            }
122    
123                  if ( ! -e $nfsroot ) {          my $debootstrap = "$nfsroot/debootstrap";
                         mkdir $nfsroot;  
                         system "debootstrap --arch i386 lenny $nfsroot http://ftp.hr.debian.org/debian";  
                 }  
124    
125                  write_file "$nfsroot/tmp/configure.sh", qq{          if ( ! -e $debootstrap ) {
 echo "do_initrd = Yes" > /etc/kernel-img.conf  
126    
127  # apt-get install kernel-image-686                  system "sudo debootstrap --arch i386 lenny $debootstrap $debian_mirror";
 apt-get install atl2-modules-2.6-686  
 echo atl2 >> /etc/initramfs-tools/modules  
128    
129  cat /etc/initramfs-tools/initramfs.conf | sed 's/BOOT=local/BOOT=nfs/' > /tmp/initramfs.conf \                  file::append "$debootstrap/etc/kernel-img.conf", "do_initrd = Yes\n" &&
130          && mv /tmp/initramfs.conf /etc/initramfs-tools/initramfs.conf                  in_chroot     $debootstrap => 'apt-get install -y --force-yes atl2-modules-2.6-686';
131                    in_chroot     $debootstrap => 'apt-get -f install -y --force-yes locales';      # linux-image-2.6-686
132    
133  update-initramfs -u -v                  file::append "$debootstrap/etc/initramfs-tools/modules", "atl2\n";
134                    file::change("$debootstrap/etc/initramfs-tools/initramfs.conf",  'BOOT=local' => 'BOOT=nfs' ) &&
135                    in_chroot     $debootstrap => 'update-initramfs -u';
136    
137            }
138    
139  };          my $export = "$nfsroot/$ip";
140            my $br     = "$nfsroot/br/$ip";
141    
142                  system "chroot $nfsroot sh -x /tmp/configure.sh";          $mounted->{"nfsroot/$ip"} ||= `mount | grep $export`;
143    
144                  open(my $exports, '>>', '/etc/exports');          if ( ! $mounted->{"nfsroot/$ip"} ) {
145                  print $exports "$nfsroot\t$server::ip/$server::netmask(rw,async,no_root_squash,no_subtree_check)\n";                  warn "mounting $export";
                 close($exports);  
146    
147                  system "exportfs -rva";                  mkdir "$nfsroot/br"     unless -e "$nfsroot/br";
148                    mkdir $br                       unless -e $br;
149                    mkdir $export           unless -e $export;
150    
151                    system "sudo mount -t aufs -o br:$br:$debootstrap none $export";
152                    system "sudo exportfs -i -o rw,async,no_root_squash,no_subtree_check,fsid=999 $ip:$export";
153            
154          }          }
155    
156            my $hostname = client::conf( $ip => 'hostname' ) || 'nfsroot';
157            file::replace "$export/etc/hostname", $hostname;
158            file::replace "$export/etc/hosts", "127.0.0.1\tlocalhost $hostname\n";
159            file::replace "$export/etc/resolv.conf", "domain $server::domain_name\nnameserver $server::ip\n";
160            file::replace "$export/etc/rsyslog.d/pxelator.conf", "*.*\t\@$server::ip\n";
161    
162            file::append "$debootstrap/etc/network/interfaces", qq{
163    
164    auto lo
165    iface lo inet loopback
166    
167    allow-hotplug eth0
168    iface eth0 inet dhcp
169    
170            };
171    
172            map {
173                    file::copy_once $_ => "$export/$_";
174                    file::append "$export/etc/rc.local", $_;
175            } ( '/srv/sysadmin-cookbook/recepies/amt/serial-console.sh' );
176    
177          pxelinux::config_for_ip( $ip, qq{          pxelinux::config_for_ip( $ip, qq{
178    
179  default nfsroot  default nfsroot
180  label nfsroot  label nfsroot
181          kernel vmlinuz          kernel debootstrap/vmlinuz
182          append initrd=initrd.img root=/dev/nfs nfsroot=$server::ip:$nfsroot ro ip=dhcp          append initrd=debootstrap/initrd.img root=/dev/nfs nfsroot=$server::ip:$export ro ip=dhcp
183    
184          });          });
185  }  }
186    
187  sub for_ip {  sub openvz_host {
188            my $ip = shift;
189            ssh::shell( $ip, 'cat /proc/vz/veinfo', 'vzlist -a', 'uptime', 'free', 'df' );
190    }
191    sub openvz_container   {
192          my $ip = shift;          my $ip = shift;
193          my $deploy = client::conf( $ip => 'deploy', default => 'webconverger' );          ssh::shell( $ip, 'cat /proc/vz/veinfo', 'uptime', 'free', 'df' );
194          eval $deploy . '($ip)';  }
195    sub printer     {}
196    sub wrt         {}
197    
198    sub for_ip {
199            my $ip = shift || return;
200            my $config = client::conf( $ip => 'config' ) || return;
201            eval $config . '($ip)';
202  #       $tftp::dir = "$server::base_dir/tftp/$pxelinux::path_prefix";  #       $tftp::dir = "$server::base_dir/tftp/$pxelinux::path_prefix";
203  }  }
204    

Legend:
Removed from v.270  
changed lines
  Added in v.348

  ViewVC Help
Powered by ViewVC 1.1.26