gokrazy/website/content/quickstart.html
2020-05-31 20:29:57 +02:00

75 lines
3.0 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

---
title: gokrazy quickstart
aliases:
- /quickstart.html
menu:
main:
title: "Quickstart"
weight: 20
---
<div class="row">
<div class="col-lg-12">
<h1>Get a Raspberry Pi 3 (no other model)</h1>
<p>
Currently, the Raspberry Pi 3 is the <strong>only</strong>
model supported. Many people assume the Raspberry Pi Zero W
could be used as well. Unfortunately, it uses the older
BCM2835 SoC, which is not arm64, so gokrazy wont run on
it. See
also <a href="https://www.reddit.com/r/golang/comments/5xgf8u/gokrazy_a_purego_userland_for_your_raspberry_pi_3/dei7b2m/">stapelbergs
reddit comment about supported hardware</a>.
</p>
<h1>Install Go</h1>
<p>
If you dont already have Go installed, install the latest <a href="https://golang.org/dl/">Go</a> version.
</p>
<h1>Install the gokrazy packer</h1>
<pre>INSTANCE=gokrazy/hello; mkdir -p ~/${INSTANCE?} && cd ~/${INSTANCE?} && echo module ${INSTANCE?} > go.mod
go get -u github.com/gokrazy/tools/cmd/gokr-packer</pre>
<h1>Overwrite an SD card with gokrazy</h1>
<p>
Plug an SD card into your card reader and locate its device node by checking <code>dmesg | tail</code>. In this example, well assume the SD card is accessible as <code>/dev/sdb</code>.
</p>
<p>
To overwrite the entire SD card <code>/dev/sdb</code> with a gokrazy installation running a hello world program, use:
</p>
<pre>cd ~/gokrazy/hello
gokr-packer -overwrite=/dev/sdb github.com/gokrazy/hello github.com/gokrazy/serial-busybox</pre>
<p>
The <code>gokr-packer</code> command above will result in log output like this:
</p>
<pre>2017/03/01 20:59:55 packer.go:85: installing [github.com/gokrazy/hello]
2017/03/01 20:59:56 packer.go:131: partitioning /dev/sdb
2017/03/01 20:59:56 parttable.go:40: device holds 15931539456 bytes
2017/03/01 20:59:56 packer.go:139: waiting for /dev/sdb1 to appear
If your applications need to store persistent data, create a file system using e.g.:
mkfs.ext4 /dev/sdb4
To boot gokrazy, plug the SD card into a Raspberry Pi 3 (no other model supported)
To interact with the device, gokrazy provides a web interface reachable at:
http://gokrazy:<i>&lt;automatically-generated-random-password&gt;</i>@gokrazy/
There will be not be any other output (no HDMI, no serial console, etc.)</pre>
<p>
After booting from this SD card, your Raspberry Pi 3 will:
<ul>
<li>obtain an IP address for hostname “gokrazy” via DHCP (IPv4) and SLAAC (IPv6)</li>
<li>synchronize the clock using NTP</li>
<li>expose a password-authenticated web interface on private IP addresses<br>
(the default password can be recovered from <code>~/.config/gokrazy/http-password.txt</code>)</li>
<li>supervise all installed programs (only the hello world program in this example)</li>
</ul>
The only way for you to interact with the device is via the
web interface (unless the installed programs provide other
ways). There will be no HDMI output, no serial console, etc.
</p>
</div>
</div>