Setting Up Networking and an HTTP Server on the BeagleBone Black with Buildroot
Embedded Linux Development Lab
This is a continuation of my previous blog where we set up a minimal Linux system for the BeagleBone Black with Buildroot.
Today we're going to set up networking and an HTTP server on the board to serve web pages.
Why might we want to do that?
Take for example any IoT device like this Smart Washing Machine, rather than running a cycle by having the user SSH into the Linux board and run scripts, one might run an HTTP server on the board and show a pretty website with nice features that anyone could use.
Modify the Buildroot Image
We need to add some extra packages to our board, mainly the HTTP Server.
Just like last time, change into your buildroot directory, and run:
make menuconfig
You should see the familiar menuconfig page:
In Target Packages: Networking applications:
Enable nginx, make sure http_server is enabled
Enable dropbear. This is an SSH client that will be convenient for us.
Enable ifupdown scripts. These are init scripts courteously written for us to initialize our static network connection on the board.
Set up Networking
To connect our board to a network, we need a connection to our desktop.
Normally, you could do this by plugging your board into your router and letting it assign an IP address, but my router is pretty far from my desk so we'll have to use another method.
Option 1
If you have a network switch laying around, like this little Netgear one I have, you could use that:
Option 2
You could use a Crossover Cable. This will allow you to connect your desktop directly to the Beaglebone.
Setting IP Addresses
Like I spoke about before, your router could just assign the board an IP address. This is because the router is running a DCHP Server that assigns IP's for every computer on your network.
Since we are connecting our PC directly to our board, this will be a separate network from your router and will require different configuration.
We could run a DCHP server on our Desktop to assign the board an IP, but because we're only connecting one thing to this network, that is certainly overkill.
We'll define a static address for our board in its /etc/network/interfaces
file.
Making an Overlay Directory
Instead of SSH'ing into the board every time we create a new image to modify this file, we can use an overlay file. This is an option in the buildroot menuconfig to allow us to add things into the image each time it builds.
In the buildroot directory, create and overlay directory, and fill it with the directories and files we need:
mkdir -p overlay/etc/network
touch overlay/etc/network/interfaces
vi overlay/etc/network/interfaces
In this vi window, paste:
auto eth0
iface eth0 inet static
address 192.168.1.100
gateway 192.168.1.1
netmask 255.255.255.0
Here what we are doing, is setting our ethernet interface, eth0
, to have a static ip address of 192.168.1.100
, and giving it the gateway of 192.168.1.1
.
Now enter the menuconfig, and in System Configuration, set the Root filesystem overlay directory to ./overlay
Now run make
to build this new image, flash it onto your SD card when you're finished.
Plug the board in and boot it holding the USR button as usual. Plug your crossover cable or switch into both the board and your desktop.
In Settings, if you're running the GNOME Desktop Environment, go into network. You won't see a connection to your board yet, because you havent configured the static IP for your desktop.
Add a Wired network, and set your settings as follows:
The last set of numbers on your address can be whatever you'd like (except the IP you used for the beaglebone), I just used 192.168.1.45
.
Save this network, and you should now see that you're connected to a wired network!
SSH
Now we should be able to ssh into our board.
ssh root@192.168.1.100
You'll notice ssh is acting very sluggish upon connection. There is something we can disable on the image to fix this.
In the menuconfig, navigate to the dropbear package. Inside this, disable reverse DNS Lookups.
Reverse DNS Lookup is a security feature, normally used to verify the authenticity of connections. But since our beaglebone isn't connected to any DNS server it will hang here as it screams out into nothing, waiting for a return from a non-existent DNS server.
Build this image and put it onto your card, and SSH access should be fast now!
Serving Web Pages
Busybox init handles a lot of the work for us here. Because we enabled nginx, buildroot has assumed that we want it to run each time on startup.
With the board booted up, and network cable connected, you should be able to go directly to 192.168.1.100
in your browser and get the nginx configure page:
According to
Next, we need to provide some basic configuration to NGINX to serve our custom pages. In the The NGINX Beginners Guide, we learn that the configuration file for nginx is in /etc/nginx/nginx.conf
and has a relatively simple configuration process.
Instead of doing this on our board, where every time we reinstall an image we'd have to repeat this process, lets automate this through the use of the overlay directory.
Back in your buildroot diretory, cd into your overlay directory.
mkdir -p etc/nginx/
touch etc/nginx/nginx.conf
In a text editor, enter the following simple config into nginx.conf
:
worker_processes 1;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
server {
listen 80;
server_name localhost;
location / {
root /data/www;
index index.html;
}
}
}
This tells nginx we want to serve out of /data/www
which is the recommended location in the aforementioned beginner's guide.
Create this directory in the overlay as well:
mkdir -p data/www
touch data/www/index.html
In a text editor, let's add a "Hello world page" to demonstrate a working embedded web server:
<!DOCTYPE HTML>
<html>
<body>
<script>
alert( 'Hello world from the BeagleBone Black!' );
document.write('Hello world from the BeagleBone Black!');
</script>
</body>
</html>
After this, run make
to build the image, flash it to the board, and boot it familiarly.
Navigate to the board's address in the browser, and:
Success! We can serve web pages from the beaglebone to your desktop!