Im looking for free entry-level materials about self hosting and network architecture in general. I know that some professors put presentations for free on their websites. im looking for: e-books,lectures,tutorials,videos.
Thanks in advance. -kapx132
So first, what is your objective? What do you want to learn? Self-hosting is extremely open ended.
Now if you’re wanting an avenue into learning entry-level networking, you can try finding Network+ study materials. Unfortunately I haven’t touched this in over 14 years so I don’t have any direct links, but literally any study book or guide, even if its a few years old, should help get you started.
my first goal is to learn how networks work, and then once i learn the basics i want to host my own matrix server.
You can take a look at MIT courseware if there is something for you
I suggest you reverse that order. If first you learn how to host your own matrix server, you’ll have a better idea of what part of “how networks work” you wan to learn.
Or maybe you decide you want a full graduation course on how network works so you can learn all of the basics. But either way, that first half is a large endeavor.
Agreed, networking knowledge can be pretty ephemeral if you don’t have a way to put it into practice and solidify that knowledge in your brain.
My suggestion would be to learn basic Linux and get a server up. Then learn firewall on that server and then how to configure and use a vpn on it - as a client AND a server. Then move on to switching and finally basic routing. At that point you’ll have enough general knowledge to know what you want to do next.
http://tcpipguide.com/free/index.htm and lookup terms/protocols on wikipedia as you go.
But as others said, I think you would learn faster if you pick a specific project and try to implement it from scratch. A matrix server is a nice project, but it will have you dig into matrix-specific configuration which is not particularly relevant if you’re just trying to learn system administration and networking.
I would start with a more “basic” project and ensure you got the fundamentals right, and document or automate (shell scripts, ansible…) all steps:
only accept SSH connections from a specific IP address and DROP all other SSH connections
,forward all HTTPS connections to another IP address
…)Then you can work your way up to more complex services, lookup security hardening measures on your existing setup (as always, document or automate all steps). To give you some ideas, you can find ansible roles I wrote for these tasks here. The common role implements most of what I listed above. The monitoring role implements the monitoring part. There are a few other roles for middleware/infrastructure services (web server/reverse proxy, DNS server, database services, VPN…) and a few more for applications (matrix+element, gitea, jellyfin, mumble…). Start at
tasks/main.yml
for each role, follow theimport_tasks
statements from there, and read at least thename:
for each task to get a good overview of what needs to be done, and implement it yourself from a shell in the first time. If you break your setup, restore the initial VM snapshot and start again (at this point you’ve automated everything, so it shuold not take more than a few minutes, right?) .Each of these tasks will require you to research available software and decide for yourself which is best for your requirements (which hypervisor? which firewall frontend? which monitoring solution? etc)
Matrix server?
they just want to enslave humanity by trapping it in a realistic simulation and harvesting their body heat for energy production.
You know… the usual.
An open chat server: Website, Wikipedia page