ghost for unix

1. What is it?

  • g4u ("ghost for unix") is a NetBSD-based bootfloppy/CD-ROM that allows easy cloning of PC harddisks to deploy a common setup on a number of PCs using FTP. The floppy/CD offers two functions. The first is to upload the compressed image of a local harddisk to a FTP server, the other is to restore that image via FTP, uncompress it and write it back to disk. Network configuration is fetched via DHCP. As the harddisk is processed as an image, any filesystem and operating system can be deployed using g4u. Easy cloning of local disks as well as partitions is also supported.

    For the curious, I've added a few screenshots:

    1. Booting g4u in bochs
    2. Device detection
    3. Welcome to g4u!
    4. Some random g4u commands
    5. Uploading a disk image with uploaddisk
    6. Restoring with slurpdisk

2. Why not one of the alternatives?

    • Server-part often runs (only) under DOS/Windows. I wanted to use a Unix based server.
    • Supported filesystems include everything from Microsoft, but others are not handled properly (Solaris/x86, NetBSD, ...)
    • I don't want to deal (ever again) with making a DOS-based bootfloppy, that gets its IP-number via DHCP.
    • I've played with doing multicast-based deployment based on imm, but the result was so slow I decided not to persue it.

3. Requirements & Download

4. Using it

  • 4.1 Preparations

    • Using the g4u floppy images:
      1. Download the two floppy images, g4u-2.1-1.fs and g4u-2.1-2.fs or g4u-2.1.fs.zip, which contains these two files.
      2. If you downloaded the g4u-2.1.fs.zip file, unpack it to get g4u-2.1-1.fs and g4u-2.1-2.fs
      3. Write the two images to two seperate floppy disk. Under Unix, a simple "cat g4u-2.1-1.fs >/dev/diskette" (and same for -2.fs) will do. Make yourself familiar with the name of your floppy device, some common ones are:

         

        • NetBSD: /dev/fd0a
        • Solaris: /dev/diskette
        • Linux: /dev/fd0

        There are also similar devices for USB sticks, but you need to grab the g4u.fs from the ISO to put there:

         

        • NetBSD: /dev/sd0d
        • Linux: /dev/sd0

        If you're using DOS, use rawrite.exe. There's also a Windows-based program available called rawr32.zip.

    • Using the g4u CDROM ISO image:
      1. Download the CDROM ISO image, g4u-2.1.iso or g4u-2.1.iso.zip
      2. If you downloaded the g4u-2.1.iso.zip file, unpack it to get g4u-2.1.iso
      3. Please consult your CDROM writing software (Nero, DiskJuggler, WinOnCD, cdrecord, ...) 's manual on how to write the g4u.iso file to a CDROM. Note that the image is bootable.

       

    • On a FTP server of your choice, create an user-account called "install", and protect it with some password. Make sure the 'install' user can login via ftp (/etc/shells...)

      If you want to use a different account, you can specify "login@server" for slurpdisk, uploaddisk etc..

    • Make sure you have a working DHCP server that hands out IP addresses and other data needed to access the FTP server from your workstation (name server, netmask, default gateway). Else you will have to set the IP-number manually..

    4.2 Image creation

    • Boot the CD or floppy on the machine you want to clone. See it read the kernel from disk, then print out all the devices found in the machine. It will do DHCP next, asking for an IP number - be sure you have DHCP configured properly! At the end you'll get a text description of possible commands, and a shell prompt.

       

    • Whole harddisk:
      Type "uploaddisk your.ftp.server.com filename.gz" to read out the machine's harddisk (rwd0d), and put it into the "install" account of your FTP server under the given filename. The disk image is compressed (with gzip -9), so maybe use a ".gz" file suffix. You don't have to, though. Before putting the file on the FTP server, the "install" account's password is requested.

      If you want to clone your second IDE disk, add it's name on the uploaddisk command line: "uploaddisk your.ftp.server.com filename.gz wd1". Similarly, if you use SCSI instead of IDE disks, use "uploaddisk your.ftp.server.com filename.gz sd0".

      If you want to use a different account name than "install", use "account@your.ftp.server.com" for both uploaddisk and slurpdisk.

       

    • One partition only:
      Get an overview of disks recognized by g4u by typing "disks", a list of partitions on a certain disk is available via "parts disk", where disk is one of the disks printed by "parts", e.g. wd0, wd1, sd0, etc. Partitions are numbered with letters starting from 'a', where partitions a-d are usually predefined, with your partitions starting at 'e'. Partitions here are BSD-partitions, which have little in common with DOS MBR partitions. To specify a partition, use something like "wd0e" or "sd0f": "uploadpart your.ftp.server.com filename.gz wd0e". Run "uploadpart" without arguments for more examples.

       

    • Wait until you're back at the shell prompt (ignore the errors :-). Depending on your network, CPU, harddisk hardware and contents, image creation can take several hours!
    • You can switch off the machine now. Type "halt" or simply press reset/power button - there are no filesystems mounted so no harm will result.
    • Check that your FTP server's "install" account now has the image file.

    4.3 Image deployment

    • Boot the CD or floppy to the shell prompt again, see above.

       

    • Whole harddisk:
      Type "slurpdisk your.ftp.server.com filename.gz". This will log into the FTP server's "install" account, verify the password, then retrieve the image, uncompress it and write it back to /dev/rwd0d.

      If you want to restore to a SCSI disk, add the disk's name to the slurpdisk command line, e.g. "slurpdisk your.ftp.server.com filename.gz sd0".

      See above if you want to use an account name other than "install".

    • One partition:
      Use "slurppart your.ftp.server.com filename.gz wd0e" or whatever values you passed to uploadpart. Please note that the partition information is taken from your MBR, which is expected to be the same as before image creation - expect surprises if you change something between image creation and deployment. In case of inevitable changes, check the start sector and size values given by "parts". For an image that includes the MBR, do a full backup with "uploaddisk".

       

    • Reboot the machine (type "reboot" or press reset button), and see if your machine comes up as expected - it should!

    4.4 Copying a disk locally

    • If you just want to copy one local disk to another one with no network & server involved, the "copydisk" command is what you want. E.g. to copy the first IDE disk to the second IDE disk, use " copydisk wd0 wd1", to do the same for SCSI disks run " copydisk sd0 sd1".

       

      Beware! All data on the target disk will be erased!

      A list of disks as found during system startup can be found using the "disks" command.

       

    4.5 Copying a partition locally

    • If you want to only copy one local partition to another local partition (similar to what 'uploadpart' and 'slurppart' do, just without the network and FTP in between), this can be done with the 'copypart' command. It takes two partition names as arguments, and copies the contents of one partition to the other. As an example if you found you want to copy your first local partition 'wd0e' to the second one 'wd0f', run:
      copypart wd0e wd0f
      
      A list of disks can be found using the ' disk' command, to list all the partitions on a disk use the ' parts' command. Partitions have the form of "wd0d", "w1e", "sd1f".

      Be aware that the partitions to copy should have identical size (down to the sector), else funny things will happen. When copying a 'big' partition into a 'small' one, g4u won't thrash the data behind the 'small' partition, but of course the copy is not complete either. Take special note that that case could happen when you restore a copy made that way, and which went fine when you first copied your small working partition to your big backup partition!

