私が使用しているホストは、リカバリシステムとしてDebian 8.10(カーネル4.9.85)を提供します。私は過去にこれを使ってUbuntuを起動しました。debootstrap
ここから。
私はインストールなどのいくつかの準備手順を使用しています。だから私が使うURL apt-cacher-ng
(localhost:3142
http://localhost:3142/us.archive.ubuntu.com/ubuntu/)そしてubuntu-archive-keyring
。
呼び出しdebootstrap
は次のとおりです。
LANG=C debootstrap --keep-debootstrap-dir --verbose --include=ubuntu-server,bash-completion,sudo,lshw,tmux,unzip,pciutils,usbutils,openssh-server,unattended-upgrades,linux-image-generic,cron --variant=minbase --arch=$(dpkg --print-architecture) bionic /target http://localhost:3142/us.archive.ubuntu.com/ubuntu/
--verbose
(何か間違ったことがあるかと思って追加しましたが、役に立ちませんでした。)
今すぐ実行するときの奇妙なことは、debootstrap
この新しいバージョンでは最終的にステップだけが表示されることです。検索、確認するそして抜粋(パッケージサブセットの場合)しかし、設定しているそのパッケージに関する情報はありません。
それで「ええ、やったのでxenial
またやってみよう」と中に言ったら、同じルーチンが出てきました。
+ debootstrap --keep-debootstrap-dir --verbose --include=ubuntu-server,bash-completion,sudo,lshw,tmux,unzip,pciutils,usbutils,openssh-server,unattended-upgrades,linux-image-generic,cron --variant=minbase --arch=
amd64 xenial /target http://localhost:3142/us.archive.ubuntu.com/ubuntu/
I: Retrieving InRelease
I: Checking Release signature
I: Valid Release signature (key id 790BC7277767219C42C86F933B4FE6ACC0B21F32)
I: Retrieving Packages
I: Validating Packages
I: Resolving dependencies of required packages...
I: Resolving dependencies of base packages...
I: Found additional base dependencies: acpid apport apt-utils at bcache-tools btrfs-tools busybox-initramfs byobu ca-certificates cloud-guest-utils cloud-initramfs-copymods cloud-initramfs-dyn-netconf cpio crda
cryptsetup cryptsetup-bin curl dh-python distro-info-data dmeventd dmsetup ethtool fonts-ubuntu-font-family-console gawk gcc-5-base gettext-base gir1.2-glib-2.0 git git-man gnupg gpgv grub-legacy-ec2 ifenslave i
fupdown initramfs-tools initramfs-tools-bin initramfs-tools-core iproute2 iso-codes iw klibc-utils kmod libapt-inst2.0 libapt-pkg5.0 libasn1-8-heimdal libasprintf0v5 libbsd0 libcurl3-gnutls libdbus-1-3 libdbus-g
lib-1-2 libdevmapper-event1.02.1 libdrm2 libdumbnet1 libedit2 liberror-perl libevent-2.0-5 libexpat1 libffi6 libfuse2 libgdbm3 libgirepository-1.0-1 libglib2.0-0 libgmp10 libgnutls30 libgpm2 libgssapi-krb5-2 lib
gssapi3-heimdal libhcrypto4-heimdal libheimbase1-heimdal libheimntlm0-heimdal libhogweed4 libhx509-5-heimdal libicu55 libidn11 libk5crypto3 libkeyutils1 libklibc libkrb5-26-heimdal libkrb5-3 libkrb5support0 libl
dap-2.4-2 liblvm2app2.2 liblvm2cmd2.02 liblz4-1 liblzo2-2 libmnl0 libmpdec2 libmpfr4 libmspack0 libnettle6 libnewt0.52 libnl-3-200 libnl-genl-3-200 libp11-kit0 libpci3 libperl5.22 libplymouth4 libpng12-0 libpopt
0 libpython-stdlib libpython2.7-minimal libpython2.7-stdlib libpython3-stdlib libpython3.5-minimal libpython3.5-stdlib libreadline5 libreadline6 libroken18-heimdal librtmp1 libsasl2-2 libsasl2-modules-db libsigs
egv2 libslang2 libsqlite3-0 libssl1.0.0 libstdc++6 libtasn1-6 libusb-0.1-4 libusb-1.0-0 libutempter0 libwind0-heimdal libwrap0 linux-base linux-firmware linux-image-4.4.0-21-generic linux-image-extra-4.4.0-21-ge
neric lsb-release lvm2 mdadm mime-support open-iscsi open-vm-tools openssh-client openssh-sftp-server openssl overlayroot patch perl perl-modules-5.22 plymouth python python-apt-common python-minimal python2.7 p
ython2.7-minimal python3 python3-apport python3-apt python3-chardet python3-dbus python3-debian python3-gi python3-minimal python3-newt python3-pkg-resources python3-problem-report python3-pycurl python3-six pyt
hon3-software-properties python3.5 python3.5-minimal readline-common screen software-properties-common sosreport ubuntu-cloudimage-keyring ubuntu-keyring ucf udev update-notifier-common vim vim-common vim-runtim
e vlan wireless-regdb xfsprogs xz-utils
I: Checking component main on http://localhost:3142/us.archive.ubuntu.com/ubuntu...
I: Retrieving acpid 1:2.0.26-1ubuntu2
I: Validating acpid 1:2.0.26-1ubuntu2
[...]
I: Chosen extractor for .deb packages: dpkg-deb
I: Extracting adduser...
I: Extracting base-files...
I: Extracting base-passwd...
[...]
I: Extracting zlib1g...
奇妙なことに、過去にはセットアップステップがスムーズに行われていました。ところで、今は静かにスキップしたんですか? !以前のdebootstrap
バージョンはBionic Beaver(Ubuntu 18.04)を理解していないため、機能しません。
問題になる可能性がある2つがあると思います。
- カーネルバージョンの違い:Ubuntu 18.04では4.15、Debian 8.10では4.9.85。
- libcバージョンの違い:2.27-3ubuntu1と2.19-18+deb8u10。
...しかし、どちらの場合も同じ違いがあると予想しますdebootstrap
。また、xenial
(Ubuntu 16.04)の場合でも、同じ違いを起すべきではありません.ただし、エラーは表示されず、代わりに重要な設定手順をスキップしてchroot
with/target
コマンドを入力してみてください/bin/bash
。
# LANG=en_US.UTF-8 chroot /target /bin/bash
groups: cannot find name for group ID 0
I have no name!@rescue:/#
少し掘り下げたが、何も見つかりませんでした/etc/passwd
。しばらくお待ちください。/dev
、/proc
に/sys
バインドインストールされます/target
。
そのDebianリカバリシステムでUbuntuを正常に起動するには、この問題をどのように解決する必要がありますか?スキーマがホストとターゲットに一致するのにインストールステップの実行を妨げる要因は何ですか?
気づく:最新のカーネルで起動できません。あるいは、むしろこのようなことを達成する唯一の方法は、まずある種の地域構造システムを設置することです。
私が使っているソフトウェア
$ debootstrap --version
debootstrap 1.0.95ubuntu1
$ uname -a
Linux rescue 4.9.85 #2 SMP Thu Mar 1 08:06:18 CET 2018 x86_64 GNU/Linux
私もそれをインストールしましたubuntu-archive-keyring
。
私はまた何を試しましたか?
私も--foreign
に渡そうとしましたdebootstrap
。理由/debootstrap/debootstrap
ただし、後で使用できる実行可能ファイルも残しておく必要があります--second-stage
。ただし、現在見ているのと同じ動作を示します。いいえコマンド--foreign
ライン切り替え後、/debootstrap/debootstrap
ターゲットファイルシステムからのブートは完了しません。
また、以下を使用してインストールを試みましたdebootstrap
。次に、に接続します。jessie-backports
apt-get install -t jessie-backports debootstrap
debootstrap 1.0.89~bpo8+1
/usr/share/debootstrap/scripts/bionic
/usr/share/debootstrap/scripts/gutsy
答え1
わかりました。呼び出しはdebootstrap
終了コード 1 を返し、失敗を示します。複数のコマンドをリンクしてサブシェルを使用する方法のため、これを見逃しました。
debootstrap
その事実を見つけた後、私が経験している問題が何であるかを調べなければなりませんでした。これは(対象内部)の観点からは明らかではありませんでしたが、/debootstrap/debootstrap.log
確かに遅れて知りました。だから反省しなければなりませんdebootstrap
。これを行うには、(トレースをオンにした状態で)シェルスクリプトを明示的に呼び出すと、実際には内部的に/usr/sbin/debootstrap
(ターゲットの内部で)出力を見ることができます。私の場合、次のトレース項目と出力に問題が表示されます。/bin/sh -x
/debootstrap/debootstrap.log
mknod
+ mknod -m 666 /target/dev/null c 1 3
mknod: '/target/dev/null': File exists
この問題は、私がターゲットをインストールし/dev
て/proc
入ったときに/sys
発生しました。前進(何一度働いた過去に! )。
新しいdebootstrap
バージョンでは無条件に失敗するようです。対応する関数呼び出しはmknod
から来ますsetup_devices_simple
。/usr/share/debootstrap/functions
スクリプトを(およびそれ以降のバージョン)と比較してdebootstrap
確認した1つの注目すべき変更は、関数呼び出しが関数から(スクリプトの)関数に移動されることです。バリアントを作成したり、「外部」コアで実行しない限り、この関数は呼び出されるため、以前よりも早く呼び出されます。1.0.59
1.0.89~bpo8+1
setup_devices
second_stage_install
first_stage_install
gutsy
setup_devices_simple
fakechroot
mknod
以前に失敗しなかった理由は、以前はデバイスを.tgzファイルとして保存し、その場所で解凍していましたが、今はdebootstrap
直接使用しているようです。mkdnod