Tunnels
knot tunnels allow HTTP and HTTPS services running on a local workstation or within a space to be exposed on the internet via a knot server.
Configuring the Server
Before tunnels can be used, the knot server must be configured to allow tunneling. This is done by setting the listen_tunnel
option in the server configuration:
[server]
listen_tunnel = 0.0.0.0:3001
tunnel_domain = "*.knot-tunnel.internal:3001"
- The
listen_tunnel
option specifies the address and port that the knot server will listen on for internet traffic to forward to user tunnels. - A wildcard domain must be pointed to this address and port, e.g.,
*.tunnel.knot.internal
.
Domain Routing
The leftmost component of the host determines the username and tunnel name. For example:
example-tunnel1.tunnel.knot.internal
routes traffic to the tunnel namedtunnel1
for the userexample
.
Creating a Tunnel
Tunnels can be created either on a local machine or within a space.
Creating a Tunnel on a Local Machine
Connect to the Knot Server Open a terminal and connect to the knot server by running the following command (replace the URL with the actual server address):
knot connect https://knot.internal:3000
- The
connect
command only needs to be run once or if the login expires.
- The
Create a Tunnel Run the
tunnel
command with the protocol, port, and tunnel name:knot tunnel http 8080 test1
- This creates a tunnel to the local port
8080
with the tunnel nameexample-test1.tunnels.knot.internal
. - Stopping the
knot tunnel
command will stop and remove the tunnel.
- This creates a tunnel to the local port
Creating a Tunnel in a Space
Enter the Space Access the space via a terminal.
Create a Tunnel Run the
tunnel
command with the protocol, port, and tunnel name:knot tunnel http 8080 test1
- This creates a tunnel to the local port
8080
with the tunnel nameexample-test1.tunnels.knot.internal
. - Stopping the
knot tunnel
command will stop and remove the tunnel.
- This creates a tunnel to the local port