5. FAQs and hints on disk cloning

  • 5.1 Supported filesystems

    • One of the questions arising a lot is "what filesystems does g4u support". The answer is: "all of them". g4u reads the disk bit by bit, starting from byte #0 to the end. It includes any MBR, boot record, partition table and the partitions themselves without further investigating the structure of the data stored in these partitions.

    5.2 Supported Operating Systems

    • The question on operating systems that can be deployed with g4u is the same as for the filesystems: any. Given the image-approach again, g4u is able to handle any operating system. Systems that were cloned successfully include NetBSD, Linux, Novell Netware 4.11 and 5.1, Solaris/x86, Windows NT, 2000 and XP.

      By moving the harddisks to a PC, g4u can even be used to deploy operating systems for non-PC based SCSI machines running HP-UX, Irix, Solaris, AIX etc.

    5.3 Supported Hardware

    • The system running g4u itself can have IDE, SATA, SCSI or RAID disks with various controllers (Adaptec, ...) as well as wide range of PCMCIA, Cardbus, ISA and PCI network cards. Please see the g4u kernel config for the full list of supported hardware.

      If you're unsure if your hardware is supported, simply boot g4u and see if your network card gets listed by "ifconfig -a" and if your disks get listed by the "disks" command. If not, adding relevant parts of "dmesg" output (from g4u; press space bar to scroll down) is required for analysis if you ask for help. See "Reporting problems" for more information.

       

    5.4 A word on disk sizes

    • The question how g4u deals with different disk sizes arises a lot too. The general answer is, g4u works best with identical disk sizes & geometry. Putting an image from a small disk on a big disk works, putting an image from a big disk to a small disk is likely to cause problems.

      If you cannot avoid preparing an image on a big disk that'll get deployed to a small disk later, make sure the "extra" space is not occupied by a active partition or filesystem, else data loss is very likely to occur!

      If you intend to deploy a "small" image to a "big" disk, the extra space that's not covered by g4u can be used for creating a partition and a filesystem. You will have to do that on your own, e.g. using your operating systems' post installation steps.

    5.5 Changing compression level

    • Per default, images uploaded to the FTP server are compressed with "gzip -9". This saves as much disk space as possible, but also takes a long time - several hours are not uncommon. You can reduce the gzip level for "uploaddisk" by setting the GZIP environment variable:

       

      # GZIP=-1 uploaddisk your.ftp.server.com filename.gz
      
      You can change compression levels between 1 (fast, little compression) and 9 (slow, maximum compression). Of course you can specify all the usual options to uploaddisk.

       

    5.6 List of recognized disks

    • During startup of g4u, all devices recognized are listed, but very fast. To get a list of recognized disks, use the 'disks' command:

       

      # disks
      wd0 at pciide0 channel 0 drive 0: 
         
         
      wd0: drive supports 16-sector pio transfers, lba addressing
      wd0: 6149 MB, 13328 cyl, 15 head, 63 sec, 512 bytes/sect x 12594960 sectors
      wd0: 32-bit data port
      wd0: drive supports PIO mode 4, DMA mode 2, Ultra-DMA mode 2
      wd0(pciide0:0:0): using PIO mode 4, Ultra-DMA mode 2 (using DMA data transfers)
      The above example shows a 6GB IDE harddisk.

       

    5.7 Problems with images at 2GB

    • Do you experience g4u aborting file transfers after the image has grown to 2 GB on the FTP server? The problem here is not g4u, but most likely your FTP server. Some older Linux distributions are known to only allow files of up to 2GB filesize, and even if there is a Linux 2.4 kernel running, that's no guarantee for a properly working server. Make sure that your ftp daemon is upto date, or install a decent operating system.

      So far, whatever FTP server comes with NetBSD, Solaris and Windows 2000 has been used without problems.

       

    5.8 Can you add feature XXX?

    • I got requests for adding many features to g4u:

       

      • using TFTP
      • using SSH/scp
      • using NFS
      • adding a X or curses based GUI
      • writing images to CDROM / deployment from CDROM
      • bzip2 compression

      After moving to a two-floppy set for g4u, some of these features may be added in the future, while others (X...) are not likely. Stay tuned!

       

    5.9 Problems with network performance

    • If upload performance is weak (less than 5MBytes/sec on a 100BaseT Ethernet switch) even with a small compression level or a fast CPU and the harddisk is idle this means the network sucks. A common problem in switched Ethernet is a duplex mismatch between the NIC and the switch. In NetBSD, the default is to negotiate speed and duplex automatically. Other settings can be set manually.

      Enforcing 100BaseTX/Full-duplex:

       

      # ifconfig fxp0 media 100BaseTX mediaopt Full-duplex
      # ifconfig -a
          fxp0: flags=[...] 
              media: Ethernet 100baseTX full-duplex 
      Using autonegotiation (default):

       

      # ifconfig fxp0 media auto
      # ifconfig -a
          fxp0: flags=[...] 
              media: Ethernet autoselect (100baseTX)

      For more information, please see the ifconfig(8) manpage as well as the Auto-Negotiation Valid Configuration Table featuring "Why Can't the Speed and Duplex Be Hardcoded On Only One Link Partner?".

       

    5.10 Reducing the image size

    • People complain that the image resulting from g4u is very big. This is normal as g4u clones the whole disks with all blocks, not attributing if they contain any valid data or if they are empty/unused. To find empty/unused blocks (and not clone them), g4u would need intimate understanding of the contained filesystem, which is different again for each filesystem - Windows FAT, Linux Ext2/3/ReiserFS/..., BSD FFS, Solaris UFS, etc. Given both tight space limitations on the floppy as well as shortage on filesystem documentation and implementations available, teaching g4u to ignore empty blocks is not likely to happen.

      But there is an easy way to circumvent the problem: use the native operating system's understanding (and implementation) of the filesystem, and make sure it prepares empty/unused blocks in a way so they don't contain random garbage data but values which can be compressed easily by g4u, thus resulting in small image sizes.

      Effectively, you just fill up the disk's unused blocks with zero-bytes. Open file for writing, stuff in 0-bytes until the disk is full, then close the file and remove it. The result is that all unused blocks were used by the file, and filled with data that g4u can then compress easily. Usually the operating system will just mark the blocks as unused, without changing the actual data content.

      Using this technique on a 20GB disk that had 6GB Solaris 8/x86 and the rest Windows 2000 Workstation shrunk the image from ~6GB compressed to ~2GB compressed. You can probably imagine the effect of this on deployment time too. :)

      To perform the filling of unused data blocks with zero-bytes, there are several ways, depending on what operating system you use on your computer, and what software you have available:

       

      Standard Unix:
      This works on any Unix variant - Linux, NetBSD, Solaris, etc.:
      dd if=/dev/zero of=/0bits bs=20971520   # bs=20m
      rm /0bits

       

      Windows Perl solution:
      This one needs perl installed. In a command shell, type:
      cd /d c:/
      c:/win-preclone.pl c:
      Click here to download the win-preclone.pl perl script.

       

      Windows Pascal solution:
      This pascal program was contributed by Matthias Jordan [mjordan at code-fu dot de]: The programs are provided here without warranty.

       

      64bit Windows binary:
      Dominic Leelodharry [dominic at authorsoftware d0t com] also sent me a binary for 64bit Windows: This program is provided here without warranty.

       

      Windows "Erasor":
      This freeware program can erase your disk in a safe way, but it can also be told to just write a pattern of all-0-bits to the disk. Grab it at www.heidi.ie/eraser. Thanks to Stephen Krans [s040 at krans dot org] for the hint!

       

      Windows "onboard" solution:
      Aparently Windows XP comes with a tool to do some harddisk encryption that can also be used to write 0-bytes to the disk. To do so, run the following command: cipher /W:C: for drive C:. You will need to abort (Control+C) after the first round, else it will write random data after filling the disk nicely with 0-bytes.
      Run any of these right before shutting down the operating system to create an image with g4u, and see the size difference.

       

    5.11 Setting IP-number manually

    • Sometimes you may not want or be able to use DHCP. In that case doing the network configuration manually is possible with g4u, too:

       

      1. Find out if your network device is recognized, and by what name, using the command

         

             ifconfig -a
        Your network device is something like "ex0", "tlp0", etc. (Note that unlike in Linux, NetBSD doesn't call all ethernet cards "eth0"!)

         

      2. Next configure the network device's IP number and netmask. It is assumed that your network device is xx0 here, and that the machine should run with IP number 1.2.3.4 and netmask 255.255.255.0:

         

             ifconfig xx0 1.2.3.4 netmask 255.255.255.0
      3. Last, you may want to make the default router known unless your FTP server is in the same IP subnet as the machine you want to use g4u on. Let's say the default router's IP address is 2.3.4.5, then the command to enter is:

         

             route add default 2.3.4.5 
      That's all - simple, huh? Just remember that g4u is still Unix! After these steps, you should be able to use g4u just as if it used DHCP.

    5.12 Extracting the g4u kernel

    • I've been asked how to boot g4u from harddisk (using e.g. grub). The idea is to extract the kernel from the boot floppy, and hand that to grub (or whatever bootloader you want - maybe use PXE to netboot g4u). Here's how to extract the kernel, named "netbsd":

       

      % ( cat g4u-2.1-1.fs | dd bs=512 skip=16 ; /
      ?   cat g4u-2.1-2.fs | dd bs=512 skip=16 /
      ? ) | tar vxf -
      -r--r--r--  1 feyrer   netbsd        53948 Nov  3 23:08 boot
      -rw-rw-r--  1 feyrer   netbsd      1479905 Nov  3 23:08 netbsd
      
      Note that the kernel ("netbsd") is actually still compressed, which is fine for the NetBSD bootloader and probably GRUB, but just in case, you may want to uncompress it:
      % file netbsd
      netbsd: gzip compressed data, was "netbsd-INSTALL_G4U", from Unix
      % mv netbsd netbsd.gz
      % gunzip netbsd.gz 
      % ls -la netbsd
      -rw-rw-r--  1 feyrer  wheel  5523084 Dec  7 18:08 netbsd
      % file netbsd
      netbsd: ELF 32-bit LSB executable, Intel 80386, version 1 (SYSV), statically linked, stripped 

5.13 Netbooting g4u via PXE

6. Support and reporting problems

  • 6.1 Support

    • The following ways of getting support for g4u exist:

       

      • Mailing list: g4u-announce@feyrer.de
        This list will contain announces about g4u only.

         

        • Subscribe or change your settings via the web, or
        • send a mail with "subscribe yourpassword" to g4u-announce-request@feyrer.de to subscribe. Please replace "yourpassword" with your personal, secret list password.
        • Look at the g4u-announce list archive.

         

      • Mailing list: g4u-help@feyrer.de
        This list is intended for questions and answers about g4u.

         

        • Subscribe or change your settings via the web, or
        • send a mail with "subscribe yourpassword" to g4u-help-request@feyrer.de to subscribe. Please replace "yourpassword" with your personal, secret list password.
        • Look at the g4u-help list archive.
      • Orkut "g4u" community:

        There's a "g4u" community at Orkut which I've created as a forum for g4u. As Orkut is too slow these days (Dec 2004), I won't follow discussion on Orkut a lot, and recommend using the above-mentioned mailing lists for getting timely response.

         

      • Optional(!) commercial license are available, see the "Commercial license" page for more information.

    6.2 Reporting problems

    • If you have trouble with g4u and want to report a problem, PLEASE add the following information. It's impossible to help you without knowing details on your systems & setup:

       

      • What g4u version do you use
      • What exact command(s) did you use
      • What exact output did you get (all of it, 1:1, no interpretation on your own)?
      • If the system hangs during boot: what are the last three lines printed on the screen (again all three of them, verbatime)
      • What does "disks" say? "parts"?
      • If you have some problems with some network card or disk driver, please include the relevant parts from "dmesg" output (scroll down with 'space')
      • What operating system, filesystem type and FTP server software do you use on your FTP server?

      Send your bug reports to the g4u-help mailing list.

7. Rebuilding from source

  • G4u is based on NetBSD boot floppy disk set. It consists of a custom kernel and custom bootfloppy, both stripped down to an absolute minimum to fit on two 1.44MB floppy disk or a CDROM. There are also the "copydisk", "uploaddisk" and "slurpdisk" scripts.

    To rebuild the images:

    • Note that for rebuilding, no root permissions are needed any more! Below, the "#" prompt shows action needed as root, "%" is the prompt for commands executed as user.

       

    • Get a i386/PC machine running NetBSD 2.0. Cross-building from other Unix-like operating systems may work too, but is untested as far as g4u is concerned.

       

    • Install mkisofs (part of the cdrecord package), e.g. either as precompiled binary:
           # PKG_PATH=ftp://ftp.NetBSD.org/pub/NetBSD/packages/2.0/i386/All 
           # export PKG_PATH
           # pkg_add -v cdrecord 
      or, if you have pkgsrc installed:
           # cd /usr/pkgsrc/sysutils/cdrecord
           # make install 
    • Get NetBSD-current source from ~May 17th 2005 as /usr/src:
           % su 
           # mkdir /usr/cvs
           # chown $USER /usr/cvs
           # ln -s cvs/src /usr/src
           # exit
           % cd /usr/cvs
           % env CVS_RSH=ssh cvs -d anoncvs@anoncvs.netbsd.org:/cvsroot co -D 20050517 src 
    • To be on the safe side, rebuild a full release (regression testing and more):
           % ./build.sh -N 1 -U release 
    • Remember where to find the new compiler - adjust if necessary:
           % setenv T /usr/src/obj.i386/tooldir.NetBSD-2.0-i386/bin 
    • Get the g4u 2.1 sources

       

    • Unpack the g4u sources:
           % cd /usr/src
           % tar plzvxf .../g4u-2.1.tgz
    • Apply patches:
           % cd /usr/src/sys/dev/ata
           % patch <wd.c.patch-g4u
           % cd /usr/src/sys/dev/scsipi
           % patch <sd.c.patch-g4u
           % cd /usr/src/sys/kern
           % patch <subr_prf.c.patch-g4u
          
    • Build the G4U floppy & ISO-image:
           % cd /usr/src/distrib/i386/floppies/g4u 
           % $T/nbmake-i386 
    • After that, you'll find "g4u1.fs", "g4u1.fs" and "g4u.iso" in /usr/src/distrib/i386/floppies/g4u:
           % pwd
           /usr/cvs/src/distrib/i386/floppies/g4u
           % ls -l g4u.*
           -rw-rw-r--   1 feyrer  netbsd  3309568 Nov  3 23:09 g4u.iso
           -rw-rw-r--   1 feyrer  netbsd  1474560 Nov  3 23:08 g4u1.fs
           -rw-rw-r--   1 feyrer  netbsd  1474560 Nov  3 23:08 g4u2.fs 

     

8. Links & Ressources

    • A tutorial for installing M0n0wall with g4u:
    Roberto Pereyra provided me with instructions on how to install the M0n0wall firewall with g4u. Cool to see them provide their own disk images!

     

    • Harvesting GUIDs / UUIDs for RIS prestaged computer accounts
    ``One of the most time consuming and overly repetitive tasks in supporting an organization with a large number of computers is handling turnover and new machine orders. A typical setup consisted of copying down the MAC addresses and destination hostnames on a piece of paper, typing them up and emailing them to someone else, update the dhcp server, etc., etc. This project is to reduce the ammount of human intervention needed to set up a machine.'' And as a bonus, it's also based on NetBSD! :) [ link]

     

    • MIDS - g4u with user dialogue
    Rob Bennett has modified g4u to load more code from an FTP server, to implement things like a (curses based) user dialogue, etc. While g4u's intent is to have everything on the boot media, this is definitely worth a look!

     

    • The iR110/150 (sparc64) dd Network Backup Page:
    People have asked me for a UltraSPARC (sparc64) based version of g4u. Well here's one: The iR110/150 dd Network Backup Page documents scripts that do disk backups of an UltraSPARC system to a remote NFS server. Bonus to the author for using Solaris! :-)

     

    • Yet Another Ghost Installer (YAGI):
    Daniel Ettle's diploma thesis which I supervised, about a network based installer at Toshiba Regensburg Operations.

     

    • Symantec Ghost
    Commercial product that didn't do what I needed and which led me to create g4u. Still, check it our if you want non-image based cloning. If you think they're too expensive, remember that I don't want to starve too. :)

9. History

  • Still 2.1 Added PXE netboot information
    2.1 Changes: Added serial drivers (com on isapnp and isa) back for those people that need serial console (a few asked...), added support for IT Express and ATI IXP IDE and Promise SATA150 controllers, many bugfixes and enhancements from NetBSD-current, including EHCI-based USB improvements, and "dmesg" now hints at pressing space/CR to scroll down [20050622]
    2.0 Yes, that's 2.0 - really! I got so fed up with the constand lack of space on the g4u floppy version that I finally decided to end the never-ending madness of removing drivers to make it fit. Instead, there are two versions of g4u now: a CDROM-version (can also be used on DVD at no extra costs), and a TWO-floppy-version (consisting of, well, TWO floppies, instead of the one used so far)! When booting the floppy version, it will load the first floppy, then ask for the second one. Press RETURN, and it will load the second floppy. (The splitting onto more than one floppy was made possible by NetBSD's fine infrastructure which is used for g4u, and which allows booting from a multi-volume tar-archive).

    The floppy and CDROM version still share the same codebase - there's still a limit of 2.88MB now, but this allows me adding back all the drivers I had to remove in the past:

    • The wscons console driver, which allows using USB keyboards
    • SATA drives (updated)
    • I2O devices
    • CS8900 (ISA) Ethernet
    • Alteon ACEnic gigabit Ethernet
    • PCMCIA and Cardbus drivers for SCSI, IDE and a *lot* of ethernet and wireless network cards.
    • Fiber Channel drivers for your SAN!
    • Hardware RAID drivers: Adaptec AAC family, AMI/LSI Logic MegaRAID, Compaq PCI array controllers, ICP-Vortex GDT and Intel RAID, Mylex DAC960 & DEC SWXCR family and 3ware Escalade RAID controllers. Whee!
    • Wireless LAN cards: Aironet PC4500/PC4800, Atheros 5210/5211/5212, ADMtek ADM8211, Intersil Prism Mini-PCI.
    • Token Ring drivers for both PCMCIA and ISA IBM/3COM TROPIC cards

    Besides all these drivers which were previously removed from g4u and now added back, be sure to check out the full list of supported hardware, including more wavelan cards, gigabit ethernet and SATA drives!

    Another minor addition made in this release is the 'copypart' program, which can be used to, well, copy single partitions locally. See Copying a partition locally for more information.

    So, this all sounds like christmas? That's a bit away, but maybe you want to donate a bit so I can buy myself and my beloved some nice present (and maybe even one that allows me to do a port of g4u to an Apple PowerBook G4? *hint, hint*)? ;)

    Those that want to do some good not only to me but to themselves and their beloved too can now aquire an optional commercial license for g4u. g4u will remain free to use for both private and commercial users, but I've received many requests for commercial licenses, and here they are!

    Last but not least, I'm fed up with the slowness of Orkut, and using the infrastructure from Source Forge, I've created two mailing lists, one for g4u related announces, and one for general questions on g4u. See the support section for more information.
    [20041207]

     

    Still 1.17 Today I had to discover that someone used g4u as a source for g4l, but instead of giving proper credit and respecting the licensing and copyright on g4u, all traces were removed that the core work was done by me. Instead, the author put his name in and his work under a different license. I'm not happy about this, and ask people to discourage such actions as well as to despise the the author of g4l (cowardly calling himself only "nme"). Read more about this in my blog.
    1.17 Major bugfix release which intends to address all the flaws in previous releases (see release notes for 1.15 and 1.16)! Besides the Freshmeat g4u page, interested parties can now find a g4u community with forum etc. on Orkut - drop me a mail if you want/need an invitation or have any questions (just as before :)! [20040718]
    Back to 1.15! There's a critical flaw in slurpdisk and other restore facilities in 1.16, which render g4u 1.16 unusable. The QA team has been fired, and we're back to 1.15. Sorry! :( [20040702]
    1.16 OK, let's see if I got things right this time: Fixed copydisk, which I broke while adding the progress bar code. Document default GZIP level when calling uploaddisk and uploadpart with no argument. Shaved more space from the config by going for the generic PCIIDE driver (only; please let me know if this made things a lot slower and if it killed SATA-support esp. if enabling IDE in your BIOS won't help - and send me a SATA-equipped machine to test this in the future! :-), removed 'rnd', gave the kernel a fixed device to start from (the ramdisk), removed COMPAT_*. Replaced console driver - you may need to turn on support for USB keyboards in your BIOS! [20040630]
    still 1.15 There's a bug in the "copydisk" command of g4u 1.15, please use g4u 1.14 if you need the copydisk command.
    still 1.15 I have a donations page now!
    1.15 Finally: Improved progress report! No more dots, volume transferred and current throughput is printed instead. Other changes: 'help' command to re-print help screen; update help screen a bit and made the prompt look a bit friendlier. Consistent GZIP handling. Building as non-root is now fully working (Thanks NetBSD!). No more Token Ring drivers, sorry, ran into space issues again. Thank for everyone who has donated so far, I'm working on a donations page. FWIW, donations of books from Amazon are welcome as well, see my wishlist: [20040412]
    1.14 After some minor *cough* bugs in 1.13, here's 1.14. No more "file system full" etc., no functional changes either. Added a few screenshots to the documentation. Keep the donations coming! :-) [20040218]
    Still 1.13 Source update! The sources released for 1.13 had a small problem (missing gz_compress, etc. while linking), I've updated the g4u-1.13.tgz source archive. Proper checksums are 2226011164 (CRC, cksum(1)) and fa2e2f00b079be1a9cf1c81d625896b1 (MD5). [20040122]
    1.13 13's a bad sign, and version 1.13 means so for g4u. Due to my job situation I'm not sure if I can continue working on g4u in the future. Your donations can motivate to do so - paypal@feyrer.de is waiting for you. Today, g4u is mentioned in in one place with commercial products like PowerQuests's DriveImage and Norton's Ghost. g4u is free software and I hoped upon it's users to support it via donations. If I just got $10 from everyone sending me questions about g4u, that'd be more than enough. Fact is that only 1 person has donated back some money so far. Here's your chance to contribute back to the Open Source community - join in!
    Pay me securely with your Visa, MasterCard, Discover, or American Express card through PayPal!
    VisaMasterCardDiscoverAmerican Express

    Griping aside, V1.13 is a wrapup based on NetBSD-current as of Jan 14th 2004, esp. made after many people hat troubles booting 1.12. New drivers are for Adaptec 29320, 39320 (aic790x) SCSI (ahd), Broadcom 4401 10/100 Ethernet (bge), DECchip 21x4x and clones Ethernet (tlp), Intel 8254x gigabit (wm), Intel IGP01E1000 MII driver (igphy), Intel i31244 and SiI SATALink SATA controllers. See the g4u kernel config file for all the details. Matthias Jordan has also sent me an update of his "nullfile" to v1.02 which I've added to the g4u webpage.

    Due to some things growing again, I had to remove all Wireless LAN and most PCI RAID controller drivers. Maybe it's time to start special g4u versions for laptops (with pcmcia, cardbus, usb, wavelan), servers (with raid, ...) in addition to the current version of g4u. Let me know if you're interested! [20040111]

    1.13pre2 Prerelease of 1.13 ISO after many people had problems booting the 1.12 ISO. No new features, but two administrative things to note: First, I've lost my job on Jan 1st 2004 due to the Bavarian government killing jobs in academics. That job was the main motivation behind creating g4u, and development of g4u beyond that date is uncertain. I plan to do at least one more release to wrap up things, but that'll need some more time to decide what drivers to include (not). Second, I have created a paypal account paypal@feyrer.de, if you want to donate money, buy me a pizza or coke or just SUPPORT FREE SOFTWARE, do so! (Judging by the feedback I got both in personal mail and in public forums, g4u seems to be a major alternative to some commercial products these days. I'd be happy if the people using it could give some money back to make it possible to continue working on the project! Yes, this is a plea for help!)
    1.12 Fix broken dd commmand ("out of memory!"). [20030820]
    1.11 New commands "uploadpart" and "slurppart" to save and restore partitions. Partition information is not changed and taken from MBR. Command 'disks' to list disks found, command 'parts' to list (BSD!) partitions on a given disk (wd0, ...). "uploaddisk" now has a default of rwd0d.gz for the imagename, so just "uploaddisk server" should work (just as "slurpdisk server" does already). [20030819]
    1.10 Bugfix release: make "GZIP=1 uploaddisk ..." work properly; document how to use a different account than 'install'. Document how to get the image size down by filling unused disk blocks with zero-bytes. [20030603]
    1.9 Maintenance update for NetBSD-current as of today; "dmesg" is now page-wise (|more); "disks" lists disks recognized on boot; allow setting GZIP=-1 to get lower compression; increased NMBCLUSTERS for usb2ethernet; Cloning from local disk to local disk with "clonedisk"; Lots of doc updates. [20030522]
    1.8 The Pumpkin Release! Sync with NetBSD 1.6. Now includes drivers for USB, RAID cards, Gigabit Ethernet and Token Ring. As a Halloween special, g4u now also comes as ISO image file in addition to a floppy image, so it can be booted from a CD instead of a floppy. Happy Halloween! :) [20021031]
    1.7 Update to accomodate latest drivers and kernel features from NetBSD 1.5.2. Fixed download of the .fs files from the web server. Added documentation about disk sizes. [20010919]
    1.6 Maintenance release to use latest drivers from NetBSD 1.5.1. Due to increased size, the Token Ring driver was removed, sorry. Greeting message of g4u with instructions was improved a bit. Web site now has a copy of the kernel config, for documentation of supported device drivers. [20010516]
    1.5 This release adds support for easy cloning of SCSI disks by giving "sd0" as the third argument to slurpdisk and uploaddisk. Also, support for i386 and i486 CPUs was added. [20010515]
    1.4 Maintenance release. [20010306]
     Played with GIMP to create the Animation next to the TOC. Thanks to the XBill artists for the OS images! Various doc updates. [20010306]
     Updated the web page a bit to answer various questions on supported filesystems and operating systems I got. Also add TOC. [20010305]
    1.3 Another bugfix release. This should get to a working state soon (i.e. now) [20010302]
    1.2 Bugfix release, the ramdisk was busted so that many commands just didn't work (ftp, ...) [20010301]
    1.1 First public release, updated to NetBSD 1.5 [20010228]
    1.0 Internal version based on NetBSD 1.4 that's been in use for two years in internal operation.

