Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/katharaframework/networkplugin
Docker Network Plugin used by Kathará to create pure L2 networks.
https://github.com/katharaframework/networkplugin
docker docker-network-plugin docker-networking kathara l2-net linux-bridge vde
Last synced: about 2 months ago
JSON representation
Docker Network Plugin used by Kathará to create pure L2 networks.
- Host: GitHub
- URL: https://github.com/katharaframework/networkplugin
- Owner: KatharaFramework
- License: apache-2.0
- Created: 2020-01-29T17:23:01.000Z (almost 5 years ago)
- Default Branch: main
- Last Pushed: 2024-04-18T17:39:36.000Z (9 months ago)
- Last Synced: 2024-05-17T00:01:37.871Z (8 months ago)
- Topics: docker, docker-network-plugin, docker-networking, kathara, l2-net, linux-bridge, vde
- Language: Go
- Homepage: https://www.kathara.org/
- Size: 122 KB
- Stars: 14
- Watchers: 6
- Forks: 7
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.md
Awesome Lists containing this project
README
# Kathará Network Plugin
This repository contains the source code for the Docker Network Plugin used by Kathará.
The plugin has two different versions, which are divided in the two main folders:
- [`vde`](/vde/): creates pure L2 LANs using VDE (Virtual Distributed Ethernet) software switches and tap interfaces (which is built using the `kathara/katharanp_vde` tag).
- [`bridge`](/bridge/) (legacy): creates pure L2 LANs using Linux bridges and veth pairs (which is built using the `kathara/katharanp` tag).## Build from source
The plugin is compiled and released for both `amd64` and `arm64` architectures. The tag of the plugin identifies the architecture.
To build both the plugin versions, type on terminal (in the root of the project):
```
$ make all_
```Where `` can be: `amd64` or `arm64`.
**NOTE**: since the `vde` version relies on C code, you can only build the Docker plugin for your target architecture!
You can also build only a specific version of the plugin by entering its directory, for example:
```
$ cd vde && make all_
```The build process leverages on Docker, so you don't need any dependencies installed in your machine.
## Use the Plugin without Kathará
It is possible to leverage on this plugin as a standalone Docker Network Plugin, in order to create pure L2 networks. Please check the `README` of each version (inside the corresponding folder) for specific information.
### Assign MAC Addresses to network interfaces
`katharanp` supports two different ways to assign a MAC Address to a network interface:
- Pass a specific MAC Address, this can be achieved by leveraging the `kathara.mac_addr` driver option while connecting a container to a network:
```bash
docker network connect --driver-opt kathara.mac_addr=aa:bb:cc:dd:ee:ff l2net container
```
- Compute a deterministic MAC Address using the container name and the interface index, this can be done with the `kathara.machine` and `kathara.iface` driver options (they are required together):
```bash
docker network connect --driver-opt kathara.machine=container --driver-opt kathara.iface=1 l2net container
```The formula to compute the MAC address is the following:
1. Join the two strings, separating the two values by a dash, e.g., `container-1`
2. Compute the MD5 of the resulting string: `b588c219865f6fe336908e5991216b13`
3. Take the first 6 hex bytes of the string, starting from the left: `b588c219865f` -> `b5:88:c2:19:86:5f`
4. Clean the first byte to obtain a locally administered unicast MAC Address: `0xb5 | 0x02 = 0xb7 & 0xfe = 0xb6`
5. The resulting MAC Address is: `b6:88:c2:19:86:5f`Example output from the container:
```bash
root@584e403aec5a:/# ifconfig eth1
eth1: flags=4163 mtu 1500
ether b6:88:c2:19:86:5f txqueuelen 1000 (Ethernet)
RX packets 8 bytes 736 (736.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 0 bytes 0 (0.0 B)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
```