Skip to main content

PIM-DM protocol

Project description

PIM-DM

PyPI - Python Version PyPI PyPI - License

We have implemented PIM-DM specification (RFC3973).

This repository stores the implementation of this protocol. The implementation is written in Python language and is destined to Linux systems.

Additionally, IGMPv2 and MLDv1 are implemented alongside with PIM-DM to detect interest of hosts.

Requirements

  • Linux machine
  • Unicast routing protocol
  • Python3 (we have written all code to be compatible with at least Python v3.3)
  • pip (to install all dependencies)
  • libpcap-dev
  • python3-dev

Installation

pip3 install pim-dm 

Run PIM-DM protocol

You may need sudo permissions, in order to run this protocol. This is required because we use raw sockets to exchange control messages. For this reason, some sockets to work properly need to have super user permissions.

To interact with the protocol you need to execute the pim-dm command. You may need to specify a command and corresponding arguments:

pim-dm -COMMAND ARGUMENTS

Start protocol process

In order to start the protocol you first need to explicitly start it. This will start a daemon process, which will be running in the background. The command is the following:

sudo pim-dm -start [-mvrf MULTICAST_TABLE_ID] [-uvrf UNICAST_TABLE_ID]

IPv4 and IPv6 multicast is supported. By default all commands will be executed on IPv4 daemon. To execute a command on the IPv6 daemon use -6.

We support multiple tables. Each daemon process will be bind to a given multicast and unicast table id, which can be defined at startup with -mvrf and -uvrf.

If -mvrf is not defined, the default multicast table id will be used (table id 0).

If -uvrf is not defined, the default unicast table id will be used (table id 254).

After starting the protocol process, if the default multicast table is not used, the following commands (for adding interfaces and listing state) need to have the argument -mvrf defined to specify the corresponding daemon process.

Multi daemon support

Multiple daemons are supported, each bind to a given multicast routing table id.

To perform configurations on one of these daemons use -mvrf command and define the daemon by its multicast table id.

To see all daemons that are currently running:

sudo pim-dm -instances

Add interface

After starting the protocol process you can enable the protocol in specific interfaces. You need to specify which interfaces will have IGMP enabled and which interfaces will have PIM-DM enabled.

  • To enable PIM-DM without State-Refresh, in a given interface, you need to run the following command:

    sudo pim-dm -ai INTERFACE_NAME [-4 | -6] [-mvrf MULTICAST_TABLE_ID]
    
  • To enable PIM-DM with State-Refresh, in a given interface, you need to run the following command:

    sudo pim-dm -aisr INTERFACE_NAME [-4 | -6] [-mvrf MULTICAST_TABLE_ID]
    
  • To enable IGMP/MLD in a given interface, you need to run the following command:

    • IGMP:
    sudo pim-dm -aiigmp INTERFACE_NAME [-mvrf MULTICAST_TABLE_ID]
    
    • MLD:
    sudo pim-dm -aimld INTERFACE_NAME [-mvrf MULTICAST_TABLE_ID]
    

Remove interface

To remove a previously added interface, you need run the following commands:

  • To remove a previously added PIM-DM interface:

    sudo pim-dm -ri INTERFACE_NAME [-4 | -6] [-mvrf MULTICAST_TABLE_ID]
    
  • To remove a previously added IGMP/MLD interface:

    • IGMP:
    sudo pim-dm -riigmp INTERFACE_NAME [-mvrf MULTICAST_TABLE_ID]
    
    • MLD:
    sudo pim-dm -rimld INTERFACE_NAME [-mvrf MULTICAST_TABLE_ID]
    

Stop protocol process

If you want to stop the protocol process, and stop the daemon process, you need to explicitly run this command:

If a specific multicast table id was defined on startup, you need to define the daemon by its multicast table id.

sudo pim-dm -stop [-mvrf MULTICAST_TABLE_ID]

Commands for monitoring the protocol process

We have built some list commands that can be used to check the "internals" of the implementation.

  • List interfaces:

    Show all router interfaces and which ones have PIM-DM and IGMP/MLD enabled. For IGMP/MLD enabled interfaces you can check the Querier state.

    sudo pim-dm -li [-4 | -6] [-mvrf MULTICAST_TABLE_ID]
    
  • List neighbors

    Verify neighbors that have established a neighborhood relationship.

    sudo pim-dm -ln [-4 | -6] [-mvrf MULTICAST_TABLE_ID]
    
  • List state

    List all state machines and corresponding state of all trees that are being monitored. Also list IGMP state for each group being monitored.

    sudo pim-dm -ls [-4 | -6] [-mvrf MULTICAST_TABLE_ID]
    
  • Multicast Routing Table

    List Linux Multicast Routing Table (equivalent to ip mroute show)

    sudo pim-dm -mr [-4 | -6] [-mvrf MULTICAST_TABLE_ID]
    