10. Copying, licenses & donations

  • No license fees are requested except for military and related uses, optional commercial licenses are available, and donations are always welcome! You can send money via paypal or buy me a book from my Amazon wishlist, as many of the people who have donated so far did - Thank you very much!

    g4u is distributed under the standard BSD license:

     

    Pay me securely with your Visa, MasterCard, Discover, or American Express card through PayPal!
    VisaMasterCardDiscoverAmerican Express

     

    /*
     * Copyright (c) 1999-2006
     *	Hubert Feyrer <hubert@feyrer.de>.  All rights reserved.
     *
     * Redistribution and use in source and binary forms, with or without
     * modification, are permitted provided that the following conditions
     * are met:
     * 1. Redistributions of source code must retain the above copyright
     *    notice, this list of conditions and the following disclaimer.
     * 2. Redistributions in binary form must reproduce the above copyright
     *    notice, this list of conditions and the following disclaimer in the
     *    documentation and/or other materials provided with the distribution.
     * 3. All advertising materials mentioning features or use of this software
     *    must display the following acknowledgement:
     *	This product includes software developed for g4u by 
     *	Hubert Feyrer <hubert@feyrer.de>.
     * 4. Neither the name of the author nor the names of its contributors
     *    may be used to endorse or promote products derived from this software
     *    without specific prior written permission.
     *
     * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
     * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
     * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     * SUCH DAMAGE.
     */
    

