Convert Figma logo to code with AI

netbirdio logonetbird

Connect your devices into a secure WireGuard®-based overlay network with SSO, MFA and granular access controls.

11,521
531
11,521
816

Top Related Projects

19,849

The easiest, most secure way to use WireGuard and 2FA.

Netmaker makes networks with WireGuard. Netmaker automates fast, secure, and distributed virtual networks.

14,698

A scalable overlay networking tool with a focus on performance, simplicity and security

11,521

Connect your devices into a secure WireGuard®-based overlay network with SSO, MFA and granular access controls.

A private network system that uses WireGuard under the hood.

Enterprise-ready zero-trust access platform built on WireGuard®.

Quick Overview

NetBird is an open-source VPN management platform that simplifies the creation and management of secure, peer-to-peer networks. It uses WireGuard® protocol for fast and secure connections, and provides a user-friendly interface for easy network administration and monitoring.

Pros

  • Easy setup and management of secure networks
  • Cross-platform support (Windows, macOS, Linux, iOS, Android)
  • Automatic key rotation and peer discovery
  • Integration with identity providers (e.g., Google Workspace, Azure AD)

Cons

  • Relatively new project, may have undiscovered issues
  • Limited documentation compared to more established VPN solutions
  • Requires self-hosting for full control and privacy
  • May not be suitable for very large enterprise networks

Getting Started

To get started with NetBird, follow these steps:

  1. Install NetBird on your device:

    curl -fsSL https://pkgs.netbird.io/install.sh | sh
    
  2. Sign up for a NetBird account or set up a self-hosted management service.

  3. Run NetBird and connect to your account:

    sudo netbird up
    
  4. Access the NetBird UI to manage your network, add peers, and configure access controls.

For more detailed instructions and advanced configuration options, refer to the official NetBird documentation at https://netbird.io/docs/.

Competitor Comparisons

19,849

The easiest, most secure way to use WireGuard and 2FA.

Pros of Tailscale

  • More mature and widely adopted project with a larger user base
  • Offers a managed service option for easier deployment and maintenance
  • Provides advanced features like access controls and single sign-on integration

Cons of Tailscale

  • Closed-source control server, limiting self-hosting options
  • Requires a central coordination server, which may introduce latency
  • Less flexible in terms of customization compared to fully open-source alternatives

Code Comparison

Tailscale (Go):

func (c *Conn) Close() error {
    c.mu.Lock()
    defer c.mu.Unlock()
    if c.closed {
        return nil
    }
    c.closed = true
    return c.pconn.Close()
}

NetBird (Go):

func (c *Conn) Close() error {
    c.Lock()
    defer c.Unlock()
    if c.isClosed {
        return nil
    }
    c.isClosed = true
    return c.conn.Close()
}

Both projects use similar patterns for connection closing, with mutex locks and checks for already closed connections. The main difference lies in variable naming conventions and specific implementation details.

Netmaker makes networks with WireGuard. Netmaker automates fast, secure, and distributed virtual networks.

Pros of Netmaker

  • More flexible networking options, including support for multiple network topologies
  • Advanced features like access control lists (ACLs) and network segmentation
  • Better suited for complex enterprise environments

Cons of Netmaker

  • Steeper learning curve and more complex setup process
  • Less user-friendly interface compared to Netbird
  • May require more resources to run and manage

Code Comparison

Netmaker (Go):

func (server *Server) CreateNetwork(network *models.Network) error {
    network.SetDefaults()
    if err := server.DB.Create(network).Error; err != nil {
        return err
    }
    return nil
}

Netbird (Go):

func (s *Server) CreateNetwork(ctx context.Context, network *Network) error {
    if err := s.store.CreateNetwork(ctx, network); err != nil {
        return err
    }
    return nil
}

Both projects use Go and have similar network creation functions, but Netmaker's implementation includes default value setting and uses GORM for database operations, while Netbird's approach is more straightforward and uses a custom store interface.

14,698

A scalable overlay networking tool with a focus on performance, simplicity and security

Pros of Nebula

  • More mature project with a longer history and larger community
  • Offers advanced networking features like IP address management and certificate-based authentication
  • Provides better performance for high-throughput applications

