npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@streamr/lnem

v1.2.2

Published

Lightweight Network EMulator

Downloads

3

Readme

Lightweight Network EMulator

Lightweight Network EMulator simplifies integration testing of network applications on Linux. It is implemented as a collection of easy-to-use Bash scripts on top of Linux network namespaces and Netem.

How it works

Lightweight Network EMulator creates a number of Linux network namespaces and places them in a star topology around the host machine. The network namespaces are named blue1, blue2, ... , blueN. Each network namespace is connected to the host with the help of a pair of virtual ethernet devices. For network namespace blueN, the virtual ethernet devices are named vethrealN and vethvirtualN, respectively. The device vethvirtualN is only visible from the namespace blueN, and the device vethrealN is visible from the host. The connection between the vethrealN and vethvirtualN devices is traffic-shaped using Netem and the tc command to introduce emulated latency, and limits for the uplink and downlink bandwidth. The emulated network uses the 10.240.0.0/12 network range. In case of emulated networks with less than 255 namespaces, the IP adderess of the device vethrealN is 10.240.N.1 and the IP address of device vethvirtualN 10.240.N.2, respectively. All routing towards the other network namespaces and the Internet goes through the host machine.

                                          Internet 
                                             |                                       
  ___________________                        |                         ___________________
 |                   |                       |                        |                   |
 |  vethvirtual1     |----- vethreal1 ----- host ----- vethreal2 -----|  vethvirtual2     |  
 |  10.240.1.2       |      10.240.1.1       |         10.240.2.1     |  10.240.2.2       |
 |  namespace blue1  |                       |                        |  namespace blue2  |
 |___________________|                       |                        |___________________|   
                                         vethrealN
                                         10.240.N.1  
                                             |
                                             |  
                                             |
                                     ___________________ 
                                    |                   |
                                    |  vethvirtualN     |
                                    |  10.240.N.2       |
                                    |  namespace blueN  | 
                                    |___________________|   

Prerequisites

  • A Linux host with a 5.x+ kernel and root privilleges (use a dedicated virtual machine to stay safe)
  • The following Debian packages (or equivivalent):
sudo apt-get install iproute2
sudo apt-get install net-tools
  • Ensure that ipv4 forwarding is enabled (if pings will not go through this is most likely disabled)
sudo sysctl -w net.ipv4.ip_forward=1
sudo sysctl -p /etc/sysctl.conf

more info on how to make the ip forwarding change permanent

  • You need a working nodejs and npm setup if you intend to install the scripts globally using npm. Alternatively you can directly execute the scripts from the bin folder

Installing using npm

sudo npm install -g @streamr/lnem

Uninstalling using npm

sudo npm uninstall -g @streamr/lnem

Connecting the emulated network to Internet through NAT

If you wish your emulated network to be able to connect to the Internet, you can set uo NAT using the script:

sudo lnem-create-nat

Disconnecting the emulated network from Internet

The NAT can be deleted using the script:

sudo lnem-delete-nat

Usage examples

Measuring emulated network using ping and netperf

Install netperf

sudo apt-get install netperf

Create a network namespace for the netperf server with download bandwidth limit of 1000 kbit/s, upload bandwidth limit of 2000 kbit/s, and one-way latency of 10 ms between the namespace and the host machine.

sudo lnem-up --download 1000 --upload 2000 --latency 10 --num 1

Create a network namespace for the netperf client with no limits. Notice that we give the offset parameter to start creating the network namespaces starting from namespace blue2, since namespace blue1 is already in use by the server.

sudo lnem-up --num 1 --offset 2

Measure the RTT between the blue1 and blue2 network namespaces using ping

sudo ip netns exec blue2 ping 10.240.1.2

Start the netperf server in the blue1 namespace

sudo ip netns exec blue1 netserver -4 &

Run the netperf client in the blue2 namespace, and instruct it to connect to the server running in namespace blue2. The result should be close to 1 Mibit/s (the download bandwidth limit we set to the server's namespace)

sudo ip netns exec blue2 netperf -4 -H 10.240.1.2 

To clean up, kill netperf server, and delete the two namespaces.

sudo pkill netserver
sudo lnem-down -n 2

License

This project is licensed under the MIT License.