Homelab: My Network setup

# homelab # networking # wireguard
Published On: July 21, 2022 (Last updated on: April 15, 2024)
239 words · 2 min

In General

Network

Tools I use

I choose Wireguard since it’s fast because of its light design, and it’s secure because it uses the best cryptographic tools available. However, for each time, the user may need to consider a SUBNET for the wireguard and a IP for each node, for me, it is every annoyed, as I have too many subnet need to be configured. Thus, I build a little tool: wgtools

How to use

  • prerequest:

    • clone the code into local directory: git clone https://github.com/TerenceLiu98/wgtools.git
    • install the requirement: python -m pip install -r requirements.txt
    • install the wireguard before using the tool
  • configuration:

    • new a ipv4 pool: python add.py network wg0
    • new (a) peer(s): python add.py node wg0 node1 + python add.py node wg0 node2 + python add.py node wg0 node3
    • check the information: cat wg0.conf
    • modify the endpoint: python modify.py wg0 node1 Endpoint 1.1.1.1
    • generate configuration for each node: python generate.py wg0 node1 + python genenrate.py wg0 node2 + python generate wg0 node3
  • script

    • copy the configuration to the machine
    • use wg-quick to quick start the wireguard
    • check the connectivity via `ping

Why not WAN

Yes, using the public IP is convenient but you may counter some security problem as there are multiple ports need to exposed for the communication between nodes (both Kubernetes and Docker Swarm). To avoid this, I can easily use a VPN to avoid the problem, thus, why not.

What wiregurad can do

To be continued.