Thanks guys! I was finally able to self host my own raw-html "blog"
from KazuchijouNo@lemy.lol to selfhosted@lemmy.world on 10 Dec 2024 06:35
https://lemy.lol/post/35499344

So, I’ve been trying to accomplish this for a while. First I posted asking for help getting started, then I posted about trying to open ports on my router. Now, I proudly post about being able to show the world (for the first time ever) my abysmal lack of css and html skills.

I would like to thank everyone in this community, specially to those who took the time to answer my n00b questions. If you’d like to see it, it will be available at: kazuchijou.com

(Beware however, for you might cringe into oblivion and back.)

Since this website is hosted on my desktop computer, there will be some down-time here and then, however I’ll leave it on for the next 48 hours (rip electricity bill) only for you guys to see. <3


Now, there are a couple of things that need addressing:

I set it up as a cloudflare tunnel and linked it to my domain. However, I still don’t know any docker at all (despite using it for the tunnel), and the process was too incredibly and stupidly easy. I don’t think I learned as much as I expected and I didn’t feel challenged at all.

The original idea was to do some port forwarding. (This was foolish and a bit of a waste of time). Despite getting a “public-ip-address” from my ISP, I still was unable to open ports successfully. I kept getting the same error again and again. If you’d like to read my original post about port forwarding you may follow this link: “[Solved] ((lie)) Noob stuck on port-forwarding wile trying to host own raw-html website. Pls help”.

While I know doing this represents a security risk, I still wanted to at least have a small success with port forwarding. I just wanted to have the raw-internet-connection experience, you know? like, the basics and such. And Cloudflare is holding my hand way too hard, I want to feel like I can shoot myself in the foot (without actually doing so)

But to be honest, I’m quite happy with the outcome. There are many other avenues I’d like to explore in the future, like setting up a reverse proxy with nginx or even darknet hosting (as sugested by another commentor).

I hope to keep learning and some day help another poor soul like myself in a similar situation. I thank you again guys, you’re the best.

[TL;DR] This is the best and most helpful community ever! thx <3

#selfhosted

threaded - newest

Cris_Color@lemmy.world on 10 Dec 2024 07:02 next collapse

Fuck yeah!

user224@lemmy.sdf.org on 10 Dec 2024 07:21 next collapse

Just in case: If your storage is completely full all of a sudden, check /var/log/nginx if you haven’t pointed the logs elsewhere.

I know I was pretty confused to find my storage absolutely full, then I found the multi-GB error.log file. When a network interface it was listening on disappeared it filled with errors as such:

2024/12/10 07:57:06 [alert] 20420#20420: accept4() failed (22: Invalid argument)
2024/12/10 07:57:06 [alert] 20420#20420: accept4() failed (22: Invalid argument)
2024/12/10 07:57:06 [alert] 20420#20420: accept4() failed (22: Invalid argument)
2024/12/10 07:57:06 [alert] 20420#20420: accept4() failed (22: Invalid argument)
2024/12/10 07:57:06 [alert] 20420#20420: accept4() failed (22: Invalid argument)
2024/12/10 07:57:06 [alert] 20420#20420: accept4() failed (22: Invalid argument)

(I just reproduced that now on-demand, thus the date.)

There’s a tool called logrotate to take care of logs, but I just did the stupid and lazy thing…

error_log /dev/null;

Well, in case you get the idea to run NGINX in Termux, and then later you find your phone hot, stuck in a bootloop, it’s possible the error.log filled the storage causing Android to crash because it now can’t even write system files.
Not that I would have done such thing…

muntedcrocodile@lemm.ee on 10 Dec 2024 07:29 next collapse

How did fix the boot loop on android?

user224@lemmy.sdf.org on 10 Dec 2024 07:46 collapse

Forcing it into recovery -> Power Off -> Booting up normally again

This freed up 8MB from somewhere, otherwise, I guess I’d have to do a hard reset.

KazuchijouNo@lemy.lol on 10 Dec 2024 07:39 collapse

Thanks a bunch!
I will certainly consider this, I had no idea nginx created these log files.

If anything, I can just rm them into oblivion right?

user224@lemmy.sdf.org on 10 Dec 2024 07:45 next collapse

Yup.

atzanteol@sh.itjust.works on 10 Dec 2024 10:10 collapse

Sorta. If the log file is open then your rm won’t take effect until the application closes the file. You won’t see the file anymore but it will still be taking up space. So if nginx is running when you delete the logs you may need to either stop it or restart it depending on how nginx handles this.

