this post was submitted on 11 Jul 2023
28 points (91.2% liked)

Selfhosted

39964 readers
255 users here now

A place to share alternatives to popular online services that can be self-hosted without giving up privacy or locking you into a service you don't control.

Rules:

  1. Be civil: we're here to support and learn from one another. Insults won't be tolerated. Flame wars are frowned upon.

  2. No spam posting.

  3. Posts have to be centered around self-hosting. There are other communities for discussing hardware or home computing. If it's not obvious why your post topic revolves around selfhosting, please include details to make it clear.

  4. Don't duplicate the full text of your blog or github here. Just post the link for folks to click.

  5. Submission headline should match the article title (don’t cherry-pick information from the title to fit your agenda).

  6. No trolling.

Resources:

Any issues on the community? Report it using the report flag.

Questions? DM the mods!

founded 1 year ago
MODERATORS
 

I want to host my website in my raspberry pi, I've read that I would need a web server software for this. Which one do you recommend? It won't be a complex website.

top 44 comments
sorted by: hot top controversial new old
[–] [email protected] 27 points 1 year ago* (last edited 1 year ago) (2 children)

Caddy! It has HTTPS built in and provides simple but powerful configuration with sane defaults.

Example Caddyfile for a static file server:

example.com {
	root * /var/www
	file_server
}

I used nginx in the past, but didn't like it's verbose config files.

[–] [email protected] 9 points 1 year ago

+1 for Caddy. It's my default webserver and reverse proxy. Built-in Https and the fact that I can get it up, running and configured in a matter of minutes are the main reasons.

[–] [email protected] 9 points 1 year ago

The first open source contribution I made was to caddy!

[–] [email protected] 17 points 1 year ago

Nginx! Simplex essential and easy.

Unless you need to rely a lot on CGIs then apache maybe is better.

[–] [email protected] 8 points 1 year ago

nginx

Not sure why others are suggesting a Raspberry Pi and nginx would cause problems? I run three public facing websites on a single Raspberry Pi 4 with 2GB RAM. Has been working flawlessly for 2 years. Typical uptime is measured in multiple months.

Running Wordpress, fail2ban and certbot. Booting and running of a USB drive - have considered SSD but no need as I cache to RAM for performance.

[–] [email protected] 8 points 1 year ago (1 children)
[–] [email protected] 1 points 1 year ago

There is a NPM (nginx proxy manager) with rly nice GUI that you can run in docker container

[–] [email protected] 8 points 1 year ago* (last edited 1 year ago) (1 children)

Apache, the OG HTTP server. Fast, well documented, battle-tested, FOSS and community-led (unlike nginx which is corporate-led). People will tell you that nginx is "faster" but never point to actual benchmarks. Both are ok.

[–] [email protected] 2 points 1 year ago (1 children)

Yeah apache is awesome. Lots of settings if u want, and every question I've ever asked and probably am yet to ask has already been answered on stack with multiple duplicates aha

[–] [email protected] 1 points 1 year ago (1 children)

Check out mod_md - this module allows getting certificates from Let's Encrypt (or any other ACME cert provider) automatically. Just set this anywhere in your config, reload apache and you're set. No more fiddling around with certbot.

MDCertificateAgreement accepted
MDContactEmail [email protected]
MDomain my.example.org

Also other comments make it look like only nginx supports FastCGI (e.g. php-fpm), apache has supported talking to FastCGI since 2005:

  <FilesMatch \.php$>
    SetHandler "proxy:unix:/run/php/php8.2-fpm.sock|fcgi://localhost"
  </FilesMatch>
[–] [email protected] 1 points 1 year ago

Yeah I use php-fpm, I didn't know much about it the first time I installed it, I just needed it for HTTP 2.

For ssl I just install certbot and let it autorun LetsEncrypt, I haven't had any issues with any of my ssl certs, it's pretty nice.

The age old LAMP stack is pretty solid, except for me it's LAPP cuz I don't wanna use mysql.

[–] [email protected] 6 points 1 year ago

I use NGINX because it's what I'm familiar with. If I was starting again, I would probably use Caddy.

[–] [email protected] 5 points 1 year ago* (last edited 1 year ago)

Caddy was my first and it's very easy to use. I use nginx nowadays because I heard it scales better. It's harder to use but manageable enough.

Depending on the type of website you're hosting, you can probably just use Cloudflare pages or Netlify instead of hosting it at home with a Pi.

[–] [email protected] 5 points 1 year ago
[–] [email protected] 4 points 1 year ago

I have recently started using Caddy and I love it! FOSS, automatic HTTPS, super easy to setup and works well as a reverse proxy. As your website will not be complex, the Caddyfile would be just a few lines.

[–] [email protected] 4 points 1 year ago

I would honestly go with Apache here. I use NGINX in my environment mainly as a reverse proxy. I do use NGINX to serve my static blog.

[–] [email protected] 3 points 1 year ago (1 children)

Apache httpd if php is involved. Otherwise, nginx.

Both are highly reliable and efficient.

[–] [email protected] 3 points 1 year ago

If running php, I usually go with PHP-FPM and nginx, much faster than Apache in most cases

[–] [email protected] 3 points 1 year ago

lighttpd, just to be different

[–] [email protected] 3 points 1 year ago* (last edited 1 year ago)

I only use nginx now, the out of box footprint is tiny.

add this deb https://packages.sury.org/nginx/ bookworm main to your /etc/apt/sources.list to install the latest stable

[–] [email protected] 3 points 1 year ago (1 children)

Is your site static or dynamic? If your site is made of good old HTML and CSS or your site is a SPA, any web server will serve it well.

I prefer Nginx as it is performant and versatile enough for most use cases.

[–] [email protected] 1 points 1 year ago (1 children)

Static mostly, I will have a few dynamic pages though.

[–] [email protected] 0 points 1 year ago

If your dynamic pages leverage PHP, Nginx can be configured to support that via FastCGI. If your site has its own server runtime (e.g. a site written with NodeJS or Go), Nginx reverse proxy is literally its strength. So yeah give Nginx a try. I bet you won't regret it.

[–] [email protected] 2 points 1 year ago (1 children)
[–] [email protected] 2 points 1 year ago

Traefik can't serve html itself though, can it?
It can route requests to a web server, but it can't serve the files itself iirc.

This Stack Overflow post seems to confirm this: https://stackoverflow.com/questions/46503797/is-there-a-way-to-serve-static-resources-with-traefik

[–] [email protected] 1 points 1 year ago

I'm a big fan of HAProxy

[–] [email protected] 0 points 1 year ago (1 children)

I always love Flask for this, it's a super simple python web server that is basically fully batteries included, just write a couple lines of python and throw your html in either /static or /templates, depending on whether it's dynamic or not, and you're live. It's not gonna move mountains but it's not meant to.

[–] [email protected] 1 points 1 year ago (2 children)

How is the performance compared to nginx or apache?

[–] [email protected] 0 points 1 year ago

Much lower and you shouldn't care. As long as you're serving less than one request per second, you will not need to care about performance. If you do, sanic and vibora are drop-in flask replacements and they are both much more performant.

load more comments
view more: next ›