60 Linux Networking commands and scripts

Recently, I wanted to test network throughput via command line with at least 3 tools. For the life of me, I could not remember iperf. Not being able to remember previously used command line tools is frustrating and something we can all relate to. So I created a go-to list of network tools for myself. Then, I thought, why not turn this list into a blog post? So I spent another hour or two compiling this ongoing list of Linux Networking Commands and Scripts. I look forward mostly to suggestions because I know there’s always something missing or new scripts out there to try.

Datadog - Visualize and alert on Linux server metrics in real-time.

Linux Networking commands and scripts

iperf3 screenshot - Stacklinux.com VPS (Linux Networking Commands and Scripts)
iperf command example/screenshot

This list of Linux Networking commands and scripts will receive ongoing updates:

  1. aria2 – downloading just about everything. Torrents included.
  2. arpwatch – Ethernet Activity Monitor.
  3. bmon – bandwidth monitor and rate estimator.
  4. bwm-ng – live network bandwidth monitor.
  5. curl – transferring data with URLs. (or try httpie)
  6. darkstat – captures network traffic, usage statistics.
  7. dhclient – Dynamic Host Configuration Protocol Client
  8. dig – query DNS servers for information and obtain various types of DNS records.
  9. dstat – replacement for vmstat, iostat, mpstat, netstat and ifstat.
  10. ethtool – utility for controlling network drivers and hardware.
  11. gated – gateway routing daemon.
  12. host – DNS lookup utility.
  13. hping – TCP/IP packet assembler/analyzer.
  14. ibmonitor – shows bandwidth and total data transferred.
  15. ifstat –  report network interfaces bandwidth.
  16. iftop – display bandwidth usage.
  17. ifconfig command – manage network interfaces, display information, and configure settings.
  18. ip (PDF file) – a command with more features that ifconfig (net-tools).
  19. iperf3 – network bandwidth measurement tool. (above screenshot Stacklinux VPS)
  20. iproute2 – collection of utilities for controlling TCP/IP.
  21. iptables – take control of network traffic.
  22. IPTraf – An IP Network Monitor.
  23. iputils – set of small useful utilities for Linux networking.
  24. iw – a new nl80211 based CLI configuration utility for wireless devices.
  25. jwhois – client for the whois service.
  26. “lsof -i” – reveal information about your network sockets.
  27. mtr – network diagnostic tool.
  28. net-tools – utilities include: arp, hostname, ifconfig, netstat, rarp, route, plipconfig, slattach, mii-tool, iptunnel and ipmaddr.
  29. ncat – improved re-implementation of the venerable netcat.
  30. netcat – networking utility for reading/writing network connections.
  31. nethogs – a small ‘net top’ tool.
  32. Netperf – Network bandwidth testing.
  33. netplan – Netplan is a utility for easily configuring networking on a Linux system.
  34. netsniff-ng – Swiss army knife for daily Linux network plumbing.
  35. netstat command – provides network statistics, routing tables, and connection information. Part of net-tools, largely replaced by ‘ss‘.
  36. netwatch – monitoring Network Connections.
  37. ngrep – grep applied to the network layer.
  38. nload – display network usage.
  39. nmap – network discovery and security auditing.
  40. nmcli – a command-line tool for controlling NetworkManager and reporting network status.
  41. nmtui – provides a text interface to configure networking by controlling NetworkManager.
  42. nslookup – query Internet name servers interactively.
  43. ping – send ICMP echo_request to network hosts.
  44. route – show / manipulate the IP routing table.
  45. slurm – network load monitor.
  46. snort – Network Intrusion Detection and Prevention System.
  47. smokeping –  keeps track of your network latency.
  48. socat – establishes two bidirectional byte streams and transfers data between them.
  49. speedometer – Measure and display the rate of data across a network.
  50. speedtest-cli – test internet bandwidth using speedtest.net
  51. ss – utility to investigate sockets.
  52. ssh –  secure system administration and file transfers over insecure networks.
  53. tcpdump – command-line packet analyzer.
  54. tcptrack – Displays information about TCP connections on a network interface.
  55. telnet – user interface to the TELNET protocol.
  56. tracepath – very similar function to traceroute.
  57. traceroute – print the route packets trace to network host.
  58. vnStat – network traffic monitor.
  59. websocat – Connection forwarder from/to web sockets to/from usual sockets, in style of socat.
  60. wget –  retrieving files using HTTP, HTTPS, FTP and FTPS.
  61. Wireless Tools for Linux – includes iwconfig, iwlist, iwspy, iwpriv and ifrename.
  62. Wireshark – network protocol analyzer.

Read also:

Network Fundamentals

