Skip to main content

JSON parsing Linux Network Namespace (netns) topology builder.

Project description

json2netns

JSON parsing Linux Network Namespace (netns) topology builder.

Install

From PyPI:

  • pip install json2netns

From GitHub:

  • pip install git+git://github.com/cooperlees/json2netns

Concepts

The script takes a JSON config file and drives namespace creation from that JSON toplogy file. Lets look at the following simple two network namespace topology:

json2netns sample topology

We have two namespaces that have 1 direct connection via a veth. It also has a OOB (Out of Band) set of interfaces that allow the main Linux Network Namespace to communicate with the netns directly.

  • By default it even bridges with a physical interface to allow external packets to be routed into the netns if desired from a physical NIC.

Configuration

The above topology is represented by sample.json. This config is also used by unittests to ensure correct functioning. We can add to it over time as users require more features.

Small 1 NS Example JSON Config

{
    "namespaces": {
        "left": {
            "id": 1,
            "interfaces": {
                "left0": {
                    "prefixes": ["fd00::1/64", "10.1.1.1/24"],
                    "peer_name": "right0",
                    "type": "veth"
                },
                "lo": {
                    "prefixes": ["fd00:1::/64", "10.6.9.1/32"],
                    "type": "loopback"
                }
            },
            "oob": false,
            "routes": {
                "route1": {
                    "dest_prefix" : "10.6.9.6/32",
                    "next_hop_ip" : "10.1.1.2",
                    "egress_if_name" : ""
                },
                "route2": {
                    "dest_prefix" : "fd00:6::/64",
                    "next_hop_ip" : "fd00::2",
                    "egress_if_name" : ""
                }
            }
        }
    },
    "oob": {},
    "physical_int": ""
}

Usage

After installing just point json2netns at a valid config file and run as root (in the future we could make it capability aware too - PR Welcome!).

  • usage: json2netns [-h] [-d] [--validate] [--workers WORKERS] config action

Actions

  • create: Create the interfaces and namespaces + bring interfaces up
  • check: Print the interface addressing + v4/6 routing tables to stdout
  • delete: Remove the namespaces and all interfaces

Development

The code has attempted to be object oriented first. Please try to use inheritance and keep new interface types sub classes of Interface etc. for all code additions.

Development 'editable' Install

python3 -m venv [--upgrade-deps] /tmp/tj
/tmp/tj/bin/pip install -r requirements_test.txt
/tmp/tj/bin/pip install -e .

Run Tests

For testing we use ptr.

/tmp/tj/bin/ptr [-k] [--print-cov] [--debug]
  • -k: keep venv ptr creates
  • --print-cov: handy to see what coverage is on all files
  • --debug: Handy to see all commands run so you can run a step manually

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

json2netns-2021.9.20.tar.gz (14.8 kB view details)

Uploaded Source

Built Distribution

json2netns-2021.9.20-py3-none-any.whl (17.4 kB view details)

Uploaded Python 3

File details

Details for the file json2netns-2021.9.20.tar.gz.

File metadata

  • Download URL: json2netns-2021.9.20.tar.gz
  • Upload date:
  • Size: 14.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for json2netns-2021.9.20.tar.gz
Algorithm Hash digest
SHA256 011e4081ff4ff9c008bbafcafe234812a96c3bf18e8896ae4bac14a78831af9b
MD5 fd43723a4bc8b752e200b46b5fde0513
BLAKE2b-256 5548784c7ffe67849d8c8f37bc94a084e3bc4450f0ff5082b40f9ad89182e7bf

See more details on using hashes here.

File details

Details for the file json2netns-2021.9.20-py3-none-any.whl.

File metadata

  • Download URL: json2netns-2021.9.20-py3-none-any.whl
  • Upload date:
  • Size: 17.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for json2netns-2021.9.20-py3-none-any.whl
Algorithm Hash digest
SHA256 9b3ee2488e721877ba770d47c7700d65f90dbcd40b683a9504a354bcd661fd00
MD5 ea1db5e4d10e1c1b2ff663d3ea092c70
BLAKE2b-256 766aab70f5d0554938c2dcae4bbce43997bcb5a0a31d169902e14088bcf901ab

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page