cmd-output.log
  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
cmd: mmdebstrap --mode=unshare --format=tar --architectures=i386 --verbose --hook-dir=/usr/share/mmdebstrap/hooks/maybe-jessie-or-older '--customize-hook=cd "$1" && find etc/apt/sources.list.d -type f -delete' '--customize-hook=upload /tmp/debusine-fetch-exec-upload-uhbrlz59/chroot.sources /etc/apt/sources.list.d/file.sources' '--customize-hook=mkdir "$1/etc/apt/keyrings-debusine"' --keyring=/tmp/debusine-fetch-exec-upload-pxbcpb8x/keyrings/keyring-repo-hg4p4loz.asc --keyring=/tmp/debusine-fetch-exec-upload-uhbrlz59/keyrings/keyring-repo-pl__2syv.asc '--customize-hook=download /etc/os-release os-release' '--customize-hook=copy-out /var/lib/dpkg var_lib_dpkg' '--customize-hook=rm -f "$1/etc/hostname"' '--customize-hook=test -h "$1/etc/resolv.conf" || rm -f "$1/etc/resolv.conf"' '--customize-hook=(test -x "$1/sbin/init" || test -h "$1/sbin/init") ; echo $? > "$1/test_sbin_init"' '--customize-hook=download test_sbin_init test-sbin-init' '--customize-hook=rm "$1/test_sbin_init"' --variant=buildd --include=apt,e2fsprogs,tzdata '' system.tar.xz '' /tmp/debusine-fetch-exec-upload-uhbrlz59/host.sources
output (contains stdout and stderr):
E: keyring "/tmp/debusine-fetch-exec-upload-pxbcpb8x/keyrings/keyring-repo-hg4p4loz.asc" does not exist
Usage:
    mmdebstrap [OPTION...] [SUITE [TARGET [MIRROR...]]]

