#ip-address #local #ip #networking #web #operating-system #address


Retrieve system's local IP address and Network Interfaces/Adapters on Linux, macOS and Windows

22 releases

0.6.1 Feb 25, 2024
0.5.7 Jan 20, 2024
0.5.6 Sep 27, 2023
0.5.4 Jul 27, 2023
0.4.2 Jul 14, 2021

#15 in Network programming

Download history 14462/week @ 2023-12-23 29749/week @ 2023-12-30 46842/week @ 2024-01-06 55978/week @ 2024-01-13 59723/week @ 2024-01-20 63543/week @ 2024-01-27 59190/week @ 2024-02-03 54678/week @ 2024-02-10 67224/week @ 2024-02-17 68086/week @ 2024-02-24 72410/week @ 2024-03-02 76188/week @ 2024-03-09 78504/week @ 2024-03-16 82101/week @ 2024-03-23 77149/week @ 2024-03-30 66932/week @ 2024-04-06

316,953 downloads per month
Used in 108 crates (78 directly)




Retrieve system's local IP address and Network Interfaces/Adapters on Linux, Windows, and macOS (and other BSD-based systems).

Crates.io Documentation Build Clippy Formatter


Get the local IP address of your system by executing the local_ip function:

use local_ip_address::local_ip;

fn main() {
    let my_local_ip = local_ip().unwrap();

    println!("This is my local IP address: {:?}", my_local_ip);

Retrieve all the available network interfaces from both, the AF_INET and the AF_INET6 family by executing the list_afinet_netifas function:

use local_ip_address::list_afinet_netifas;

fn main() {
    let network_interfaces = list_afinet_netifas().unwrap();

    for (name, ip) in network_interfaces.iter() {
        println!("{}:\t{:?}", name, ip);

Underlying approach on retrieving network interfaces or the local IP address may differ based on the running operative system.

OS Approach
Linux Establishes a Netlink socket interchange to retrieve network interfaces
BSD-based Uses of getifaddrs to retrieve network interfaces
Windows Consumes Win32 API's to retrieve the network adapters table

Operating System Support

Current supported platforms include:

  • Linux (requires at least v0.1.0);
  • macOS (requires at least v0.1.0);
  • Windows (requires at least v0.3.0);
  • Other BSD-based (requires at least v0.5.0); including:
    • FreeBSD
    • OpenBSD
    • NetBSD
    • DragonFly

Please note that we only test the BSD implementation of this on macOS and FreeBSD, under the assumption that other BSD-based systems will behave similarly. If you have any complications using this library on the other BSD-based, please create an issue.


In order to create a release you must push a Git tag as follows

git tag -a <version> -m <message>


git tag -a v0.1.0 -m "First release"

Tags must follow semver conventions Tags must be prefixed with a lowercase v letter.

Then push tags as follows:

git push origin main --follow-tags


Every contribution to this project is welcome. Feel free to open a pull request, an issue or just by starting this project.


Distributed under the terms of both the MIT license and the Apache License (Version 2.0)


~104K SLoC