I built a personal Web server*, and I did it awesomely

Friday, September 15, 2017

I built a personal Web server*, and I did it awesomely


*JK I built 5.

A month or so ago, I was sitting on the floor of my apartment, feeling a sense of ennui. I needed a new hobby. Lying on trigger point therapy balls while reading sci fi, while satisfying, wasn't enough anymore. I was itching to make something.

It just so happens that I'd had a fun idea for a Web application I'd like to build, about which I will say no more because it's not done and you can't have my idea. Around the same time, I got caught up by friends' wedding excitement and offered to build and host some wedding websites.

It doesn't sound like you'd need your own Web server for that, you're thinking. No, it doesn't. But I wanted one.

It's borderline irresponsible to host your own Web server, what with cloud this and cloud that, but I'm feeling irresponsible. And I'm feeling like I want to play with new things.

Thus was born this adventure. Come along with me. Build a Web server awesomely.


I'm going to lay out the ultimate state, just to get you real excited. If it doesn't make sense yet, don't panic; we'll go through each step below.

We're going to make it so that you can have a single Raspberry Pi hosting multiple Web servers, each serving traffic to a different domain name (or subdomain). We'll do this by having all of these domains point to our router's (dynamic, external) IP address, which is configured to forward requests to port 80 to the (static, internal) IP address of our Raspberry Pi. On the Pi, we're running a a reverse proxy server that forwards these requests, based on the domain name in the request, to individual Web servers on other ports, each one serving a single domain. Except I lied there. We'll actually have the domains point to a DDNS hostname, which itself points to our router's IP; we do this because our ISP doesn't guarantee us a static IP address and it could change at any moment.

To make it concrete: You go to www.whatareheirloomtomatoes.com. Because my router has a dynamic IP address, I can't just have www.whatareheirloomtomatoes.com redirect to my router's IP (or I can, but when my router gets assigned a new IP out of nowhere, I'll be sad); instead, I have a CNAME record that aliases my domain to my DDNS hostname, which I've registered for with a DDNS service (e.g. no-ip.com or dynu.com). This DDNS service gets notified when my IP changes (by a small piece of software they provide to poll for changes), so it knows what my current IP is, and forwards your request for www.whatareheirloomtomatoes.com to that IP on port 80. My router sends that request to my Pi on port 80, where nginx is listening; nginx looks up www.whatareheirloomtomatoes.com in a configuration file I've set up and sees that it should forward that request to the port I've specified, say 8080. On 8080, I have a nodejs server running that serves up the content for www.whatareheirloomtomatoes.com. Ta-da!

If you only want to do a subset of these things – like only set up a single Web server, no reverse proxying, no DDNS madness – I've modularized the topics and you can call it quits when it suits you.

By the end of this, here are all of the technologies we will have played with:
  • Development environment:
    • Atom: IDE (optional; use whatever IDE you want)
    • PuTTY: SSH client (optional; only if sshing from Windows to your pi)
    • Bitvise: SFTP client (optional; again only if sshing from Windows to your pi)
  • Web server:
    • Nginx: Reverse proxying
    • Nodejs: Web servers (optional; if you want to serve a static site, you can use nginx alone. Or use Apache, if you want to party like it's 1999. I don't care.)
      • Forever: Keep those Web servers running
      • Nodemon: Reload your server on change
    • ddclient: Update your DDNS service when your ip changes (optional, if your router can connect directly to your DDNS service)
  • Configuration you never cared to know about:
    • Port forwarding on your router
    • Domain DNS settings (for those who have a custom domain)

Ready to start? Follow the guides below on your path to awesomeness.

  1. Part I: Setting up your enviroment: The Pi, the router, and your development machine
  2. Part II: Host a single server (custom domain edition)
  3. Part III: Set up DDNS to deal with your dynamic IP – for free!
  4. Part IV: Why host one server when you could have n servers? [coming soon]

22 comments :

  1. I loved your blog post.Really looking forward to read more. Awesome. sadness quotes

    ReplyDelete
  2. I cherish this site!! The glimmer up the top is magnificent!! סיינטולוגיה

    ReplyDelete
  3. So don't swindle the universe of your quality and thoughts make personal development a week after week assignment and discover what you are really able to do.Thisalpha.com

    ReplyDelete
  4. This is my first visit to your web journal! We are a group of volunteers and new activities in the same specialty. Website gave us helpful data to work. San Francisco Personals

    ReplyDelete
  5. But a typical confusion is that lone local apps will give clients a disconnected encounter. 안전놀이터

    ReplyDelete
  6. It certainly is practically extremely difficult to come across well-aware on this topic..., but you seem like you are familiar with what exactly you’re posting on! Regards.. https://zenradius.com/bluehost-vs-hostgator


    ReplyDelete
  7. single Web server, Someone To Write My Essay For Me no reverse & DDNS madness. the modularized the topics and when it suits you.

    ReplyDelete
  8. Got any other favorites you use to evaluate a website once it's live? Iea-Etsap

    ReplyDelete
  9. Visiting the emergency care facilities for sprained ankles is often a better choice than waiting a few days for treatment. This is because a sprain can quickly become more severe, leading to more complications. Furthermore, if left untreated, sprained ankles can lead to more serious illnesses that may require surgery. However, if you think you may benefit from some rest, you should go to your family doctor or emergency care center as soon as possible. Read the full info here urgent care for a sprained ankle.

    ReplyDelete
  10. https://onohosting.com/ Search for an organization that has been conveying hosting administrations for over 10 years and has the executives set up to deal with an extending client base productively.

    ReplyDelete
  11. Are you looking for hanine pronunciation? There are many different ways to pronounce the Arabic word "hanine". In this blog post, we look at three different pronunciations of this word in American English. The first pronunciation is the most common and is pronounced "HAH-nee". The second pronunciation is a bit more regional and is pronounced "huh-NEEN". The third pronunciation is less common but is still heard in parts of the United States. Pronounced "ha-NINE". Whatever pronunciation of Hanine you choose, be sure to practice saying it out loud! This will help you improve your pronunciation and avoid confusion when speaking to native English speakers. Thanks for reading and Happy Hanukkah!

    ReplyDelete
  12. This is so good as warzyd. You should to check it out. He is amazing and can show what things like nobody else. Give him a chance a check. But except i really like your blog. Good job! wind mitigation

    ReplyDelete
  13. Thanks for taking the time to discuss this, I feel strongly about it and love learning more on this topic. keep posting. Promotional Backpacks

    ReplyDelete
  14. the variable name is defined, it can only be used once in that program. Finally, if you choose to assign a new value to an already existing variable, the previous value will get overwritten. java programming assignment help

    ReplyDelete
  15. Quadrobits offers budget-pleasant, worldwide static net design offerings. Our expert crew crafts custom, user-centric designs to raise your online presence. Read the full info here digital marketing

    ReplyDelete
  16. Hero MotoCorp, an esteemed Indian motorbike producer, gives a diverse range of bikes in Bangladesh. For the most updated pricing and availability, kindly visit their official website or consult neighborhood sellers. Find more information Hero Bangladesh.

    ReplyDelete