kiwi-ng [global options] service <command> [<args>]

kiwi-ng -h | --help
kiwi-ng [--profile=<name>...]
    image <command> [<args>...]
kiwi-ng [--debug]
    result <command> [<args>...]
kiwi-ng [--profile=<name>...]
    system <command> [<args>...]
kiwi-ng compat <legacy_args>...
kiwi-ng -v | --version
kiwi-ng help


KIWI NG is an imaging solution that is based on an image XML description. Such a description is represented by a directory which includes at least one config.xml or .kiwi file and may as well include other files like scripts or configuration data.

A collection of example image descriptions can be found on the github repository here: Most of the descriptions provide a so called appliance image. Appliance means that it’s a small, text only based image including a predefined remote source setup to allow installation of missing software components at a later point in time.

KIWI NG operates in two steps. The system build command combines both steps into one to make it easier to start with KIWI NG. The first step is the preparation step and if that step was successful, a creation step follows which is able to create different image output types.

In the preparation step, you prepare a directory including the contents of your new filesystem based on one or more software package source(s) The creation step is based on the result of the preparation step and uses the contents of the new image root tree to create the output image.

KIWI NG supports the creation of the following image types:

  • ISO Live Systems

  • Virtual Disk for e.g cloud frameworks

  • OEM Expandable Disk for system deployment from ISO or the network

  • File system images for deployment in a pxe boot environment

Depending on the image type a variety of different disk formats and architectures are supported.



Use Escape Sequences to print different types of information in colored output. The underlaying terminal has to understand those escape characters. Error messages appear red, warning messages yellow and debugging information will be printed light grey.


Print debug information on the commandline.


Specify log file. the logfile contains detailed information about the process.


Select profile to use. The specified profile must be part of the XML description. The option can be specified multiple times to allow using a combination of profiles


Specify an alternative shared cache directory. The directory is shared via bind mount between the build host and image root system and contains information about package repositories and their cache and meta data. The default location is set to /var/cache/kiwi


Select image build type. The specified build type must be configured as part of the XML description.


Show program version


$ git clone

$ kiwi --type oem system build \
    --description kiwi-descriptions/suse/x86_64/suse-leap-15.1 \
    --target-dir /tmp/myimage


This version of KIWI NG uses a different caller syntax compared to former versions. However there is a compatibility mode which allows to use a legacy KIWI NG commandline as follows:

$ kiwi compat \
    --build kiwi-descriptions/suse/x86_64/suse-leap-15.1 \
    --type oem -d /tmp/myimage