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: https://nginxtest.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
Unsure if this interests you, but check out Jekyll, a static site generator https://jekyllrb.com/
Basically you write in markdown and have Jekyll generate the site for you
Thanks! I’ll check it out!
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!
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”
Well done. Looks nice.
Thanks!
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…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?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.
Yup.
How did fix the boot loop on android?
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.
rawbloggin huh.
You got me
I’ve been raw-blogging all week B)
Fuck yeah!
Congratulations. I’m happy for you.
Thank you!
How do you protect your home network?
Uhhhh… Prayers?
So far the only protection I’ve got is running it through a cloudflare tunnel. And that’s it.
Then why did you expose it to the internet?
He didn’t.
He exposed it to cloudflare
“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.
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
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.
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
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.