ユースケース: Ubuntu 18.04 上に,すばやく,ARM 版 Rasbian (buster) の隔離された開発環境を作りたい.
【目次】
【サイト内の関連ページ】
Ubuntu で OS のシステム更新を行うときは, 次のコマンドを実行.
Ubuntu のインストールは別ページ »で説明
sudo apt -y update sudo apt -yV upgrade sudo /sbin/shutdown -r now
sudo apt -y update sudo apt -y install qemu-user-static debootstrap schroot
※ armhf 版 Debian の環境を作成したいときは, 別ページの説明を見てください
ここでの設定
終了まで,しばらく待つ
sudo rm -rf /home/raspbian sudo mkdir /home/raspbian sudo qemu-debootstrap --foreign --arch armel --variant buildd --include=ca-certificates,apt,wget,sudo,vim-tiny,debootstrap buster /home/raspbian https://archive.raspbian.org/raspbian
sudo chroot /home/raspbian uname -m exit
ここでは,nano のインストール, C プログラムの編集とビルドと実行を行ってみる.
sudo chroot /home/raspbian uname -m
apt update apt upgrade apt install nano
#include<stdio.h> int main() { printf("Hello,World!\n"); printf("sizeof(size_t)=%ld\n", sizeof(size_t)); return 0; }
cd /tmp gcc -o a.out hello.c ./a.out
exit
schroot を設定し,一般ユーザでも chroot が実行できるようにする
「directory=/home/raspbian」のところは,実際に作成したディレクトリに書き換えること
「kaneko」のところは,使用させたいユーザのユーザ名に書き換えること(複数のときは,カンマで区切る)
[raspbian] description=Debian GNU/Linux 10 (Buster) type=directory directory=/home/raspbian root-users=kaneko users=kaneko
schroot -c raspbian -p bash uname -m exit
schroot -c raspbian -p bash -u root uname -m exit
これは,SSHによるリモートログインの受付のために用いるユーザである.
仮想マシンのために使用するディレクトリとは別物
sudo adduser --uid 1234 --home /home/ai ai
※ やり直すときは「sudo deluser ai」を実行して,アカウントを削除してからやり直す.
これは,隔離された環境(chroot 環境)の中で,sudo を実行したいときなどのため,隔離された環境(chroot 環境)の中でアカウント(ユーザ名,パスワード)を追加する.
※ 上で設定したパスワードと同じパスワードにする必要はない.ユーザID,ホームディレクトリ,ユーザ名は同じにすること.
sudo chroot /home/raspbian rm -rf /home/ai deluser ai adduser --uid 1234 --ingroup sudo --home /home/ai ai exit
これは,隔離された環境(chroot 環境)の中で,sudo を実行したいときのため.(必要がなければ,この操作は省略すること).
/home/raspbian/etc/sudoers に「Defaults visiblepw」を書き加える.
権限を変えておく
sudo chmod 444 /home/raspbian/etc/sudoers sudo chmod 444 /home/raspbian/etc/sudoers.d/*
ssh を使ってのリモートログインを受け付けたい. ssh の定めにより,の所有者を root に,権限を「755」に設定する.
sudo chown root:root /home sudo chmod 755 /home sudo chown root:root /home/raspbian sudo chmod 755 /home/raspbian sudo chown root:root /home/raspbian/home sudo chmod 755 /home/raspbian/home sudo chown root:root /home/raspbian/home/ai sudo chmod 755 /home/raspbian/home/ai
SSH によるリモートログイン時に chroot が実行されるように,/etc/ssh/sshd_config に次の記述を追加
「ChrootDirectory=/home/raspbian」の「/home/raspbian」のところは,実際に作成したディレクトリに書き換えること
Match User ai X11Forwarding yes AllowTcpForwarding yes ChrootDirectory /home/raspbian
sudo service sshd reload
ssh ai@localhost
※ エラーメッセージが出てログインできない場合には,/etc/ssh/sshd_config の設定,そして,「ディレクトリの権限の設定」を確認する