Doing an experiment with my RPi 4, using it as a small but powerful local server.
My current PC is a 10 year old Macbook Pro 13" 2010, which is sluggish sometimes.
So I want to offload some heavy tasks (ffmpeg time-lapse creation, long-running tasks and services) to the Raspberry Pi and connect to it either via LAN or Wi-Fi.
Below you can read my findings about performance, applications and general issues I encountered and tried to solve.
Table of Contents
- Update 2023
- First steps
- Connection via LAN to PC
- Connection via Wi-Fi
- Benchmarking Transfer speeds via iperf
- Applications
- Final words
Update 2023
This post is still relevant, but in the meantime (since 2020) I’ve written a few new posts that could interest you too:
- Provisioning a Raspberry Pi with Ansible (and an iPad)
- Self-hosting miniflux with docker and provisioning with Ansible
- Self-hosting with nginx + docker-compose
- What apps I’m currently self-hosting
- Self-hosted Miniflux + Wallabag
- 3D printing with an iPad, Raspberry Pi and OctoPrint
First steps
I started by:
- Flashing a minimal RaspiOS Buster Lite image on a 32GB SD card (prob better for the future if I used a 128GB one)
- No setup of Wi-Fi connectivity through
wpa_supplicant
- Creating an empty
ssh
file in the SD card to enable SSH access
Powered up the Pi and I was able to connect via LAN.
Additionally, I changed the hostname of the Raspberry Pi to serverry
(through raspi-config
).
Connection via LAN to PC
Connecting the RPi to my MBP through LAN was the first thing I wanted to try.
The Pi is now available on my PC as serverry.local
.
Internet Sharing from PC to RPi
“Internet Sharing” from the PC to the Pi was super easy.
Worked first try, just had to enable the internet sharing setting on my Mac:
Connection via Wi-Fi
Set up a wpa_supplicant.conf
in /etc/wpa_supplicant/wpa_supplicant.conf
or place it
in the root of the SD card.
This enables the Raspberry Pi to have independent internet connectivity.
Here is an example:
ctrl_interface=DIR=/var/run/wpa_supplicant GROUP=netdev
ap_scan=1
update_config=1
network={
scan_ssid=1
ssid="YOUR_SSID"
psk="YOUR_PSK"
}
Now the RPi is also available in my home-network under serverry.fritz.box
Benchmarking Transfer speeds via iperf
Did a simple benchmark using iperf
, once using Wi-Fi and once using the direct ethernet connection to my PC.
Here are the results:
- LAN transfer speeds (Mac - RPi): 900+MBits/s
- WLAN transfer speeds (Mac - RPi): 60+MBits/s)
Makes total sense, still interesting.
Benchmark over LAN
~ iperf3 -c serverry.local
Connecting to host serverry.local, port 5201
[ 7] local fe80::58b0:35ff:feef:3a64 port 62068 connected to fe80::b713:505e:420e:d16b port 5201
[ ID] Interval Transfer Bitrate
[ 7] 0.00-1.00 sec 111 MBytes 933 Mbits/sec
[ 7] 1.00-2.01 sec 97.9 MBytes 817 Mbits/sec
[ 7] 2.01-3.01 sec 110 MBytes 919 Mbits/sec
[ 7] 3.01-4.01 sec 110 MBytes 929 Mbits/sec
[ 7] 4.01-5.01 sec 107 MBytes 891 Mbits/sec
[ 7] 5.01-6.01 sec 110 MBytes 925 Mbits/sec
[ 7] 6.01-7.01 sec 109 MBytes 911 Mbits/sec
[ 7] 7.01-8.01 sec 107 MBytes 902 Mbits/sec
[ 7] 8.01-9.01 sec 108 MBytes 908 Mbits/sec
[ 7] 9.01-10.00 sec 109 MBytes 916 Mbits/sec
- - - - - - - - - - - - - - - - - - - - - - - - -
[ ID] Interval Transfer Bitrate
[ 7] 0.00-10.00 sec 1.05 GBytes 905 Mbits/sec sender
[ 7] 0.00-10.01 sec 1.05 GBytes 904 Mbits/sec receiver
Benchmark over Wi-Fi
~ iperf3 -c serverry.fritz.box
Connecting to host serverry.fritz.box, port 5201
[ 7] local 192.168.188.52 port 62063 connected to 192.168.188.53 port 5201
[ ID] Interval Transfer Bitrate
[ 7] 0.00-1.00 sec 8.18 MBytes 68.6 Mbits/sec
[ 7] 1.00-2.00 sec 7.78 MBytes 65.2 Mbits/sec
[ 7] 2.00-3.00 sec 7.77 MBytes 65.2 Mbits/sec
[ 7] 3.00-4.00 sec 7.63 MBytes 63.9 Mbits/sec
[ 7] 4.00-5.00 sec 7.24 MBytes 60.6 Mbits/sec
[ 7] 5.00-6.00 sec 7.49 MBytes 63.2 Mbits/sec
[ 7] 6.00-7.00 sec 7.28 MBytes 61.0 Mbits/sec
[ 7] 7.00-8.08 sec 7.94 MBytes 61.6 Mbits/sec
[ 7] 8.08-9.00 sec 6.25 MBytes 57.0 Mbits/sec
[ 7] 9.00-10.12 sec 7.32 MBytes 54.8 Mbits/sec
- - - - - - - - - - - - - - - - - - - - - - - - -
[ ID] Interval Transfer Bitrate
[ 7] 0.00-10.12 sec 74.9 MBytes 62.1 Mbits/sec sender
[ 7] 0.00-10.12 sec 74.9 MBytes 62.0 Mbits/sec receiver
Applications
ffmpeg for time-lapse
Lately I’ve been busy with time-lapses, and the process of creating one with ffmpeg on my MBP was getting slower and slower (seemingly).
Did a benchmark of creating a time-lapse of 20 FPS, based on 775 snapshots. The snapshots were taken every minute from 7AM til 8PM.
There is to mention that the Pi has 4 cores 4GB RAM, while my MBP has 2 cores 8GB RAM.
On the Raspberry Pi the ffmpeg
process took 12m30s to complete.
While on my MBP it took 20m!
Almost twice as fast, daaamn!
I think for more graphics intensive uses, the MBP would win though, since it has a Nvidia 320m, for what’s worth
This is a comparison of htop
between both devices
Raspberry Pi
Macbook Pro 13" 2010
n8n for automation
I wanted to use n8n.io to automate some personal tasks, and create useful workflow automations.
There is an ARM build for n8n using docker, fortunately:
docker run -d --restart always --name n8n -p 5678:5678 -v ~/.n8n:/root/.n8n n8nio/n8n:0.78.0-rpi
You could also use npx
, npx n8n
The dashboard is available via http://serverry.local:5678
, you now have access to your local n8n instance.
emby for media server
Recently discovered emby.media.
It can be used as a personal library of your media files, for easy access, organization and streaming.
The installation was as easy as:
wget https://github.com/MediaBrowser/Emby.Releases/releases/download/4.5.0.25/emby-server-deb_4.5.0.25_armhf.deb -O emby-server.deb
sudo dpkg -i emby-server.deb
Emby is now available on http://serverry.local:8096/
hakatime
Hakatime is a server implementation of Wakatime.
Unfortunately, the docker image is not built for ARM, so it cannot work on the Pi.
I’m getting the classic error when spinning up the docker image:
standard_init_linux.go:211: exec user process caused "exec format error"
Will have to figure out how to build the project manually…
That’s a pity though, I was super stoked to get Hakatime up and running :(
Tor proxy
Managed to easily set up a tor proxy on the Raspberry Pi.
As easy as
sudo apt install tor
echo "SocksPort 0.0.0.0:9050\nSocksPolicy accept *\nRunAsDaemon 1" >> /etc/tor/torrc
sudo systemctl restart tor@default.service
Now I can connect from my Mac to the RPi and browse via Tor.
# turn on
networksetup -setsocksfirewallproxy "Wi-Fi" "serverry.fritz.box" "9050" off
# turn off
networksetup -setsocksfirewallproxystate "Wi-Fi" off
Verify connectivity through check.torproject.org
Final words
So far the experience was pretty pleasant.
4 out of 5 use cases (ffmpeg, n8n, emby, hakatime, tor) worked out of the box.
What I want to try out next is:
- Inboxen: infinite number of unique inboxes
- TriggerHappy
- NextCloud
- Zenbot: trading bot
- Firefly: personal finance
- A password manager, haven’t decided yet