Config File

It is possible to configure the protocol using a YAML file. This configuration file can be used to set all interfaces that will have PIM-DM/IGMP/MLD enabled, as well to fine tune these protocols by setting their timers. Currently the settings are shared by all interfaces. In a future release it will be possible to set timers per interface.

To use this feature you need to manually install PyYaml. PyYaml is not automatically installed with pim-dm to support older Python versions (as of now PyYaml requires at least Python v3.5).

This YAML file is a configuration file example.

It it also possible to get an YAML configuration file from the current settings of the daemon. This will output an YAML template that can be used later for enabling the daemon with the same settings (enabled interfaces and timers). The command for this matter is the following:

sudo pim-dm -get_config [-mvrf MULTICAST_TABLE_ID]

To input an YAML configuration file to the daemon:

sudo pim-dm -config CONFIGURATION_FILE_PATH

Help command

In order to determine which commands and corresponding arguments are available you can call the help command:

pim-dm -h

Tests

We have performed tests to our PIM-DM implementation. You can check on the corresponding branches:

  • Test_PIM_Hello - Topology used to test the establishment of adjacency between routers.
  • Test_PIM_BroadcastTree - Topology used to test our implementation regarding the creation and maintenance of the broadcast tree.
  • Test_PIM_Assert - Topology used to test the election of the AssertWinner.
  • Test_PIM_Join_Prune_Graft - Topology used to test the Pruning and Grafting of the multicast distribution tree.
  • Test_PIM_StateRefresh - Topology used to test PIM-DM State Refresh.
  • Test_IGMP - Topology used to test our IGMPv2 implementation.

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

pim-dm-1.4.1.tar.gz (95.1 kB view details)

Uploaded Source

Built Distributions

pim_dm-1.4.1-pp38-pypy38_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (206.0 kB view details)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

pim_dm-1.4.1-cp36-cp36m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (280.6 kB view details)

Uploaded CPython 3.6m manylinux: glibc 2.17+ x86-64

File details

Details for the file pim-dm-1.4.1.tar.gz.

File metadata

  • Download URL: pim-dm-1.4.1.tar.gz
  • Upload date:
  • Size: 95.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.3 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.64.0 importlib-metadata/4.8.3 keyring/23.4.1 rfc3986/1.5.0 colorama/0.4.5 CPython/3.6.8

File hashes

Hashes for pim-dm-1.4.1.tar.gz
Algorithm Hash digest
SHA256 9b51c0ebfd0658d60674f30abd659ceed18bbcc2e919668f2d32954225b1aeae
MD5 8f5f3cdc8ed54ffe216bb3c89409f83b
BLAKE2b-256 e8e020b49ff67ed114212ec02806f23ab1c3fc5121a102f33483ba12a0b562f4

See more details on using hashes here.

File details

Details for the file pim_dm-1.4.1-pp38-pypy38_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for pim_dm-1.4.1-pp38-pypy38_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 70a398877d54a703ce3c166862d9372f4dee38c36c2d467cc8a5fa11dba81340
MD5 366ec9a435da673d1d2f14979e5ca722
BLAKE2b-256 3e6ff4dbbf69436806210f367cd84c9dc28c81de843c892b5c2c4c6d9b0d6411

See more details on using hashes here.

File details

Details for the file pim_dm-1.4.1-cp36-cp36m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

  • Download URL: pim_dm-1.4.1-cp36-cp36m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
  • Upload date:
  • Size: 280.6 kB
  • Tags: CPython 3.6m, manylinux: glibc 2.17+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.3 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.64.0 importlib-metadata/4.8.3 keyring/23.4.1 rfc3986/1.5.0 colorama/0.4.5 CPython/3.6.8

File hashes

Hashes for pim_dm-1.4.1-cp36-cp36m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 9b9ce6033ff0025c7c8e1c1724eb4e5adda681889b389611c62c8ab9e57e46d3
MD5 33799bf6a4c959f7fa7ed2f735a3f55e
BLAKE2b-256 85619716c489c719dc694c85fb36877eb9a0f02dfcaf3eaf4747012ab9654a28

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