Cons of Nebula

  • More complex setup and configuration process
  • Lacks built-in NAT traversal capabilities
  • Limited platform support compared to NetBird

Code Comparison

NetBird configuration example:

peers:
  - public_key: ABC123...
    allowed_ips:
      - 10.0.0.1/32

Nebula configuration example:

static_host_map:
  "10.0.0.1": ["public_ip:4242"]
lighthouse:
  am_lighthouse: false
  interval: 60

Both projects aim to create secure overlay networks, but NetBird focuses on simplicity and ease of use, while Nebula offers more advanced networking features at the cost of increased complexity. NetBird provides a more user-friendly experience with its web UI and automatic NAT traversal, making it suitable for less technical users. Nebula, on the other hand, offers greater flexibility and control over network configurations, making it a better choice for advanced users and complex network setups.

11,521

Connect your devices into a secure WireGuard®-based overlay network with SSO, MFA and granular access controls.

Pros of NetBird

  • More comprehensive documentation and user guides
  • Larger community and more active development
  • Better integration with cloud platforms and services

Cons of NetBird

  • Higher resource consumption
  • Steeper learning curve for new users
  • More complex configuration process

Code Comparison

NetBird:

func (s *Server) Run() error {
    s.wg.Add(1)
    go s.runGRPCServer()
    s.wg.Add(1)
    go s.runHTTPServer()
    s.wg.Wait()
    return nil
}

NetBird>:

func (s *Server) Start() error {
    err := s.startGRPCServer()
    if err != nil {
        return err
    }
    return s.startHTTPServer()
}

The code comparison shows that NetBird uses goroutines for concurrent server execution, while NetBird> opts for a sequential approach. This difference reflects the overall design philosophy of each project, with NetBird focusing on performance and scalability, and NetBird> prioritizing simplicity and ease of use.

Both projects aim to provide secure and efficient networking solutions, but they cater to slightly different use cases and user preferences. NetBird is better suited for larger, more complex deployments, while NetBird> may be more appropriate for smaller projects or users who prefer a simpler setup process.

A private network system that uses WireGuard under the hood.

Pros of innernet

  • Written in Rust, potentially offering better performance and memory safety
  • Designed for internal networks, with a focus on simplicity and ease of use
  • Supports automatic IP address assignment and management

Cons of innernet

  • Limited to internal networks, not suitable for public-facing VPNs
  • Fewer features compared to NetBird, such as lack of built-in DNS management
  • Smaller community and less frequent updates

Code Comparison

innernet (Rust):

let server = Server::new(config)?;
server.run().await?;

NetBird (Go):

server, err := server.New(config)
if err != nil {
    return err
}
err = server.Run()

Both projects use similar high-level structures for server initialization and running, but innernet's Rust implementation may offer better performance and safety guarantees. NetBird's Go code is more verbose due to explicit error handling.

innernet is focused on internal networks, making it simpler to set up and manage for specific use cases. NetBird offers a more comprehensive solution with additional features like DNS management and public VPN support.

While innernet benefits from Rust's performance and safety, NetBird has a larger community and more frequent updates, potentially leading to better long-term support and feature development.

Enterprise-ready zero-trust access platform built on WireGuard®.

Pros of Firezone

  • Built with Elixir, offering robust concurrency and fault tolerance
  • Provides a user-friendly web UI for easier management
  • Supports single sign-on (SSO) integration with various identity providers

Cons of Firezone

  • Less mature project compared to Netbird
  • Smaller community and fewer contributors
  • Limited multi-platform support (primarily focused on Linux)

Code Comparison

Netbird (Go):

func (s *Server) Run() error {
    s.wg.Add(1)
    go s.runTURNServer()
    return s.runSignalServer()
}

Firezone (Elixir):

defmodule Firezone.Server do
  use GenServer

  def start_link(_) do
    GenServer.start_link(__MODULE__, [], name: __MODULE__)
  end

  def init(_) do
    {:ok, %{}}
  end
end

Both projects use different programming languages, which impacts their architecture and performance characteristics. Netbird's Go implementation may offer better raw performance, while Firezone's Elixir codebase provides better concurrency handling and fault tolerance. The code snippets demonstrate the different approaches to server implementation in each project.

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

