MochiuWiki : SUSE, EC, PCB
案内
メインページ
最近の更新
おまかせ表示
MediaWiki についてのヘルプ
ツール
リンク元
関連ページの更新状況
特別ページ
ページ情報
We ask for
Donations
検索
個人用ツール
ログイン
Toggle dark mode
名前空間
ページ
議論
表示
閲覧
ソースを閲覧
履歴を表示
Linuxコマンド - chrootのソースを表示
提供: MochiuWiki : SUSE, EC, PCB
←
Linuxコマンド - chroot
あなたには「このページの編集」を行う権限がありません。理由は以下の通りです:
この操作は、次のグループのいずれかに属する利用者のみが実行できます:
管理者
、new-group。
このページのソースの閲覧やコピーができます。
== 概要 == <br><br> == QEMU-User-Staticのインストール == QEMU-User-Staticは、クロスアーキテクチャの開発者にとって重要なツールである。<br> これにより、ユーザはchroot環境を作成して、クロスコンパイルされたプログラムを実行することができる。<br> <br> 例えば、ユーザはシステムレベルのエミュレーションのオーバーヘッド無しに、AArch64の実行ファイルを実行することができる。<br> <br> ==== パッケージ管理システムからインストール ==== sudo zypper install qemu-arm qemu-linux-user qemu-uefi-aarch64 <br> ==== ソースコードからインストール ==== ここでは、ARMおよびAArch64向けのQEMU-User-Staticのインストール手順を示す。<br> なお、他のアーキテクチャにおいても、同様の手順でインストールすることができる。<br> <br> QEMUのビルドに必要なライブラリをインストールする。<br> sudo zypper install flex bison automake gcc gcc-c++ make glibc glibc-utils glibc-devel-static glib2-devel glibc-utils ncurses-devel libxml2-devel \ glibc-devel-static glibc-devel-static-32bit glib2-devel glib2-devel-static glib2-devel-32bit \ zlib-devel zlib-devel-32bit zlib-devel-static zlib-devel-static-32bit libpcap-devel-static readline-devel-static xfsprogs-devel \ pcre-devel-static pcre2-devel pcre2-devel-static gmp-devel perl-Text-Markdown sysprof-capture-devel-static # 以下の依存関係のライブラリは不要の可能性がある gtk3-devel libgnutls-devel libnettle-devel libseccomp-devel liburing-devel libgbm-devel glusterfs-devel \ libjpeg8-devel libpng16-devel libpulse-devel alsa-devel libjack-devel spice-protocol-devel libspice-server-devel \ libxkbcommon-devel libxkbcommon-x11-devel libcap-devel libcap-ng-devel libpcap-devel libcurl-devel libudev-devel virglrenderer-devel \ libiscsi-devel libzstd-devel libnfs-devel libvdeplug-devel brlapi-devel libSDL2-devel libSDL2_image-devel librados-devel \ lzfse-devel libmpath0 libcacard-devel lzo-devel snappy-devel libgcrypt-devel libu2f-server-devel libu2f-host-devel \ usbredir-devel libusb-1_0-devel libpmem-devel libkeyutils1 keyutils-devel libselinux-devel fuse-devel fuse3-devel libbpf-devel \ libbd_swap-devel libcapstone-devel libslirp-devel libfdt-devel sphinx libsphinxclient-devel numad libnuma1 numactl libnuma-devel \ librbd-devel rdma-core-devel libnet-devel libfvde-devel libdmmp-devel multipath-tools-devel libssh-devel libssh2-devel \ rpcbind rpcgen readline-devel libyajl-devel libpciaccess-devel device-mapper-devel libtirpc-devel libnl3-devel libpixman-1-0-devel \ libxslt-devel python3-docutils capstone libcapstone4 libcapstone-devel python3-capstone <br> QEMUのソースコードをダウンロードする。<br> * QEMUの公式Webサイトから、ソースコードをダウンロードする場合 *: [https://www.qemu.org/download/ QEMUの公式Webサイト]にアクセスして、ソースコードをダウンロードする。 *: ダウンロードしたファイルを解凍する。 *: <code>tar xf qemu-<バージョン>.tar.xz</code> *: <code>cd qemu-<バージョン></code> *: <br> * Gitからソースコードをダウンロードする場合 *: <code>git clone https://gitlab.com/qemu-project/qemu.git</code> *: <code>cd qemu</code> *: <code>git submodule update --init --recursive</code> <br> QEMUをQEMU-User-Staticとして、ビルドおよびインストールする。<br> mkdir build && cd build <br> <code>--disable-system</code>オプションを指定する時、softmmuターゲットが無効になる。<br> ただし、softmmuターゲットがいくつかの共有ライブラリに依存していることは知られている。<br> <code>--static</code>オプションを指定した場合、これらのsoftmmuターゲットはリンクエラーを引き起こす。<br> ../configure --prefix=<QEMU-User-Staticのインストールディレクトリ> \ --enable-linux-user --static \ --disable-system --disable-brlapi --disable-cap-ng --disable-capstone \ --disable-curl --disable-curses --disable-docs --disable-gcrypt --disable-gnutls \ --disable-gtk --disable-guest-agent --disable-guest-agent-msi --disable-libiscsi \ --disable-libnfs --disable-mpath --disable-nettle --disable-opengl --disable-pie \ --disable-sdl --disable-spice --disable-tools --disable-vte --disable-werror \ --disable-debug-info --disable-glusterfs \ --disable-blobs \ # QEMU 7.x以前の場合 (QEMU 8.0以降は不要) --extra-ldflags=-latomic \ --target-list=aarch64-linux-user,aarch64_be-linux-user,arm-linux-user,armeb-linux-user # ARM, AArch64のみをインストールする場合 # <u>全てのアーキテクチャをインストールする場合は、当オプションは付加しない</u> # 以下のオプションは任意である --cross-prefix=$(info)- \ --host-cc=clang \ # Clangを使用してビルドする場合 --host=$(clang --print-target-triple) \ # Clangを使用してビルドする場合 --build=$(TARGETPLATFORM= TARGETPAIR= clang --print-target-triple) \ # Clangを使用してビルドする場合 --cc=clang \ # Clangを使用してビルドする場合 --disable-system # softmmuターゲットを無効にする make -j $(nproc) または ninja -C . -j $(nproc) make install または ninja -C . install <br> QEMU-User-Staticの設定スクリプトをコピーする。<br> mkdir /<QEMU-User-Staticのインストールディレクトリ>/sbin mkdir -p /<QEMU-User-Staticのインストールディレクトリ>/lib/binfmt.d cp /<QEMUのソースコードがあるディレクトリ>/scripts/qemu-binfmt-conf.sh /<QEMU-User-Staticのインストールディレクトリ>/sbin <br> QEMU-User-Staticの設定スクリプトを、以下に示すように編集する。<br> <u>この設定は、変数<code>QEMU_PATH</code>の設定を除いて、不要の可能性が高い。</u><br> vi /<QEMU-User-Staticのインストールディレクトリ>/sbin/qemu-binfmt-conf.sh <br> <syntaxhighlight lang="sh"> # /<QEMU-User-Staticのインストールディレクトリ>/sbin/qemu-binfmt-conf.shファイル # 344行目あたり ## 編集前 QEMU_PATH=/usr/local/bin # 編集後 QEMU_PATH=/<QEMU-User-Staticのインストールディレクトリ>/bin </syntaxhighlight> <br> 各アーキテクチャのバイナリフォーマットファイルを生成する。<br> sudo /<Qemu-User-Staticのインストールディレクトリ>/sbin/qemu-binfmt-conf.sh \ --systemd ALL \ --persistent yes \ --preserve-argv0 yes \ --exportdir /<Qemu-User-Staticのインストールディレクトリ>/lib/binfmt.d/ <br> <del>次に、QEMU-User-Staticに必要なBinfmtを、[https://pkgs.org/download/qemu-linux-user pkgs.orgのWebサイト]からダウンロードする。</del><br> <del>Binfmtは、QEMU-User-Staticのバージョンと異なっていても問題無い。</del><br> <del>ダウンロードしたファイルを展開する。</del><br> <del>rpm2cpio qemu-linux-user-<バージョン>.x86_64.rpm | cpio -id</del> <br> <del>展開したディレクトリに移動して、ARMおよびAArch64のBinfmtファイルを/<QEMU-User-Staticのインストールディレクトリ>/binディレクトリにコピーする。</del><br> <del>cd qemu-linux-user-<バージョン>.x86_64/usr/bin</del> <del>cp qemu-binfmt qemu-arm-binfmt qemu-aarch64-binfmt /<QEMU-User-Staticのインストールディレクトリ>/bin</del> <br> 必要であれば、QEMU-User-Staticのパスを~/.profileファイル等に環境変数<code>PATH</code>に追記する。<br> vi ~/.profile <br> <syntaxhighlight lang="sh"> # ~/.profileファイル等 export PATH="/<QEMU-User-Staticのインストールディレクトリ>/bin:/<QEMU-User-Staticのインストールディレクトリ>/sbin:$PATH" </syntaxhighlight> <br><br> == 例 : openSUSE Tumbleweed (PinePhone) == x86またはx64のPCを使用している場合、ARMバイナリのQEMU変換を設定する。<br> もし、ARM PCを使用している場合は、この操作は行わない。<br> # パッケージ管理システムからインストールしている場合 sudo /usr/sbin/qemu-binfmt-conf.sh # ソースコードからインストールしている場合 sudo /<QEMU-User-Staticのインストールディレクトリ>/sbin/qemu-binfmt-conf.sh \ --persistent yes \ --preserve-argv0 yes \ --exportdir /<QEMU-User-Staticのインストールディレクトリ>/lib/binfmt.d/ <br> イメージファイルのルートファイルシステムにおいて、オフセットを確認する。<br> <u>この時、raw2拡張子の開始位置と1セクタのサイズを乗算して、ルートファイルシステムのオフセットを求める。</u><br> sudo fdisk -l <openSUSE Tumbleweedのイメージファイル名>.raw <br> openSUSE Tumbleweedのイメージファイルをマウントする。<br> 以下の例では、/mntディレクトリにマウントしている。<br> sudo mount -t btrfs -o loop,offset=<ルートファイルシステムのオフセット 例: raw2拡張子の開始位置と1セクタのサイズを乗算した値> <openSUSE Tumbleweedのイメージファイル名>.raw /mnt sudo mount --bind /sys /mnt/sys && sudo mount --make-rslave /mnt/sys && \ sudo mount --bind /dev /mnt/dev && sudo mount --make-rslave /mnt/dev && \ sudo mount --bind /proc /mnt/proc && sudo mount --make-rslave /mnt/proc && \ sudo mount --bind /dev/pts /mnt/dev/pts # または sudo mount --rbind /sys /mnt/sys && sudo mount --make-rslave /mnt/sys && \ sudo mount --rbind /dev /mnt/dev && sudo mount --make-rslave /mnt/dev && \ sudo mount --rbind /proc /mnt/proc && sudo mount --make-rslave /mnt/proc && \ sudo mount --rbind /dev/pts /mnt/dev/pts sudo cp /run/netconfig/resolv.conf /mnt/etc/ <br> AArch64命令セットをエミュレートするために必要なファイルを、openSUSE Tumbleweed (PinePhone)のマウント先ディレクトリにコピーする。<br> # パッケージ管理システムからインストールしている場合 sudo cp /usr/bin/qemu-aarch64-binfmt /usr/bin/qemu-aarch64 /mnt/usr/bin/ # ソースコードからインストールしている場合 sudo cp /<QEMU-User-Staticのインストールディレクトリ>/bin/qemu-aarch64 /mnt/usr/bin/ <br> openSUSE Tumbleweed (PinePhone)の環境にchrootする。<br> sudo chroot /mnt qemu-aarch64 /bin/bash <br> 以下の例のようなコマンドを実行して、正常に動作するかどうかを確認する。<br> (root権限で実行されるため、<code>sudo</code>は不要)<br> zypper ref zypper dup zypper in nano <br> openSUSE Tumbleweed (PinePhone)の環境を終了する場合は、ターミナルから<code>exit</code>コマンドを実行した後、<br> openSUSE Tumbleweed (PinePhone)のイメージファイルをアンマウントする。<br> sudo umount -dfl /mnt/sys && \ sudo umount -dfl /mnt/dev/pts && \ sudo umount -dfl /mnt/dev && \ sudo umount -dfl /mnt/proc && \ sudo umount -dfl /mnt <br><br> == 例 : Manjaro ARM, Mobian (PinePhone) == x86またはx64のPCを使用している場合、ARMバイナリのQEMU変換を設定する。<br> もし、ARM PCを使用している場合は、この操作は行わない。<br> # パッケージ管理システムからインストールしている場合 sudo /usr/sbin/qemu-binfmt-conf.sh # ソースコードからインストールしている場合 sudo /<QEMU-User-Staticのインストールディレクトリ>/sbin/qemu-binfmt-conf.sh \ --persistent yes \ --preserve-argv0 yes \ --exportdir /<QEMU-User-Staticのインストールディレクトリ>/lib/binfmt.d/ <br> イメージファイルのルートファイルシステムにおいて、オフセットを確認する。<br> <u>この時、img拡張子の開始位置と1セクタのサイズを乗算して、ルートファイルシステムのオフセットを求める。</u><br> sudo fdisk -l <Manjaro ARM または Mobianのイメージファイル名>.img <br> Manjaro ARM、 または、Mobianのイメージファイルをマウントする。<br> 以下の例では、/mntディレクトリにマウントしている。<br> sudo mount -t ext4 -o loop,offset=<ルートファイルシステムのオフセット 例: img拡張子の開始位置と1セクタのサイズを乗算した値> <Manjaro ARM または Mobianのイメージファイル名>.img /mnt sudo mount --bind /sys /mnt/sys && sudo mount --make-rslave /mnt/sys && \ sudo mount --bind /dev /mnt/dev && sudo mount --make-rslave /mnt/dev && \ sudo mount --bind /proc /mnt/proc && sudo mount --make-rslave /mnt/proc && \ sudo mount --bind /dev/pts /mnt/dev/pts # または sudo mount --rbind /sys /mnt/sys && sudo mount --make-rslave /mnt/sys && \ sudo mount --rbind /dev /mnt/dev && sudo mount --make-rslave /mnt/dev && \ sudo mount --rbind /proc /mnt/proc && sudo mount --make-rslave /mnt/proc && \ sudo mount --rbind /dev/pts /mnt/dev/pts sudo cp /run/netconfig/resolv.conf /mnt/etc/ <br> AArch64命令セットをエミュレートするために必要なファイルを、Manjaro ARM、または、Mobian(PinePhone)のマウント先ディレクトリにコピーする。<br> # パッケージ管理システムからインストールしている場合 sudo cp /usr/bin/qemu-aarch64-binfmt /usr/bin/qemu-aarch64 /mnt/usr/bin/ # ソースコードからインストールしている場合 sudo cp /<QEMU-User-Staticのインストールディレクトリ>/bin/qemu-aarch64 /mnt/usr/bin/ <br> Manjaro ARM、または、Mobian (PinePhone)の環境にchrootする。<br> sudo chroot /mnt qemu-aarch64 /bin/bash <br> 以下の例のようなコマンドを実行して、正常に動作するかどうかを確認する。<br> (root権限で実行されるため、<code>sudo</code>は不要)<br> # Manjaro ARM pcman -Syyu pacman -S --needed nano # Mobian apt update apt upgrade <br> <u>※注意</u><br> <u>Manjaro ARMのシステムをアップデートする時、以下に示すようなエラーが発生する場合がある。</u><br> error: <インストールするパッケージ名>: signature from "Arch Linux ARM Build System <builder@archlinuxarm.org>" is unknown trust <br> <u>この時、/etc/pacman.confファイルを以下に示すように編集する。</u><br> sudo vi /etc/pacman.conf <br> <syntaxhighlight lang="ini"> # 42行目あたり #SigLevel = Required DatabaseOptional # コメントアウトする SigLevel = Optional TrustAll # 追記する </syntaxhighlight> <br> Manjaro ARM、または、Mobian (PinePhone)の環境を終了する場合は、ターミナルから<code>exit</code>コマンドを実行した後、<br> Manjaro ARM、または、Mobian (PinePhone)のイメージファイルをアンマウントする。<br> sudo umount -dfl /mnt/sys && \ sudo umount -dfl /mnt/dev/pts && \ sudo umount -dfl /mnt/dev && \ sudo umount -dfl /mnt/proc && \ sudo umount -dfl /mnt <br><br> == 例 : Raspbian OS (AArch64) == x86またはx64のPCを使用している場合、ARMバイナリのQEMU変換を設定する。<br> もし、ARM PCを使用している場合は、この操作は行わない。<br> # パッケージ管理システムからインストールしている場合 sudo /usr/sbin/qemu-binfmt-conf.sh # ソースコードからインストールしている場合 sudo /<QEMU-User-Staticのインストールディレクトリ>/sbin/qemu-binfmt-conf.sh \ --persistent yes --preserve-argv0 yes \ --exportdir /<QEMU-User-Staticのインストールディレクトリ>/lib/binfmt.d/ <br> イメージファイルのルートファイルシステムにおいて、オフセットを確認する。<br> <u>この時、img3拡張子の開始位置と1セクタのサイズを乗算して、ルートファイルシステムのオフセットを求める。</u><br> sudo fdisk -l <Raspbian OS (AArch64)のイメージファイル名>.img <br> Raspbian OS (AArch64)のイメージファイルをマウントする。<br> 以下の例では、/mntディレクトリにマウントしている。<br> sudo mount -t ext4 -o loop,offset=<ルートファイルシステムのオフセット 例: img3拡張子の開始位置と1セクタのサイズを乗算した値> <Raspbian OS (AArch64)のイメージファイル名>.raw /mnt <br> AArch64命令セットを動作させるために必要なライブラリを、Raspbian OS (AArch64)のマウント先ディレクトリにコピーする。<br> # パッケージ管理システムからインストールしている場合 sudo cp /usr/bin/qemu-aarch64-binfmt /usr/bin/qemu-aarch64 /mnt/bin/ # ソースコードからインストールしている場合 sudo cp /<QEMU-User-Staticのインストールディレクトリ>/bin/qemu-aarch64 /mnt/usr/bin/ <br> chrootコマンドを実行して、Raspbian OS (AArch64)を起動する。<br> sudo chroot /mnt qemu-aarch64 /bin/bash <br> 終了する場合は、Raspbian OS (AArch64)のイメージファイルをアンマウントする。<br> sudo umount -fl /mnt <br><br> __FORCETOC__ [[カテゴリ:RHEL]][[カテゴリ:SUSE]][[カテゴリ:Raspberry_Pi]][[カテゴリ:PinePhone]]
Linuxコマンド - chroot
に戻る。
案内
メインページ
最近の更新
おまかせ表示
MediaWiki についてのヘルプ
ツール
リンク元
関連ページの更新状況
特別ページ
ページ情報
We ask for
Donations
Collapse