This is how I built a home web server with a Raspberry Pi, Node JS, and an Express Server.
- Raspberry Pi B+
- Power Supply
- Micro SD Card (At least 8 GB)
- Case (Optional)
- Raspberry Pi B+
- Power Supply for Raspberry Pi
- Modem and Router
- Ethernet Cord
-
Install the operating system by following these steps
-
Once the operating system is installed, from the command line update the software to the latest.
$ sudo apt-get update; sudo apt-get upgrade
-
If wanted, change the default
pi
user password to something more secure.$ sudo raspi-config
-
Navigate to
2 Change User Password
and follow the steps.
$ wget http://node-arm.herokuapp.com/node_latest_armhf.deb
$ sudo dpkg -i node_latest_armhf.deb
$ node -v
$ sudo apt-get install git
Fork this repo so that you can commit your own updates later on, then clone your repo to your Pi.
$ cd ~/
$ git clone <your-forked-url>
$ cd ~/raspberry-pi-web-server
$ npm install
$ node server.js
Open a browser and go to <your-pi's-IP>:5000
You did it! You successfully ran a webserver on your Raspberry Pi. Now what? How about we open up your router to the outside world and setup a deployment method.
In order for your buddies to access your home web server, you'll need your own domain name that points to your router's dynamic IP provided by your local ISP. I went with the free version of noip.com. After creating an account with noip, follow these steps.
$ cd ~/
$ wget http://www.no-ip.com/client/linux/noip-duc-linux.tar.gz
$ tar vzxf noip-duc-linux.tar.gz
$ cd noip-2.1.9-1
$ sudo make
$ sudo make install
Follow the commands (entering in your username and password from noip) and then start the process.
$ sudo /usr/local/bin/noip2
Now we want this to start whenever your raspberry pi boots, so follow this tutorial to create a startup script if you want it.
Whenever your Raspberry Pi reboots, it'll get a new dynamic IP from your router. We'd rather not have this happen, so let's make it a static IP instead. I followed this tutorial to accomplish this.
You need to enable single port forwarding on your local router. Our webserver is running on port 5000, so I followed this tutorial to open up that port on my router. It may be different for each router.
After saving these port forwarding settings, start up your server with node server.js
, and you should be able to navigate to http://<your-domain>.ddns.net:5000
and see our Raspian homepage!
I'd love to get rid of the :5000
at the end of our url, but unfortunately my ISP restricts access to port 80
, so I can't use a proxy service such as nginx
at this time to proxy pass through all the requests at port 80
to port 5000
.
Well, you've done it, you can successfully view a webpage hosted on your raspberry pi from the outside world. For me, that's just the first step. I want to be able to development on my local computer, and push them changes to my pi simply!
I ❤️ pm2. It's a great module to deploy your nodejs applications. First let's install it on both your computer and your raspberry pi.
$ sudo npm install -g pm2
I like to store my web server in the /var/www
. So let's first create that directory and then make the pi
user the owner.
$ sudo mkdir /var/www
$ sudo chown pi /var/www
$ sudo chgrp pi /var/www
Now we'll use pm2 to deploy straight from our local machine to our raspberry pi, but first we need to be able to ssh into our raspberry pi.
$ sudo raspi-config
$ 8 Advanced Options
$ A4 SSH
$ Enable
Then you'll need to setup another single port forwarding on your router to allow SSH into your home. For my linksys router I had to find out what port allowed remote access on my router by going to Administration
and seeing the port under Remote Management Port
. It was 8080
for me. Then I setup the following single port forwarding.
External Port: 8080
Internal Port: 22
Protocol: Both
To IP Address: <your pi IP>
Enabled: Checked
Test that your SSH works by executing this command.
$ ssh -p 8080 pi@<your domain>.ddns.net
Now on your local computer clone this repo.
$ git clone https://github.com/sean-hill/raspberry-pi-web-server.git
Then edit the ecosystem.json
file and replace the variables between < >
with your appropriate fields. Once you've done that, execute the following commands on your computer to setup your project on your raspberry pi.
$ pm2 deploy ecosystem.json production setup
$ pm2 deploy ecosystem.json production
You'll be prompted to enter your pi
password multiple times. If this bothers you, I recommend creating public/private ssh keys on your computer and to copy your public key to your raspberry pi as described here.
Now head back over to your raspberry pi, and exectute these commands.
$ cd /var/www
$ pm2 list
You should see your app running and be able to access your server from your browser at <your-domain>.ddns.net:5000
!
│ Web Server │ 0 │ fork │ 10488 │ online │ 7 │ 6m │ 22.156 MB │ disabled │
Now every time you make changes to your server, commit the changes, push them up, and then deploy your app using pm2. You never have to SSH into your Raspberry Pi.
This is a bit of tedious process, but you just set up your own personal web server for less then 50 bucks. Pretty sweet! Good luck and let me know if this process could be improved!