elperronegro@lemmy.world on 10 Dec 2024 08:51 next collapse

Well done. I have been having similar port forwarding problems as you. Had started to look at cloudflare tunnels but am now encouraged to go ahead. Thanks

KazuchijouNo@lemy.lol on 10 Dec 2024 16:07 collapse

Sure thing! Also, when you’re prompted to input the protocol type use HTTP, not HTTPS, cloudflare will turn it into HTTPS. But my website gave me the error 502 because of that.

khapyman@sopuli.xyz on 10 Dec 2024 10:13 next collapse

I’m ancient, websites with little to no CSS (and absolutely no client side scripts) are refreshing. I don’t know if I’d like all of web to be like that, but there’s something to be said for the absolute individuality of everybody writing their sites from scratch.

It’s way too easy to spin up a Wordpress installation and be done with it.

Salute!

KazuchijouNo@lemy.lol on 10 Dec 2024 16:12 collapse

Yes! I actually like that style a lot more. It’s lighter, without bloat, and minimalist. Only html and css.

And I’d like to say “yeah, I wrote it all by hand btw”

K3can@lemmy.radio on 10 Dec 2024 17:26 collapse

Nice. I wrote mine “by hand”, too. No CSS, just raw HTML. I think it’s a more personal experience than just using whatever random template some all-in-one web hosting company offers.

KazuchijouNo@lemy.lol on 10 Dec 2024 19:44 collapse

Nice!! I agree with you. The experience is more personalized. You can show people who you are, and show them that you’re not just another default template. I loved the gifs btw. Are you self hosting it or is it on a vps?

Btw, how did you do the side panel menu-thingy? I’d appreciate if you just pointed the direction, I’ll read the docs myself

K3can@lemmy.radio on 10 Dec 2024 23:10 collapse

Self hosted from my homelab on an nginx server. I also self host my blog, which has some info on my whole set up. My blog uses some basic bloging software, though, rather than being hand-made.

The “side menu thingy” is achieved through HTML “frames”. It’s an element of HTML that’s pretty much extinct nowadays, but was all the rage when I built my very first page back in the day.

kreskin@lemmy.world on 10 Dec 2024 11:16 next collapse

rawbloggin huh.

KazuchijouNo@lemy.lol on 10 Dec 2024 16:13 collapse

You got me

I’ve been raw-blogging all week B)

nichtburningturtle@feddit.org on 10 Dec 2024 17:45 next collapse

Congratulations. I’m happy for you.

KazuchijouNo@lemy.lol on 11 Dec 2024 03:45 collapse

Thank you!

3nthusiast@infosec.pub on 10 Dec 2024 23:05 next collapse

Well done. Looks nice.

KazuchijouNo@lemy.lol on 11 Dec 2024 03:45 collapse

Thanks!

tehn00bi@lemmy.world on 10 Dec 2024 23:37 next collapse

How do you protect your home network?

KazuchijouNo@lemy.lol on 11 Dec 2024 02:07 collapse

Uhhhh… Prayers?

So far the only protection I’ve got is running it through a cloudflare tunnel. And that’s it.

possiblylinux127@lemmy.zip on 11 Dec 2024 05:15 collapse

Then why did you expose it to the internet?

Evotech@lemmy.world on 11 Dec 2024 05:50 collapse

He didn’t.

He exposed it to cloudflare

possiblylinux127@lemmy.zip on 11 Dec 2024 06:26 collapse

“They’re the same picture”

Not that I am saying it is bad necessarily. Cloudflare does add a extra level of protection. In fact I would say that the chances of a compromise go way down. My concerned is that a lack of knowledge could lead to a compromise.

KazuchijouNo@lemy.lol on 12 Dec 2024 03:33 collapse

Thanks! I appreciate your concern.

This website is just a personal fun project, and I haven’t got anything to lose if it gets compromised. On the contrary I’ve gained a lot so far, and I might gain even more if something bad were to happen to it.

No one can hack into the knowledge and experience I’ve gained so far.

If you’ve got any advice on security tools, good practices, etc. I’d appreciate them! I may lack the knowledge, but not the will to learn more

possiblylinux127@lemmy.zip on 12 Dec 2024 05:36 next collapse

The concern is that your device could start serving a different task without you knowing. It might end up being used to help mask hijacked Azure accounts for instance.

