Skip to main content

A web-based tool for simulating network quality

Project description

NetHang Logo

Tests

NetHang is a web-based tool designed to simulate network quality, focusing on the diversity of last-mile network conditions. For modern internet applications and services with high real-time requirements, NetHang offers a stable, reentrant, customizable, and easily extensible network quality simulation system, helping to achieve low-latency and high-quality internet services.

Add Path

Unlike traditional network impairment tools that target backbone network quality between servers and switches, NetHang is optimized for:

  • Simulating network quality from user equipment (UE) to servers, typically traversing:

    • UE <--> Lan (Wi-Fi or Wired) <--> Routers <--> ISP edge nodes <--> APP servers
    • UE <--> Cellular <--> ISP edge nodes <--> APP servers
    • UE <--> Air interface <--> Satellite <--> APP servers
  • The current network model is built and simplified based on existing network quality data modeling, while also supporting users to easily customize the network models they need for testing in YAML format. The following image shows the StarLink network simulation ( Queuing changes every 20s - 30s caused by Satellite handover ):

StarLink Simulation
  • NetHang clearly displays the differences in data traffic before and after simulation, as well as the state of the simulation conditions.
Manipulate Charts

Features

  • Configurable traffic rules and models
  • Traffic rate limiting and shaping
  • Throttle queue depth control
Throttle Settings
  • Network latency and latency variation (Jitter) simulation
  • Jitter simulation with and without reordering allowed
Latency Settings Latency Settings
  • Packet loss with random and burst support
Loss Settings
  • Support for both uplink and downlink traffic control
  • Real-time traffic statistics display

Requirements

  • Python 3.8 or higher
  • Linux system with tc and iptables support
  • Root privileges for traffic control operations

Installation

From PyPI (Recommended)

You can install NetHang from PyPI using the following command:

pip install nethang

From Source (For Developers)

You can also install NetHang from source by cloning the repository and running the following command:

pip install .

License

MIT License

Copyright (c) 2025 NetHang Contributors

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

Contributing

  1. Fork the repository
  2. Create a feature branch
  3. Commit your changes
  4. Push to the branch
  5. Create a Pull Request

Please make sure to update tests as appropriate and adhere to the existing coding style.

Authors

NetHang Contributors

Acknowledgments

  • Thanks to all contributors who have helped with the project
  • Inspired by various network traffic control tools and utilities

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

nethang-0.2.0.tar.gz (336.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

nethang-0.2.0-py3-none-any.whl (331.4 kB view details)

Uploaded Python 3

File details

Details for the file nethang-0.2.0.tar.gz.

File metadata

  • Download URL: nethang-0.2.0.tar.gz
  • Upload date:
  • Size: 336.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.7

File hashes

Hashes for nethang-0.2.0.tar.gz
Algorithm Hash digest
SHA256 3f5b37923427f3f58ef020fcc97c06d60023275ca4e60eb98f9fb48426be7e6f
MD5 091af8fcd9f183153d872b70380af041
BLAKE2b-256 c1689e4d620ad21a318590ff788b189ab53f9d541bf31a5cd168c8c718d10a23

See more details on using hashes here.

File details

Details for the file nethang-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: nethang-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 331.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.7

File hashes

Hashes for nethang-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ac9b628109b41e2e9a1295c415aea3fade2c4149550cc3e3495f4ec03b9767d0
MD5 60ff2c67ac7671b307eb01efc8ef5921
BLAKE2b-256 69b8d361dd42b831ea4802ad094e6bbd26bf26a43cc895454f8a89c10560d9b0

See more details on using hashes here.

Supported by

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