QEMU/KVMその後

Distroによったり,MacPortsやHomeBrewそれぞれで,QEMUやlibvirtのconfigureの仕方が違って,できることにかなりの差があります.

出来上がりとして,一番守備範囲が広いのは,Manjaro (aarch64)です.しかし,安定版じゃないみたいで,仮想マシンを作ってちゃんと動くのは,i386とx86_64だけで,Raspberry Pi 3をエミュレートする設定はできるんですが,動いてくれません.

Manjaro AMD64版(または,Arch Linux AMD64版)なら,いろいろできて安定と思われますが,第2 workstationにインストールするためには,既にインストールしてあるDebianかGentooを消すか引っ越すかして空きを作らないといけません.

一番安定して動いてくれるGentooでは,今のところx86_64の仮想マシンしか作れません.これは,なんかフラグかなんかで他のエミュレーターを増やせると思うので,調べてみます.

macOSの取り組みでは,MacPortではvirtqemudとvirtnetworkdができないので,仮想マシンが動きません(当社調べ).そこで,HomeBrewに乗り換え,virtqemud他,libvirtのmodularデーモンがひととおりできましたが,Virt-managerでマシンを作ることができませんでした.

で,このへんで燃え尽きてしまいました😥 現在手持ちのハードウェアで一番ハイスペックなMac miniでQEMUを動かしたかったのですが諦めます.

AMD64のGentooで,Raspberry Piのエミュレーションができないかくらいに縮小して取り組んでみます.

要UEFI firmware

なんだかわかりませんが,Manjaro (Arch Linux) で,Raspbery Pi OSのSDカードのイメージから起動するためには,UEFIのfirmwareが必要で,そのためには,OVMFとかが必要なようです.しかし,aarch64版はないようです😥

したがって,Raspberry Pi 4 model BのManjaroで動かす仮想マシンは,x86 PCのBIOS形式のブートしか使えない,ということのようです.

AMD64 Gentooでも,この情報をもとに,edk2-ovmfをインストールしてみましたが,RPi3の仮想マシンを設定しようとしても,UEFIは見つからないというエラーが出ます.

ただし,ものすごく遅い😥
設定不可能😓

Homebrewで苦戦中

長年,MacPortsでいろいろソフトをインストールしてきましたが,今回QEMUのインストールがうまく行かなかったので,この際,Homebrewに乗り換えることにしました.

インストールは,お手軽簡単なんですが,ソフトのインストールをはじめると,リンクが張れなかったというエラーが多発します.エラーが出ても,どんどん進行していくので,このままでいいのかと思ったらやっぱりだめでした.Virt-Managerを起動すると,あれがないこれがないというので,指示通りに,

brew link あれ
brew link これ

しますが,だめです.

筆者の/usr/localは,これまで,mysqlやGNU Octaveやその他思い出せませんがいろいろインストールしてきたので,Homebrewが期待しているようなきれいな場所ではないようです.

そこで,インストールスクリプトを改ざんして,最初は/opt/homebrewにしましたが,「そこはM1 Mac様の指定席だ」(意訳)としかられ,次に,/usr/beerにしましたが,「/usr/local以外のprefixだとあれはだめ,これもだめ」(〃)と叱られました.

お手軽簡単な仕組みは,普通の使い方をしようとしない人間には,非常に扱いにくいです.

しかたがないので,/usr/localの中身を消して,やり直すことにします.Octaveは今日全く使ってませんし,スタンドアロンのアプリもあるので消すことになんの問題もありません.いっぽう,MySQLは動いている可能性がありますが,それを消すことで影響が出たらまた考えるということにします.

しかし,継続的に使用したものは無し😥
mysqlは,お仕着せバイナリーだと思いますが,GNU Octaveに関しては,どのようにインストールしたのか思い出せません😓

libvirt: monolithic vs modular

libvirt(d)のドキュメントなどを少し読んでます.

もともとlibvirtdは,1つのデーモンで何でもこなすようになっていたようですが,最近では,機能別にモジュール化したデーモンを使う方向に移行しているそうです.

QEMUをhypervisorとするときの担当daemonは,virtqemudだということです.Gentoo(AMD64)の/usr/sbinを覗くと,

ls -l /usr/sbin/virt*
-rwxr-xr-x 1 root root 482520 Feb  7 09:09 /usr/sbin/virtinterfaced
-rwxr-xr-x 1 root root  81272 Feb  7 09:09 /usr/sbin/virtlockd
-rwxr-xr-x 1 root root  81080 Feb  7 09:09 /usr/sbin/virtlogd
-rwxr-xr-x 1 root root 482520 Feb  7 09:09 /usr/sbin/virtnetworkd
-rwxr-xr-x 1 root root 482520 Feb  7 09:09 /usr/sbin/virtnodedevd
-rwxr-xr-x 1 root root 482520 Feb  7 09:09 /usr/sbin/virtnwfilterd
-rwxr-xr-x 1 root root 486616 Feb  7 09:09 /usr/sbin/virtproxyd
-rwxr-xr-x 1 root root 482520 Feb  7 09:09 /usr/sbin/virtqemud
-rwxr-xr-x 1 root root 482520 Feb  7 09:09 /usr/sbin/virtsecretd
-rwxr-xr-x 1 root root 482520 Feb  7 09:09 /usr/sbin/virtstoraged