The biggest thing I can recommend is least privilege and defense in depth. You want your setup to be compartmentalized as much as possible and you should aim for minimal permissions. The idea is that even if a security hole is exploited the blast radius is limited.

You are probably fine. It is just something to keep in mind.

tehn00bi@lemmy.world on 14 Dec 2024 13:46 collapse

Yeah, I bring this up because I’ve been playing around with a similar idea of a simple html website for documenting personal projects. My site still isn’t really live, but I have it running on a vm through a cloud flare tunnel, similar to you.

KazuchijouNo@lemy.lol on 14 Dec 2024 20:38 next collapse

Yeah! That’s cool, I haven’t had any issues so far.

Everyday I get a bunch of logs of bots trying to access files and folders that don’t exist. It seems that they are targeting wordpress sites because all the files start with ‘wp-’ for example, some tried to access ‘wp-admin/credentials’, but since my site isn’t wordpress I’m not worried. Besides, I’m pretty sure that I could implement some rules on the firewall or even on nginx to block access to said directories by (for example) redirecting them to a different page.

KazuchijouNo@lemy.lol on 14 Dec 2024 20:39 collapse

I’d love to see your website btw!

mac@lemm.ee on 11 Dec 2024 04:23 next collapse

Unsure if this interests you, but check out Jekyll, a static site generator jekyllrb.com

Basically you write in markdown and have Jekyll generate the site for you

KazuchijouNo@lemy.lol on 12 Dec 2024 03:21 next collapse

Thanks! I’ll check it out!

yonder@sh.itjust.works on 12 Dec 2024 19:56 collapse

Hugo is also pretty cool.

Shimitar@feddit.it on 11 Dec 2024 05:35 next collapse

Love it!

1000 kudos!

Check my wiki wiki.gardiol.org I have documented my journey as well, it could be useful for you too maybe.

Also more kudos for using NGINX.

KazuchijouNo@lemy.lol on 12 Dec 2024 03:20 next collapse

This is truly a treasure trove! Thanks a bunch. I read the intro and I completely agree with you. That’s the reason why I’m doing all this. I wan’t to be able to make my own website in the most self-sufficient way possible, and then share the knowledge with as many people as I can so that they may as well open their own websites.

I miss the old internet, hence the style of my website.

Shimitar@feddit.it on 12 Dec 2024 07:15 collapse

Thank you! I hope my wiki can be useful to you.

Yes, we need more internet like it was, no monetization, no ads, just sharing for the fun of it. That needs to restart back from us. A little tiny part maybe, but worthwhile.

Lots of people talks, but few acts.

KazuchijouNo@lemy.lol on 12 Dec 2024 03:40 collapse

Also, is there any particular reason why my decision to use NGINX stood out to you? Is it a good start?

I wanted to use APACHE at first (really trying to go for that old internet experience) but decided to use NGINX because the learning resources were more readily available, (and I kept hearing “NGINX” everywhere)

Shimitar@feddit.it on 12 Dec 2024 07:16 collapse

Apache is more a web server and less a reverse proxy. Nginx shines as reverse proxy more than as a web server IMHO.

√But lots of people here prefer “simpler” solutions like traefik or caddy, seeing somebody jumping to nginx made me smile positively.

KazuchijouNo@lemy.lol on 13 Dec 2024 18:30 collapse

I’m learning docker now. I found a whole video about the reverse proxy capabilities of nginx and docker, so I’ll be checking that out.

My goal is to have my own homelab and expose some services to the internet, or maybe even set up my own vpn so that I may access and configure things on my network from somewhere else.

I’m still struggling with the port forward thingie, and while Cloudflare tunnels are a nice thing to have, they protect me too much. I want a public IP address that I can use and register on a DNS, or ssh directly into my network from anywhere in the world. As I mentioned, I want to be able to shoot myself in the foot without actually doing so, (hopefully).

ipkpjersi@lemmy.ml on 14 Dec 2024 05:07 collapse

Self-hosting is definitely a ton of fun. I love being able to host my own services, whether it’s using like a server in the cloud or my own hardware.

KazuchijouNo@lemy.lol on 14 Dec 2024 20:46 collapse

Definitely!

You get to learn a lot, and most importantly, you become self suficient and free. No need to depend on corporations to manage your services, because you can do that yourself.

Want your own cloud? Just run and configure nextcloud on your server :D

Want your own personal blog? Make it yourself!

It’s so fun!