You can’t work with computer networks without understanding the basics. These are the foundation of all networking and include:

  • Network Protocols: The rules and standards that govern data transmission over a network. TCP/IP for reliable communication, HTTP for web traffic, FTP for file transfers.
  • Network Topologies: The physical and logical arrangement of devices on a network. Bus, star, ring and more.
  • Network Devices: The hardware that makes up a network, routers, switches, firewalls. Each device has a specific job to manage and direct traffic.
  • Network Media: The physical material used to transmit data, copper cables, fiber optic cables, wireless signals. The choice of media affects the speed and reliability of the network.

Now you have a foundation to build upon for more advanced networking and technologies to build, manage and troubleshoot.

Network Connectivity

Network connectivity is the lifeblood of any network, devices communicate and share resources. There are several ways to get network connectivity:

  • Wired Connections: Use physical cables, Ethernet, to connect devices. Wired connections are reliable and fast, great for stable high-speed networks.
  • Wireless Connections: Use wireless signals, Wi-Fi, to connect devices. Wireless connections are flexible and mobile, devices can connect without the physical constraints of cables.
  • Virtual Private Networks (VPNs): VPNs use encryption and other security measures to create secure private connections over public networks. This is for protecting sensitive data and privacy when accessing remote networks.

Network connectivity is used for:

  • Internet Access: Connect to the global network of computers to access online resources.
  • File Sharing: Devices to share files and data over a network.
  • Communication: Real-time communication through email, instant messaging and video conferencing.

Understanding and managing network connectivity, so devices can communicate efficiently and securely.

IP Addresses and DNS

IP addresses and DNS (Domain Name System) are the foundation of network connectivity, devices can locate and communicate with each other:

  • IP Addresses: Unique numerical addresses assigned to each device on a network. They are identifiers, devices send and receive data accurately. There are two types of IP addresses, IPv4 and IPv6, IPv6 has a larger address space.
  • DNS: This system translates human-readable domain names (www.example.com) into IP addresses. This is important because humans find domain names easier to remember, computers use IP addresses to route data.

When you type a domain name in a web browser, the DNS system translates it into an IP address and directs your request to the correct server. This is what makes browsing the internet so intuitive and easy.

Network Info and Stats

Monitoring network performance is key to a healthy and efficient network. Here are some key stats:

  • Network Traffic: The amount of data being transmitted over the network at any given time. Monitoring traffic helps to identify congestion and optimize bandwidth.
  • Network Latency: The delay between sending and receiving data. High latency affects real-time applications like video conferencing and online gaming.
  • Network Packet Loss: The number of data packets lost during transmission. High packet loss means there’s a network issue that needs to be fixed.
  • Network Throughput: The rate of data transmitted over the network. This is a key performance and capacity indicator.

By looking at these metrics, network admins can see how the network is performing, identify issues and take corrective action to ensure smooth and efficient network operation.

Linux Network Commands

Linux has a lot of commands to manage and troubleshoot network connections. Here are some essential Linux network commands:

  • ifconfig: Used to configure and manage network interfaces. You can assign IP addresses, enable or disable interfaces and more.
  • ip: A more powerful command to manage IP addresses and routing tables. Preferred for modern network configurations.
  • ping: Used to test network connectivity by sending ICMP echo requests to a host. Helps to diagnose network issues by measuring round-trip time and packet loss.
  • traceroute: Traces the path of data packets to a network host, shows each hop along the way. Useful to identify where delays or failures occur in the network.
  • netstat: Shows network stats and connections, gives insights to active connections, routing tables and interface stats.

These commands are a must have for anyone working with Linux networks, powerful tools to configure, manage and troubleshoot network connections.

Security

Network security is key to preventing unauthorized access and cyber threats. Here:

  • Firewalls: Devices that control incoming and outgoing network traffic based on security rules, a barrier between trusted and untrusted networks.
  • Encryption: Converts plaintext data into unreadable ciphertext, so it can’t be accessed during transmission.
  • Access Control: Measures that determine who can access the network and what they can do, so only authorized users can interact with network resources.
  • Intrusion Detection and Prevention Systems (IDPS): Systems that monitor network traffic for unauthorized access or malicious activity, to detect and prevent security breaches.

Protecting your data and network resources is key to implementing network security. By securing against threats you secure your network.

Published: January 31st, 2020 | Last updated: November 10th, 2024

Tags: , ,

Discussion

  1. There is a lot here to look over. I will have to check into this more when I have time. I used to do this a lot. Loved working with commands and scripts and trying different things out.

  2. Great list. I’ve used smokeping in my early years with Linux to monitor my wan interface. It was great but I recently moved to uptimeKuma to monitor my internet and other docker apps.

    I also used snort via pfsense but man, things were always being blocked, so I only placed it in monitoring mode :sweat_smile::sweat_smile::sweat_smile:

  3. Also consider these:

    1. NetworkManager – for network management and configuration.
    2. Bird – An Internet routing daemon which supports multiple routing protocols.
    3. tshark – The command-line version of Wireshark, for network protocol analysis in a terminal.


Top ↑