てな具合です.一方,macOSでは,

ls -l /opt/local/sbin/virt*
-rwxr-xr-x 1 root admin 79152 8 4 2020 /opt/local/sbin/virtlockd
-rwxr-xr-x 1 root admin 80424 8 4 2020 /opt/local/sbin/virtlogd
-rwxr-xr-x 1 root admin 439400 8 4 2020 /opt/local/sbin/virtproxyd
-rwxr-xr-x 1 root admin 434832 8 4 2020 /opt/local/sbin/virtsecretd
-rwxr-xr-x 1 root admin 434832 8 4 2020 /opt/local/sbin/virtstoraged
-rwxr-xr-x 1 root admin 434832 8 4 2020 /opt/local/sbin/virtvboxd

です.virtqemudやvirtnetworkdなどがありません.当然,同時にbuildされた,monolithicなlibvirtdにも,virtqemudなどの機能は含まれていないと想像できます.

macOSで,KVMが機能しないのは解りますが,QEMUも動かないんでしょうか.かつて,Qという,QEMUのアプリがありましたからそうではないと思います.が,MacPortsの中身がさっぱり解らないので,お手上げです.

VirtualBoxは削除

ちなみに,VirtualBoxで動くGentooは,あいかわらずSegfault乱発で,まともに動いてくれないので,削除しました.

MacでQEMUは難航

MacPortsもなんにも知らないで使ってきたのですが,GentooのUSEflagに似たような,Variantというのがあるのを知りました.

MacPortsでは,理由は知りませんが,Apple謹製のXQuartzに変えて,MacPortsによるXorgの移植品を使う方向に切り替えつつあるようです(当社調べ).

で,どうも,Virt-Managerに関連したソフトの一つが,もはやXQuartzをサポートせず,Xorgのみに対応しているようです.そこで,

/opt/local/etc/macports/variants.conf

に,なんやかんや書くようなのですが,どうしたわけか,記憶と実態とが違っているので,中身を掲載するのはやめます(あとで,はっきり理由がわかったら掲載します).

で,なんやかんや書いて,virt-managerまでbuildできて動くのですが,libvirtdを動かしているにもかかわらず,virt-managerで接続しようとしても,繋がりません.

macOSで,virsh uriをroot権限で実行すると,

virsh uri
error: failed to connect to the hypervisor
error: internal error: Failed to create vbox driver object.

という具合にエラーになります.Gentooの実マシンで同様にvirsh uriを実行すると,

virsh uri
qemu:///system

と,教科書通りに出ます.

virsh -Vは,macOSでは,

virsh -V
Virsh command line tool of libvirt 6.6.0
See web site at https://libvirt.org/

Compiled with support for:
Hypervisors: VMware VirtualBox ESX Test
Networking: Remote
Storage: Dir
Miscellaneous: Daemon Secrets Debug Readline

となり,一方Gentooの実マシンは,

virsh -V
Virsh command line tool of libvirt 6.8.0
See web site at https://libvirt.org/

Compiled with support for:
Hypervisors: QEMU/KVM VMware ESX Test
Networking: Remote Network Bridging Interface udev Nwfilter VirtualPort
Storage: Dir Filesystem SCSI
Miscellaneous: Daemon Nodedev Secrets Debug Readline

大きな違いは,MacPort (macOS)のほうは,HypervisorsにQEMUが含まれていないことでしょう.

これが,virsh uriでエラーになり,virt-managerが接続できない原因でしょう.

さて,どうしていいか,さっぱりわからない😥

いろいろ扱いにくいんでしょうね.知らんけど.

Web cam買いました

USB接続でパソコンにつないでweb会議するのに使うやつです😓

大昔に,Kensingtonのものを2種類くらい買ってずいぶん長く使っていました.その頃の印象が強いので,USB web camはそんなにいいもんじゃないように思っていました.

コロナ禍でも,web会議に参加することはそんなにないのですが,Macbookで2度ほど,あと1度はiPhoneを使いました.

Macbookの内蔵カメラは解像度が低くいのは残念ですが,使用するのは楽です.iPhoneも手軽ではありますが,参加者の顔が小さくしか見えないは残念です.モニターをつなぐ手もありますが,使用中はiPhone本体もかなり熱を持つので,それなら,パソコン(というかMac mini)にカメラをつないだ方が良かろうと言うことで,久しぶりにUSB web camを買うことにしたわけです.

時代が時代なので,選択肢が多くて決断するまで悩みましたが,値段とブランドでLogcool (Logitech)の実売価格3,000円の,C505にしました.

SVGAとかのKensingtonのものと比較すると画質は雲泥の差ですね.コンパクトで,モニターの上部に簡単にセットできますし.

モニターの下に置いてもテストしましたが,けっこう目線を下げ続けるのはつらいので上で行くことにしました.

Logicool C505 USB web cam
今は,カメラ類は扱ってないようです.