Options:
    Options are case insensitive. Short options may be bundled. Long options
    require a double dash and may be abbreviated to uniqueness. Options can
    be placed anywhere on the command line, even before or mixed with the
    SUITE, TARGET, and MIRROR arguments. A double dash "--" can be used to
    stop interpreting command line arguments as options to allow SUITE,
    TARGET and MIRROR arguments that start with a single or double dash.
    Option order only matters for options that can be passed multiple times
    as documented below.

    -h,--help
            Print synopsis and options of this man page and exit.

    --man   Show the full man page as generated from Perl POD in a pager.
            This requires the perldoc program from the perl-doc package.
            This is the same as running:

                pod2man /usr/bin/mmdebstrap | man -l -

    --version
            Print the mmdebstrap version and exit.

    --variant=name
            Choose which package set to install. Valid variant names are
            extract, custom, essential, apt, required, minbase, buildd,
            important, debootstrap, -, and standard. The default variant is
            debootstrap. See the section VARIANTS for more information.

    --mode=name
            Choose how to perform the chroot operation and create a
            filesystem with ownership information different from the current
            user. Valid mode names are auto, sudo, root, unshare, fakeroot,
            fakechroot and chrootless. The default mode is auto. See the
            section MODES for more information.

    --format=name
            Choose the output format. Valid format names are auto,
            directory, tar, squashfs, ext2 and null. The default format is
            auto. See the section FORMATS for more information.

    --aptopt=option|file
            Pass arbitrary options to apt. Will be permamently added to
            /etc/apt/apt.conf.d/99mmdebstrap inside the chroot. Use hooks
            for temporary configuration options. Can be specified multiple
            times. Each option will be appended to 99mmdebstrap. A semicolon
            will be added at the end of the option if necessary. If the
            command line argument is an existing file, the content of the
            file will be appended to 99mmdebstrap verbatim.

            Example: This is necessary for allowing old timestamps from
            snapshot.debian.org

                --aptopt='Acquire::Check-Valid-Until "false"'
                --aptopt='Apt::Key::gpgvcommand "/usr/libexec/mmdebstrap/gpgvnoexpkeysig"'

            Example: Settings controlling download of package description
            translations

                --aptopt='Acquire::Languages { "environment"; "en"; }'
                --aptopt='Acquire::Languages "none"'

            Example: Enable installing Recommends (by default mmdebstrap
            doesn't)

                --aptopt='Apt::Install-Recommends "true"'

            Example: Configure apt-cacher or apt-cacher-ng as an apt proxy

                --aptopt='Acquire::http { Proxy "http://127.0.0.1:3142"; }'

            Example: For situations in which the apt sandbox user cannot
            access the chroot

                --aptopt='APT::Sandbox::User "root"'

            Example: Minimizing the number of packages installed from
            experimental

                --aptopt='APT::Solver "aspcud"'
                --aptopt='APT::Solver::aspcud::Preferences
                   "-count(solution,APT-Release:=/a=experimental/),-removed,-changed,-new"'

    --keyring=file|directory
            Change the default keyring to use by apt during the initial
            setup. This is similar to setting Dir::Etc::Trusted and
            Dir::Etc::TrustedParts using --aptopt except that the latter
            setting will be permanently stored in the chroot while the
            keyrings passed via <--keyring> will only be visible to apt as
            run by mmdebstrap. Do not use --keyring if apt inside the chroot
            needs to know about your keys after the initial chroot creation
            by mmdebstrap. This option is mainly intended for users who use
            mmdebstrap as a deboostrap drop-in replacement. As such, it is
            probably not what you want to use if you use mmdebstrap with
            more than a single mirror unless you pass it a directory
            containing all the keyrings you need.

            By default, the local setting of Dir::Etc::Trusted and
            Dir::Etc::TrustedParts are used to choose the keyring used by
            apt as run by mmdebstrap. These two locations are set to
            /etc/apt/trusted.gpg and /etc/apt/trusted.gpg.d by default.
            Depending on whether a file or directory is passed to this
            option, the former and latter default can be changed,
            respectively. Since apt only supports a single keyring file and
            directory, respectively, you can not use this option to pass
            multiple files and/or directories. Using the "--keyring"
            argument in the following way is equal to keeping the default:

                --keyring=/etc/apt/trusted.gpg --keyring=/etc/apt/trusted.gpg.d

            If you need to pass multiple keyrings, use the "signed-by"
            option when specifying the mirror like this:

                mmdebstrap mysuite out.tar "deb [signed-by=/path/to/key.gpg] http://..."

            Another reason to use "signed-by" instead of --keyring is if apt
            inside the chroot needs to know by what key the repository is
            signed even after the initial chroot creation.

            The "signed-by" option will automatically be added to the final
            "sources.list" if the keyring required for the selected SUITE is
            not yet trusted by apt. Automatically adding the "signed-by"
            option in these cases requires "gpg" to be installed. If "gpg"
            and "ubuntu-archive-keyring" are installed, then you can create
            a Ubuntu Bionic chroot on Debian like this:

                mmdebstrap bionic ubuntu-bionic.tar

            The resulting chroot will have a "source.list" with a
            "signed-by" option pointing to
            /usr/share/keyrings/ubuntu-archive-keyring.gpg.

            You do not need to use --keyring or "signed-by" if you placed
            the keys that apt needs to know about into
            /etc/apt/trusted.gpg.d in the --setup-hook (which is before "apt
            update" runs), for example by using the <copy-in> special hook.
            You also need to copy your keys into the chroot explicitly if
            the key you passed via "signed-by" points to a location that is
            not otherwise populated during chroot creation (for example by
            installing a keyring package).

    --dpkgopt=option|file
            Pass arbitrary options to dpkg. Will be permanently added to
            /etc/dpkg/dpkg.cfg.d/99mmdebstrap inside the chroot. Use hooks
            for temporary configuration options. Can be specified multiple
            times. Each option will be appended to 99mmdebstrap. If the
            command line argument is an existing file, the content of the
            file will be appended to 99mmdebstrap verbatim.

            Example: Exclude paths to reduce chroot size

                --dpkgopt='path-exclude=/usr/share/man/*'
                --dpkgopt='path-include=/usr/share/man/man[1-9]/*'
                --dpkgopt='path-exclude=/usr/share/locale/*'
                --dpkgopt='path-include=/usr/share/locale/locale.alias'
                --dpkgopt='path-exclude=/usr/share/doc/*'
                --dpkgopt='path-include=/usr/share/doc/*/copyright'
                --dpkgopt='path-include=/usr/share/doc/*/changelog.Debian.*'

    --include=pkg1[,pkg2,...]
            Comma or whitespace separated list of packages which will be
            installed in addition to the packages installed by the specified
            variant. The direct and indirect hard dependencies will also be
            installed. The behaviour of this option depends on the selected
            variant. The extract and custom variants install no packages by
            default, so for these variants, the packages specified by this
            option will be the only ones that get either extracted or
            installed by dpkg, respectively. For all other variants, apt is
            used to install the additional packages. Package names are
            directly passed to apt and thus, you can use apt features like
            "pkg/suite", "pkg=version", "pkg-", use a glob or regex for
            "pkg", use apt patterns or pass a path to a .deb package file
            (see below for notes concerning passing the path to a .deb
            package file in unshare mode). See apt(8) for the supported
            syntax.

            The option can be specified multiple times and the packages are
            concatenated in the order in which they are given on the command
            line. If later list items are repeated, then they get dropped so
            that the resulting package list is free of duplicates. So the
            following are equivalent:

                --include="pkg1/stable pkg2=1.0 pkg3-"
                --include=pkg1/stable,pkg2=1.0,pkg3-,,,
                --incl=pkg1/stable --incl="pkg2=1.0 pkg3-" --incl=pkg2=1.0,pkg3-

            Since the list of packages is separated by comma or whitespace,
            it is not possible to mix apt patterns or .deb package file
            paths containing either commas or whitespace with normal package
            names. If you do, your patterns and paths will be split by comma
            and whitespace as well and become useless. To pass such a
            pattern or package file path, put them into their own --include
            option. If the argument to --include starts with an apt pattern
            or with a file path, then it will not be split:

                --include="?or(?priority(required), ?priority(important))"
                --include="./path/to/deb with spaces/and,commas/foo.deb"

            Specifically, all arguments to --include that start with a "?",
            "!", "~", "(", "/", "./" or "../" are not split and treated as
            single arguments to apt. To add more packages, use multiple
            --include options. To disable this detection of patterns and
            paths, start the argument to --include with a comma or
            whitespace.

            If you pass the path to a .deb package file using --include,
            mmdebstrap will ensure that the path exists. If the path is a
            relative path, it will internally by converted to an absolute
            path. Since apt (outside the chroot) passes paths to dpkg (on
            the inside) verbatim, you have to make the .deb package
            available under the same path inside the chroot as well or
            otherwise dpkg inside the chroot will be unable to access it.
            This can be achieved using a setup-hook. A hook that
            automatically makes the contents of "file://" mirrors as well as
            .deb packages given with --include available inside the chroot
            is provided by mmdebstrap as
            --hook-dir=/usr/share/mmdebstrap/hooks/file-mirror-automount.
            This hook takes care of copying all relevant file to their
            correct locations and cleans up those files at the end. In
            unshare mode, the .deb package paths have to be accessible by
            the unshared user as well. This means that the package itself
            likely must be made world-readable and all directory components
            on the path to it world-executable.

    --components=comp1[,comp2,...]
            Comma or whitespace separated list of components like main,
            contrib, non-free and non-free-firmware which will be used for
            all URI-only MIRROR arguments. The option can be specified
            multiple times and the components are concatenated in the order
            in which they are given on the command line. If later list items
            are repeated, then they get dropped so that the resulting
            component list is free of duplicates. So the following are
            equivalent:

                --components="main contrib non-free non-free-firmware"
                --components=main,contrib,non-free,non-free-firmware
                --comp=main --comp="contrib non-free" --comp="main,non-free-firmware"

    --architectures=native[,foreign1,...]
            Comma or whitespace separated list of architectures. The first
            architecture is the native architecture inside the chroot. The
            remaining architectures will be added to the foreign dpkg
            architectures. Without this option, the native architecture of
            the chroot defaults to the native architecture of the system
            running mmdebstrap. The option can be specified multiple times
            and values are concatenated. If later list items are repeated,
            then they get dropped so that the resulting list is free of
            duplicates. So the following are equivalent:

                --architectures="amd64 armhf mipsel"
                --architectures=amd64,armhf,mipsel
                --arch=amd64 --arch="armhf mipsel" --arch=armhf,mipsel

    --simulate, --dry-run
            Run apt-get with --simulate. Only the package cache is
            initialized but no binary packages are downloaded or installed.
            Use this option to quickly check whether a package selection
            within a certain suite and variant can in principle be installed
            as far as their dependencies go. If the output is a tarball,
            then no output is produced. If the output is a directory, then
            the directory will be left populated with the skeleton files and
            directories necessary for apt to run in it. No hooks are
            executed in with --simulate or --dry-run.

    --setup-hook=command
            Execute arbitrary commands right after initial setup (directory
            creation, configuration of apt and dpkg, ...) but before any
            packages are downloaded or installed. At that point, the chroot
            directory does not contain any executables and thus cannot be
            chroot-ed into. See section HOOKS for more information.

            Example: Setup chroot for installing a sub-essential
            busybox-based chroot with --variant=custom
            --include=dpkg,busybox,libc-bin,base-files,base-passwd,debianuti
            ls

                --setup-hook='mkdir -p "$1/bin"'
                --setup-hook='for p in awk cat chmod chown cp diff echo env grep less ln
                    mkdir mount rm rmdir sed sh sleep sort touch uname mktemp; do
                    ln -s busybox "$1/bin/$p"; done'
                --setup-hook='echo root:x:0:0:root:/root:/bin/sh > "$1/etc/passwd"'
                --setup-hook='printf "root:x:0:\nmail:x:8:\nutmp:x:43:\n" > "$1/etc/group"'

            For a more elegant way for setting up a sub-essential
            busybox-based chroot, see the --hook-dir option below.

    --extract-hook=command
            Execute arbitrary commands after the Essential:yes packages have
            been extracted but before installing them. See section HOOKS for
            more information.

            Example: Install busybox symlinks

                --extract-hook='chroot "$1" /bin/busybox --install -s'

    --essential-hook=command
            Execute arbitrary commands after the Essential:yes packages have
            been installed but before installing the remaining packages. The
            hook is not executed for the extract and custom variants. See
            section HOOKS for more information.

            Example: Enable unattended upgrades

                --essential-hook='echo unattended-upgrades
                    unattended-upgrades/enable_auto_updates boolean true
                    | chroot "$1" debconf-set-selections'

            Example: Select Europe/Berlin as the timezone

                --essential-hook='echo tzdata tzdata/Areas select Europe
                    | chroot "$1" debconf-set-selections'
                --essential-hook='echo tzdata tzdata/Zones/Europe select Berlin
                    | chroot "$1" debconf-set-selections'

    --customize-hook=command
            Execute arbitrary commands after the chroot is set up and all
            packages got installed but before final cleanup actions are
            carried out. See section HOOKS for more information.

            Example: Preparing a chroot for use with autopkgtest

                --customize-hook='chroot "$1" passwd --delete root'
                --customize-hook='chroot "$1" useradd --home-dir /home/user
                    --create-home user'
                --customize-hook='chroot "$1" passwd --delete user'
                --customize-hook='echo host > "$1/etc/hostname"'
                --customize-hook='echo "127.0.0.1 localhost host" > "$1/etc/hosts"'
                --customize-hook=/usr/share/autopkgtest/setup-commands/setup-testbed

    --hook-directory=directory
            Execute scripts in directory with filenames starting with
            "setup", "extract", "essential" or "customize", at the
            respective stages during an mmdebstrap run. The files must be
            marked executable. Their extension is ignored. Subdirectories
            are not traversed. This option is a short-hand for specifying
            the remaining four hook options individually for each file in
            the directory. If there are more than one script for a stage,
            then they are added alphabetically. This is useful in cases,
            where a user wants to run the same hooks frequently. For
            example, given a directory "./hooks" with two scripts
            "setup01-foo.sh" and "setup02-bar.sh", this call:

                mmdebstrap --customize=./scriptA --hook-dir=./hooks --setup=./scriptB

            is equivalent to this call:

                mmdebstrap --customize=./scriptA --setup=./hooks/setup01-foo.sh \
                    --setup=./hooks/setup02-bar.sh --setup=./scriptB

            The option can be specified multiple times and scripts are added
            to the respective hooks in the order the options are given on
            the command line. Thus, if the scripts in two directories depend
            upon each other, the scripts must be placed into a common
            directory and be named such that they get added in the correct
            order.

            Example 1: Run mmdebstrap with eatmydata

                --hook-dir=/usr/share/mmdebstrap/hooks/eatmydata

            Example 2: Setup chroot for installing a sub-essential
            busybox-based chroot

                --hook-dir=/usr/share/mmdebstrap/hooks/busybox

            Example 3: Automatically mount all directories referenced by
            "file://" mirrors into the chroot

                --hook-dir=/usr/share/mmdebstrap/hooks/file-mirror-automount

    --skip=stage[,stage,...]
            mmdebstrap tries hard to implement sensible defaults and will
            try to stop you before shooting yourself in the foot. This
            option is for when you are sure you know what you are doing and
            allows one to skip certain actions and safety checks. See
            section OPERATION for a list of possible arguments and their
            context. The option can be specified multiple times or you can
            separate multiple values by comma or whitespace.

    -q,--quiet, -s,--silent
            Do not write anything to standard error. If used together with
            --verbose or --debug, only the last option will take effect.

    -v,--verbose
            Instead of progress bars, write the dpkg and apt output directly
            to standard error. If used together with --quiet or --debug,
            only the last option will take effect.

    -d,--debug
            In addition to the output produced by --verbose, write detailed
            debugging information to standard error. Errors will print a
            backtrace. If used together with --quiet or --verbose, only the
            last option will take effect.

    --logfile=filename
            Instead of writing status information to standard error, write
            it into the file given by filename.


aborted: False
returncode: 2

Files in working directory:

--------------------
debug log System bootstrap a system tarball - 19 hours, 45 minutes ago 0 minutes
BETA