Megalos (Kathara over Kubernetes) - KatharaFramework/Kathara GitHub Wiki
Starting from version 3.0.0, Kathará officially supports Kubernetes as a backend virtualization system. Unfortunately, due to some design decisions and compatibility issues there are a few differences when deploying a network scenario on Kubernetes.
Differences between Kathará and Megalos
- Collision domain names cannot be more than 4 characters length.
- The network interfaces defined for a specific device are called
netX
instead ofethX
. Moreover, each device has aneth0
interface used by Kubernetes to communicate with that device (check its deployment status, heartbeats, etc.). ANY change made to theeth0
interface will cause a device failure, with a deletion and a re-schedule. - When a routing daemon is used, the
eth0
network interface MUST be disabled inside the routing daemon. Moreover, the Kubernetes Pods subnet must be denied. Here you can find an example on how to acheive this using Quagga:
router ospf (or rip)
passive-interface eth0
!
! AFTER NETWORK AND REDISTRIBUTE SECTIONS
!
distribute-list noeth0 out kernel
!
access-list noeth0 deny XX.YY.ZZ.KK/AA = Kubernetes Pods Subnet (e.g. 172.0.0.0/8)
access-list noeth0 permit any
!
- The
hosthome
directory is not mounted. - The
shared
directory is bound to the host directory/home/shared
of the worker node where a device is running. Hence, the directory content will be different if the same device is scheduled in another worker node. - Inside a network scenario, the .tar.gz of a device directory must not exceed 3MB. Notice that the .tar.gz is automatically created by Kathará and will raise a dedicated exception if it is bigger than 3MB.
- Unlike Kathará, when a network scenario is deployed, terminals are not automatically opened. To connect to a device shell, use
kathara connect
command. - The
.startup
file MUST always return with exit code 0. This means that blocking applications must not be launched in foreground. Use Bash operator&
to launch them in background.
Using Kathará with Kubernetes
- Install the Megalos CNI on your Kubernetes cluster.
- If Kathará is not installed in the master node, use
kathara settings
to setup a remote connection with the Kubernetes API Server (URL and API Key are required). - Start playing with your network scenarios.