livemedia-creator: Allow disk sizes to be < 1GiB

Anaconda seems to insist on 3G minimum, but that is a different issue.
This commit is contained in:
Brian C. Lane 2014-04-03 11:52:41 -07:00
parent 30591349ca
commit 94e92ee9ea

View File

@ -240,7 +240,7 @@ class VirtualInstall( object ):
""" """
Run virt-install using an iso and kickstart(s) Run virt-install using an iso and kickstart(s)
""" """
def __init__( self, iso, ks_paths, disk_img, img_size=2, def __init__( self, iso, ks_paths, disk_img, img_size=2048,
kernel_args=None, memory=1024, vnc=None, arch=None, kernel_args=None, memory=1024, vnc=None, arch=None,
log_check=None, virtio_host="127.0.0.1", virtio_port=6080, log_check=None, virtio_host="127.0.0.1", virtio_port=6080,
qcow2=False): qcow2=False):
@ -250,7 +250,7 @@ class VirtualInstall( object ):
ks_paths is a list of paths to a kickstart files. All are injected, the ks_paths is a list of paths to a kickstart files. All are injected, the
first one is the one executed. first one is the one executed.
disk_img is the path to a disk image (doesn't need to exist) disk_img is the path to a disk image (doesn't need to exist)
img_size is the size, in GiB, of the image if it doesn't exist img_size is the size, in MiB, of the image if it doesn't exist
kernel_args are extra arguments to pass on the kernel cmdline kernel_args are extra arguments to pass on the kernel cmdline
memory is the amount of ram to assign to the virt memory is the amount of ram to assign to the virt
vnc is passed to the --graphics command verbatim vnc is passed to the --graphics command verbatim
@ -282,7 +282,7 @@ class VirtualInstall( object ):
else: else:
disk_opts += ",format=raw" disk_opts += ",format=raw"
if not os.path.isfile(disk_img): if not os.path.isfile(disk_img):
disk_opts += ",size={0}".format(img_size) mksparse(disk_img, img_size * 1024**2)
args.append("--disk") args.append("--disk")
args.append(disk_opts) args.append(disk_opts)
@ -397,7 +397,7 @@ def make_appliance(disk_img, name, template, outfile, networks=None, ram=1024,
sha256 = hashlib.sha256() sha256 = hashlib.sha256()
with open(disk_img) as f: with open(disk_img) as f:
while True: while True:
data = f.read(1024*1024) data = f.read(1024**2)
if not data: if not data:
break break
sha256.update(data) sha256.update(data)
@ -416,21 +416,26 @@ def make_appliance(disk_img, name, template, outfile, networks=None, ram=1024,
f.write(result) f.write(result)
def make_fsimage(diskimage, fsimage, label="Anaconda"): def make_fsimage(diskimage, fsimage, img_size=None, label="Anaconda"):
""" """
Copy the / partition of a partitioned disk image to an un-partitioned Copy the / partition of a partitioned disk image to an un-partitioned
disk image. disk image.
diskimage is the full path to partitioned disk image with a / diskimage is the full path to partitioned disk image with a /
fsimage is the full path of the output fs image file fsimage is the full path of the output fs image file
img_size is the size of the fsimage in MiB or None to make it as small as possible
label is the label to apply to the image. Defaults to "Anaconda" label is the label to apply to the image. Defaults to "Anaconda"
""" """
with PartitionMount(diskimage) as img_mount: with PartitionMount(diskimage) as img_mount:
if not img_mount or not img_mount.mount_dir: if not img_mount or not img_mount.mount_dir:
return None return None
log.info("Creating fsimage %s", fsimage) log.info("Creating fsimage %s (%s)", (fsimage, img_size or "minimized"))
mkext4img(img_mount.mount_dir, fsimage, label=label) if img_size:
# convert to Bytes
img_size *= 1024**2
mkext4img(img_mount.mount_dir, fsimage, size=img_size, label=label)
def make_runtime(opts, mount_dir, work_dir): def make_runtime(opts, mount_dir, work_dir):
@ -522,6 +527,10 @@ def make_livecd(opts, mount_dir, work_dir):
def novirt_install(opts, disk_img, disk_size, repo_url): def novirt_install(opts, disk_img, disk_size, repo_url):
""" """
Use Anaconda to install to a disk image Use Anaconda to install to a disk image
disk_img is the full path to the disk image to be created
disk_size is the size in MiB
repo_url is the url of the repository to use for the installation
""" """
import selinux import selinux
@ -549,7 +558,7 @@ def novirt_install(opts, disk_img, disk_size, repo_url):
# Make a blank fs image # Make a blank fs image
args += ["--dirinstall"] args += ["--dirinstall"]
mkext4img(None, disk_img, label=opts.fs_label, size=disk_size * 1024**3) mkext4img(None, disk_img, label=opts.fs_label, size=disk_size * 1024**2)
if not os.path.isdir(ROOT_PATH): if not os.path.isdir(ROOT_PATH):
os.mkdir(ROOT_PATH) os.mkdir(ROOT_PATH)
mount(disk_img, opts="loop", mnt=ROOT_PATH) mount(disk_img, opts="loop", mnt=ROOT_PATH)
@ -557,7 +566,7 @@ def novirt_install(opts, disk_img, disk_size, repo_url):
args += ["--image", disk_img] args += ["--image", disk_img]
# Create the sparse image # Create the sparse image
mksparse(disk_img, disk_size * 1024**3) mksparse(disk_img, disk_size * 1024**2)
# Make sure anaconda has the right product and release # Make sure anaconda has the right product and release
os.environ["ANACONDA_PRODUCTNAME"] = opts.project os.environ["ANACONDA_PRODUCTNAME"] = opts.project
@ -612,7 +621,7 @@ def virt_install(opts, install_log, disk_img, disk_size):
install_log is the path to write the log from virt-install install_log is the path to write the log from virt-install
disk_img is the full path to the final disk or filesystem image disk_img is the full path to the final disk or filesystem image
disk_size is the size of the disk to create in GiB disk_size is the size of the disk to create in MiB
""" """
iso_mount = IsoMountpoint(opts.iso, opts.location) iso_mount = IsoMountpoint(opts.iso, opts.location)
log_monitor = LogMonitor(install_log) log_monitor = LogMonitor(install_log)
@ -629,7 +638,7 @@ def virt_install(opts, install_log, disk_img, disk_size):
for arg in opts.qcow2_args: for arg in opts.qcow2_args:
qcow2_args += arg.split(" ", 1) qcow2_args += arg.split(" ", 1)
mkqcow2(disk_img, disk_size*1024**3, qcow2_args) mkqcow2(disk_img, disk_size*1024**2, qcow2_args)
if opts.make_fsimage: if opts.make_fsimage:
diskimg_path = tempfile.mktemp(prefix="disk", suffix=".img", dir=opts.tmp) diskimg_path = tempfile.mktemp(prefix="disk", suffix=".img", dir=opts.tmp)
@ -651,7 +660,7 @@ def virt_install(opts, install_log, disk_img, disk_size):
raise InstallError("virt_install failed") raise InstallError("virt_install failed")
if opts.make_fsimage: if opts.make_fsimage:
make_fsimage(diskimg_path, disk_img, label=opts.fs_label) make_fsimage(diskimg_path, disk_img, disk_size, label=opts.fs_label)
os.unlink(diskimg_path) os.unlink(diskimg_path)
@ -678,8 +687,8 @@ def make_image(opts, ks):
Returns the full path of of the image created. Returns the full path of of the image created.
""" """
disk_size = 1 + (sum([p.size for p in ks.handler.partition.partitions]) / 1024) disk_size = 1 + sum(p.size for p in ks.handler.partition.partitions)
log.info("disk_size = %sGB", disk_size) log.info("disk_size = %sMiB", disk_size)
if opts.image_name: if opts.image_name:
disk_img = joinpaths(opts.tmp, opts.image_name) disk_img = joinpaths(opts.tmp, opts.image_name)