Mini Shell

Direktori : /usr/share/doc/python3-blivet/examples/
Upload File :
Current File : //usr/share/doc/python3-blivet/examples/lvm_cachepool.py

import os

import blivet
from blivet.size import Size
from blivet.util import set_up_logging, create_sparse_tempfile


set_up_logging()
b = blivet.Blivet()   # create an instance of Blivet (don't add system devices)

# create a disk image file on which to create new devices
disk1_file = create_sparse_tempfile("disk1", Size("100GiB"))
b.disk_images["disk1"] = disk1_file
disk2_file = create_sparse_tempfile("disk2", Size("100GiB"))
b.disk_images["disk2"] = disk2_file

b.reset()

try:
    disk1 = b.devicetree.get_device_by_name("disk1")
    disk2 = b.devicetree.get_device_by_name("disk2")

    b.initialize_disk(disk1)
    b.initialize_disk(disk2)

    pv = b.new_partition(size=Size("50GiB"), fmt_type="lvmpv", parents=[disk1])
    b.create_device(pv)
    pv2 = b.new_partition(size=Size("50GiB"), fmt_type="lvmpv", parents=[disk2])
    b.create_device(pv2)

    # allocate the partitions (decide where and on which disks they'll reside)
    blivet.partitioning.do_partitioning(b)

    vg = b.new_vg(parents=[pv, pv2])
    b.create_device(vg)

    # new lv with base size 5GiB and growth up to 15GiB and an ext4 filesystem
    lv = b.new_lv(fmt_type="ext4", size=Size("5GiB"), parents=[vg], name="cached")
    b.create_device(lv)

    # new cache pool
    cpool = b.new_lv(size=Size("1 GiB"), parents=[vg], pvs=[pv2], cache_pool=True, name="fastlv")
    b.create_device(cpool)

    # write the new partitions to disk and format them as specified
    b.do_it()
    print(b.devicetree)

    # attach the newly created cache pool to the "slow" LV
    lv.attach_cache(cpool)

    b.reset()
    print(b.devicetree)

    input("Check the state and hit ENTER to trigger cleanup")
finally:
    b.devicetree.teardown_disk_images()
    os.unlink(disk1_file)
    os.unlink(disk2_file)