Skip to content

Latest commit

 

History

History
133 lines (99 loc) · 3.84 KB

README.md

File metadata and controls

133 lines (99 loc) · 3.84 KB

gom (gokrazy-machine)

A lightweight virtual/emulated machine based on qemu, to run and develop for gokrazy.

It supports all major Linux distributions and macOS (both intel and apple silicon (M1,M2,..)) >= 12.x.

pre-install requirements

A hard requirement for this to work is to install qemu >= 7.1.0.

On macOS this can be done directly with:

brew install qemu

On Linux you might need to compile and install qemu with:

curl -SLO https://download.qemu.org/qemu-7.1.0.tar.xz
tar -xf qemu-7.1.0.tar.xz
cd qemu-7.1.0
./configure
make -j $(nproc)
sudo make install

install

go install github.com/damdo/gokrazy-machine/cmd/gom

Check version

gom version

play

The main command is

gom play --full /tmp/disk.img

The gorkazy web UI will be available at a certain address and port depending on how you configured networking.

By default it will be available at http://locahost:PORT, where the port is a randomly assigned to achieve host to guest mapping over NAT.

The NATTED port can be found in the log output of gom, at the top, where the qemu Args are reported before the machine is started, in the -netdev argument.

e.g. if you see: -netdev user,id=net0,hostfwd=tcp::59681-:80,hostfwd=tcp::59682-:443,hostfwd=tcp::59683-:22 then the port mapped to the guest port 80 is 59681, meaning the gokrazy web UI will be at http://locahost:59681.

There are various other modes with which you can run gom, take a look below!

with various disk images

Run machine from a full disk img.

gom play --full /tmp/disk.img

Run machine from different disk parts (boot,root,mbr).

gom play --boot=/tmp/boot.img --root=/tmp/root.img --mbr=/tmp/mbr.img

Run machine from remote OCI artifact (the image won't be kept locally). NOTE: to work with this tool an OCI artifact will need to be constructed in this way.

gom play --arch amd64 --oci <your-oci-amd64-img-url>

# or with an arm64 image

gom play --arch arm64 --oci <your-oci-arm64-img-url>

# if the OCI artifact reference is in a private repository, you can specify credentials
# by using --oci.user and --oci.password
gom play --arch amd64 --oci.user "<youruser>" --oci.password "<yourpassword>" --oci <your-oci-amd64-img-url>

# if the OCI registry is HTTP only you can specify the --oci.plainHTTP=true flag

Run machine from .gaf (Gokrazy Archive Format) disk.

gom play --gaf /tmp/disk.gaf

with various networking setups

By default a gom machine will use a nat network, and will map port 80, 443 and 22 to random ports. These random assigned ports can be found in the log output of gom, at the top, where the qemu Args are reported before the machine is started, in the -netdev argument. e.g. -netdev user,id=net0,hostfwd=tcp::59681-:80,hostfwd=tcp::59682-:443,hostfwd=tcp::59683-:22

But if you need to do specific or extra mappings, or use different modes, here is how you can do it.

Run gom machine in NAT network, with specific port forwarding. Set --net-nat="<outer-port>-:<inner-port>,<outer-port>-:<inner-port>"

gom play ... --net-nat="8181-:80,2222-:22"

[Supported only for macOS] Run gom machine in shared network, with specific IP range. This can be set with --net-shared, a comma separated string where users can set --net-shared="<start-ip,end-ip,subnet-mask>"

gom play ... --net-shared="192.168.70.1,192.168.70.254,255.255.255.0"

with various target architectures

By default gom will use the amd64/x86_64 architecture as the target machine architecture. But arm64 can also be set.

For amd64/x86_64:

gom play --arch="amd64"

For arm64:

gom play --arch="arm64"

with custom memory for the guest VM

By default gom will use 1G of memory for the guest VM. It can be customized with

gom play --memory="2G"