:hatching_chick: New Release! Device Posture Checks. Learn more


Start using NetBird at netbird.io
See Documentation
Join our Slack channel


NetBird combines a configuration-free peer-to-peer private network and a centralized access control system in a single platform, making it easy to create secure private networks for your organization or home.

Connect. NetBird creates a WireGuard-based overlay network that automatically connects your machines over an encrypted tunnel, leaving behind the hassle of opening ports, complex firewall rules, VPN gateways, and so forth.

Secure. NetBird enables secure remote access by applying granular access policies while allowing you to manage them intuitively from a single place. Works universally on any infrastructure.

Open-Source Network Security in a Single Platform

netbird_2

NetBird on Lawrence Systems (Video)

Watch the video

Key features

ConnectivityManagementSecurityAutomationPlatforms
  • - [x] Kernel WireGuard
  • - [x] Linux
  • - [x] Peer-to-peer connections
  • - [x] Auto peer discovery and configuration
  • - [x] Mac
  • - [x] Connection relay fallback
  • - [x] Windows
  • - [x] IdP groups sync with JWT
  • - [x] Android
  • - [x] NAT traversal with BPF
  • - [x] Peer-to-peer encryption
  • - [x] iOS
  • - [x] OpenWRT
  • - [x] Periodic re-authentication
    • - [x] Docker

    Quickstart with NetBird Cloud

    Quickstart with self-hosted NetBird

    This is the quickest way to try self-hosted NetBird. It should take around 5 minutes to get started if you already have a public domain and a VM. Follow the Advanced guide with a custom identity provider for installations with different IDPs.

    Infrastructure requirements:

    • A Linux VM with at least 1CPU and 2GB of memory.
    • The VM should be publicly accessible on TCP ports 80 and 443 and UDP ports: 3478, 49152-65535.
    • Public domain name pointing to the VM.

    Software requirements:

    • Docker installed on the VM with the docker-compose plugin (Docker installation guide) or docker with docker-compose in version 2 or higher.
    • jq installed. In most distributions Usually available in the official repositories and can be installed with sudo apt install jq or sudo yum install jq
    • curl installed. Usually available in the official repositories and can be installed with sudo apt install curl or sudo yum install curl

    Steps

    • Download and run the installation script:
    export NETBIRD_DOMAIN=netbird.example.com; curl -fsSL https://github.com/netbirdio/netbird/releases/latest/download/getting-started-with-zitadel.sh | bash
    
    • Once finished, you can manage the resources via docker-compose

    A bit on NetBird internals

    • Every machine in the network runs NetBird Agent (or Client) that manages WireGuard.
    • Every agent connects to Management Service that holds network state, manages peer IPs, and distributes network updates to agents (peers).
    • NetBird agent uses WebRTC ICE implemented in pion/ice library to discover connection candidates when establishing a peer-to-peer connection between machines.
    • Connection candidates are discovered with the help of STUN servers.
    • Agents negotiate a connection through Signal Service passing p2p encrypted messages with candidates.
    • Sometimes the NAT traversal is unsuccessful due to strict NATs (e.g. mobile carrier-grade NAT) and a p2p connection isn't possible. When this occurs the system falls back to a relay server called TURN, and a secure WireGuard tunnel is established via the TURN server.

    Coturn is the one that has been successfully used for STUN and TURN in NetBird setups.

    See a complete architecture overview for details.

    Community projects

    Note: The main branch may be in an unstable or even broken state during development. For stable versions, see releases.

    Support acknowledgement

    In November 2022, NetBird joined the StartUpSecure program sponsored by The Federal Ministry of Education and Research of The Federal Republic of Germany. Together with CISPA Helmholtz Center for Information Security NetBird brings the security best practices and simplicity to private networking.

    CISPA_Logo_BLACK_EN_RZ_RGB (1)

    Testimonials

    We use open-source technologies like WireGuard®, Pion ICE (WebRTC), Coturn, and Rosenpass. We very much appreciate the work these guys are doing and we'd greatly appreciate if you could support them in any way (e.g., by giving a star or a contribution).

    Legal

    WireGuard and the WireGuard logo are registered trademarks of Jason A. Donenfeld.