(c) Copyright 1999-2005 Hubert Feyrer <hubert@feyrer.de>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Quartz是OpenSymphony开源组织在Job scheduling领域又一个开源项目,它可以与J2EE与J2SE应用程序相结合也可以单独使用。Quartz可以用来创建简单或为运行十个,百个,甚至是好几万个Jobs这样复杂的程序。Jobs可以做成标准的Java组件或 EJBs。 Quartz的优势: 1、Quartz是一个任务调度框架(库),它几乎可以集成到任何应用系统中。 2、Quartz是非常灵活的,它让您能够以最“自然”的方式来编写您的项目的代码,实现您所期望的行为 3、Quartz是非常轻量级的,只需要非常少的配置 —— 它实际上可以被跳出框架来使用,如果你的需求是一些相对基本的简单的需求的话。 4、Quartz具有容错机制,并且可以在重启服务的时候持久化(”记忆”)你的定时任务,你的任务也不会丢失。 5、可以通过Quartz,封装成自己的分布式任务调度,实现强大的功能,成为自己的产品。6、有很多的互联网公司也都在使用Quartz。比如美团 Spring是一个很优秀的框架,它无缝的集成了Quartz,简单方便的让企业级应用更好的使用Quartz进行任务的调度。   课程说明:在我们的日常开发中,各种大型系统的开发少不了任务调度,简单的单机任务调度已经满足不了我们的系统需求,复杂的任务会让程序猿头疼, 所以急需一套专门的框架帮助我们去管理定时任务,并且可以在多台机器去执行我们的任务,还要可以管理我们的分布式定时任务。本课程从Quartz框架讲起,由浅到深,从使用到结构分析,再到源码分析,深入解析Quartz、Spring+Quartz,并且会讲解相关原理, 让大家充分的理解这个框架和框架的设计思想。由于互联网的复杂性,为了满足我们特定的需求,需要对Spring+Quartz进行二次开发,整个二次开发过程都会进行讲解。Spring被用在了越来越多的项目中, Quartz也被公认为是比较好用的定时器设置工具,学完这个课程后,不仅仅可以熟练掌握分布式定时任务,还可以深入理解大型框架的设计思想。
[入门数据分析的第一堂课]这是一门为数据分析小白量身打造的课程,你从网络或者公众号收集到很多关于数据分析的知识,但是它们零散不成体系,所以第一堂课首要目标是为你介绍:Ø  什么是数据分析-知其然才知其所以然Ø  为什么要学数据分析-有目标才有动力Ø  数据分析的学习路线-有方向走得更快Ø  数据分析的模型-分析之道,快速形成分析思路Ø  应用案例及场景-分析之术,掌握分析方法[哪些同学适合学习这门课程]想要转行做数据分析师的,零基础亦可工作中需要数据分析技能的,例如运营、产品等对数据分析感兴趣,想要更多了解的[你的收获]n  会为你介绍数据分析的基本情况,为你展现数据分析的全貌。让你清楚知道自己该如何在数据分析地图上行走n  会为你介绍数据分析的分析方法和模型。这部分是讲数据分析的道,只有学会底层逻辑,能够在面对问题时有自己的想法,才能够下一步采取行动n  会为你介绍数据分析的数据处理和常用分析方法。这篇是讲数据分析的术,先有道,后而用术来实现你的想法,得出最终的结论。n  会为你介绍数据分析的应用。学到这里,你对数据分析已经有了初步的认识,并通过一些案例为你展现真实的应用。[专享增值服务]1:一对一答疑         关于课程问题可以通过微信直接询问老师,获得老师的一对一答疑2:转行问题解答         在转行的过程中的相关问题都可以询问老师,可获得一对一咨询机会3:打包资料分享         15本数据分析相关的电子书,一次获得终身学习
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值