| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521 | 
<!DOCTYPE html><html>  <head>    <meta charset="utf-8" />    <meta name="viewport" content="width=device-width, initial-scale=1.0" />  <meta name="viewport" content="width=device-width,initial-scale=1">  <meta http-equiv="x-ua-compatible" content="ie=edge">  <meta name="lang:clipboard.copy" content="Copy to clipboard">  <meta name="lang:clipboard.copied" content="Copied to clipboard">  <meta name="lang:search.language" content="en">  <meta name="lang:search.pipeline.stopwords" content="True">  <meta name="lang:search.pipeline.trimmer" content="True">  <meta name="lang:search.result.none" content="No matching documents">  <meta name="lang:search.result.one" content="1 matching document">  <meta name="lang:search.result.other" content="# matching documents">  <meta name="lang:search.tokenizer" content="[\s\-]+">      <link href="https://fonts.gstatic.com/" rel="preconnect" crossorigin>    <link href="https://fonts.googleapis.com/css?family=Roboto+Mono:400,500,700|Roboto:300,400,400i,700&display=fallback" rel="stylesheet">    <style>      body,      input {        font-family: "Roboto", "Helvetica Neue", Helvetica, Arial, sans-serif      }      code,      kbd,      pre {        font-family: "Roboto Mono", "Courier New", Courier, monospace      }    </style>    <link rel="stylesheet" href="_static/stylesheets/application.css"/>  <link rel="stylesheet" href="_static/stylesheets/application-palette.css"/>  <link rel="stylesheet" href="_static/stylesheets/application-fixes.css"/>    <link rel="stylesheet" href="_static/fonts/material-icons.css"/>    <meta name="theme-color" content="#3f51b5">  <script src="_static/javascripts/modernizr.js"></script>          <title>About — Netmaker 0.10.0 documentation</title>    <link rel="stylesheet" type="text/css" href="_static/pygments.css" />    <link rel="stylesheet" type="text/css" href="_static/material.css" />    <script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>    <script src="_static/jquery.js"></script>    <script src="_static/underscore.js"></script>    <script src="_static/doctools.js"></script>    <link rel="author" title="About these documents" href="#" />    <link rel="index" title="Index" href="genindex.html" />    <link rel="search" title="Search" href="search.html" />    <link rel="next" title="Architecture" href="architecture.html" />    <link rel="prev" title="Welcome to the Netmaker Documentation" href="index.html" />       </head>  <body dir=ltr        data-md-color-primary=indigo data-md-color-accent=light-blue>    <svg class="md-svg">    <defs data-children-count="0">            <svg xmlns="http://www.w3.org/2000/svg" width="416" height="448" viewBox="0 0 416 448" id="__github"><path fill="currentColor" d="M160 304q0 10-3.125 20.5t-10.75 19T128 352t-18.125-8.5-10.75-19T96 304t3.125-20.5 10.75-19T128 256t18.125 8.5 10.75 19T160 304zm160 0q0 10-3.125 20.5t-10.75 19T288 352t-18.125-8.5-10.75-19T256 304t3.125-20.5 10.75-19T288 256t18.125 8.5 10.75 19T320 304zm40 0q0-30-17.25-51T296 232q-10.25 0-48.75 5.25Q229.5 240 208 240t-39.25-2.75Q130.75 232 120 232q-29.5 0-46.75 21T56 304q0 22 8 38.375t20.25 25.75 30.5 15 35 7.375 37.25 1.75h42q20.5 0 37.25-1.75t35-7.375 30.5-15 20.25-25.75T360 304zm56-44q0 51.75-15.25 82.75-9.5 19.25-26.375 33.25t-35.25 21.5-42.5 11.875-42.875 5.5T212 416q-19.5 0-35.5-.75t-36.875-3.125-38.125-7.5-34.25-12.875T37 371.5t-21.5-28.75Q0 312 0 260q0-59.25 34-99-6.75-20.5-6.75-42.5 0-29 12.75-54.5 27 0 47.5 9.875t47.25 30.875Q171.5 96 212 96q37 0 70 8 26.25-20.5 46.75-30.25T376 64q12.75 25.5 12.75 54.5 0 21.75-6.75 42 34 40 34 99.5z"/></svg>          </defs>  </svg>    <input class="md-toggle" data-md-toggle="drawer" type="checkbox" id="__drawer">  <input class="md-toggle" data-md-toggle="search" type="checkbox" id="__search">  <label class="md-overlay" data-md-component="overlay" for="__drawer"></label>  <a href="#about" tabindex="1" class="md-skip"> Skip to content </a>  <header class="md-header" data-md-component="header">  <nav class="md-header-nav md-grid">    <div class="md-flex navheader">      <div class="md-flex__cell md-flex__cell--shrink">        <a href="index.html" title="Netmaker 0.10.0 documentation"           class="md-header-nav__button md-logo">                      <i class="md-icon"></i>                  </a>      </div>      <div class="md-flex__cell md-flex__cell--shrink">        <label class="md-icon md-icon--menu md-header-nav__button" for="__drawer"></label>      </div>      <div class="md-flex__cell md-flex__cell--stretch">        <div class="md-flex__ellipsis md-header-nav__title" data-md-component="title">          <span class="md-header-nav__topic">Netmaker Docs</span>          <span class="md-header-nav__topic"> About </span>        </div>      </div>      <div class="md-flex__cell md-flex__cell--shrink">        <label class="md-icon md-icon--search md-header-nav__button" for="__search"></label>        <div class="md-search" data-md-component="search" role="dialog">  <label class="md-search__overlay" for="__search"></label>  <div class="md-search__inner" role="search">    <form class="md-search__form" action="search.html" method="get" name="search">      <input type="text" class="md-search__input" name="q" placeholder="Search"             autocapitalize="off" autocomplete="off" spellcheck="false"             data-md-component="query" data-md-state="active">      <label class="md-icon md-search__icon" for="__search"></label>      <button type="reset" class="md-icon md-search__icon" data-md-component="reset" tabindex="-1">              </button>    </form>    <div class="md-search__output">      <div class="md-search__scrollwrap" data-md-scrollfix>        <div class="md-search-result" data-md-component="result">          <div class="md-search-result__meta">            Type to start searching          </div>          <ol class="md-search-result__list"></ol>        </div>      </div>    </div>  </div></div>      </div>              <div class="md-flex__cell md-flex__cell--shrink">          <div class="md-header-nav__source">            <a href="https://github.com/gravitl/netmaker/" title="Go to repository" class="md-source" data-md-source="github">    <div class="md-source__icon">      <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 24 24" width="28" height="28">        <use xlink:href="#__github" width="24" height="24"></use>      </svg>    </div>    <div class="md-source__repository">    Netmaker  </div></a>          </div>        </div>                <script src="_static/javascripts/version_dropdown.js"></script>  <script>    var json_loc = ""versions.json"",        target_loc = "../",        text = "Versions";    $( document ).ready( add_version_dropdown(json_loc, target_loc, text));  </script>      </div>  </nav></header>    <div class="md-container">              <nav class="md-tabs" data-md-component="tabs">    <div class="md-tabs__inner md-grid">      <ul class="md-tabs__list">          <li class="md-tabs__item"><a href="index.html" class="md-tabs__link">Netmaker 0.10.0 documentation</a></li>      </ul>    </div>  </nav>    <main class="md-main">      <div class="md-main__inner md-grid" data-md-component="container">                  <div class="md-sidebar md-sidebar--primary" data-md-component="navigation">            <div class="md-sidebar__scrollwrap">              <div class="md-sidebar__inner">                <nav class="md-nav md-nav--primary" data-md-level="0">  <label class="md-nav__title md-nav__title--site" for="__drawer">    <a href="index.html" title="Netmaker 0.10.0 documentation" class="md-nav__button md-logo">              <i class="md-icon"></i>          </a>    <a href="index.html"       title="Netmaker 0.10.0 documentation">Netmaker Docs</a>  </label>    <div class="md-nav__source">      <a href="https://github.com/gravitl/netmaker/" title="Go to repository" class="md-source" data-md-source="github">    <div class="md-source__icon">      <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 24 24" width="28" height="28">        <use xlink:href="#__github" width="24" height="24"></use>      </svg>    </div>    <div class="md-source__repository">    Netmaker  </div></a>    </div>        <ul class="md-nav__list">    <li class="md-nav__item">            <input class="md-toggle md-nav__toggle" data-md-toggle="toc" type="checkbox" id="__toc">    <label class="md-nav__link md-nav__link--active" for="__toc"> About </label>          <a href="#" class="md-nav__link md-nav__link--active">About</a>              <nav class="md-nav md-nav--secondary">    <label class="md-nav__title" for="__toc">Contents</label>  <ul class="md-nav__list" data-md-scrollfix="">        <li class="md-nav__item"><a href="#about--page-root" class="md-nav__link">About</a><nav class="md-nav">              <ul class="md-nav__list">        <li class="md-nav__item"><a href="#what-is-netmaker" class="md-nav__link">What is Netmaker?</a>        </li>        <li class="md-nav__item"><a href="#how-does-netmaker-work" class="md-nav__link">How Does Netmaker Work?</a>        </li>        <li class="md-nav__item"><a href="#use-cases-for-netmaker" class="md-nav__link">Use Cases for Netmaker</a>        </li></ul>            </nav>        </li>  </ul></nav>      <ul class="md-nav__list">     <li class="md-nav__item">              <a href="#what-is-netmaker" class="md-nav__link">What is Netmaker?</a>              </li>    <li class="md-nav__item">              <a href="#how-does-netmaker-work" class="md-nav__link">How Does Netmaker Work?</a>              </li>    <li class="md-nav__item">              <a href="#use-cases-for-netmaker" class="md-nav__link">Use Cases for Netmaker</a>              </li></ul>        </li>    <li class="md-nav__item">              <a href="architecture.html" class="md-nav__link">Architecture</a>              </li>    <li class="md-nav__item">              <a href="install.html" class="md-nav__link">Install</a>              </li>    <li class="md-nav__item">              <a href="quick-start.html" class="md-nav__link">Quick Install</a>              </li>    <li class="md-nav__item">              <a href="getting-started.html" class="md-nav__link">Getting Started</a>              </li>    <li class="md-nav__item">              <a href="external-clients.html" class="md-nav__link">Ingress + External Clients</a>              </li>    <li class="md-nav__item">              <a href="egress-gateway.html" class="md-nav__link">Egress Gateway</a>              </li>    <li class="md-nav__item">              <a href="relay-server.html" class="md-nav__link">Relay Servers</a>              </li>    <li class="md-nav__item">              <a href="https://k8s.netmaker.org" class="md-nav__link">Kubernetes</a>              </li>    <li class="md-nav__item">              <a href="server-installation.html" class="md-nav__link">Advanced Server Installation</a>              </li>    <li class="md-nav__item">              <a href="client-installation.html" class="md-nav__link">Advanced Client Installation</a>              </li>    <li class="md-nav__item">              <a href="oauth.html" class="md-nav__link">Integrating OAuth</a>              </li>    <li class="md-nav__item">              <a href="usage.html" class="md-nav__link">External Guides</a>              </li>    <li class="md-nav__item">              <a href="ui-reference.html" class="md-nav__link">UI Reference</a>              </li>    <li class="md-nav__item">              <a href="api.html" class="md-nav__link">API Reference</a>              </li>    <li class="md-nav__item">              <a href="upgrades.html" class="md-nav__link">Upgrades</a>              </li>    <li class="md-nav__item">              <a href="troubleshoot.html" class="md-nav__link">Troubleshooting</a>              </li>    <li class="md-nav__item">              <a href="support.html" class="md-nav__link">Support</a>              </li>    <li class="md-nav__item">              <a href="conduct.html" class="md-nav__link">Code of Conduct</a>              </li>    <li class="md-nav__item">              <a href="license.html" class="md-nav__link">License</a>              </li>  </ul>  </nav>              </div>            </div>          </div>          <div class="md-sidebar md-sidebar--secondary" data-md-component="toc">            <div class="md-sidebar__scrollwrap">              <div class="md-sidebar__inner">                <nav class="md-nav md-nav--secondary">    <label class="md-nav__title" for="__toc">Contents</label>  <ul class="md-nav__list" data-md-scrollfix="">        <li class="md-nav__item"><a href="#about--page-root" class="md-nav__link">About</a><nav class="md-nav">              <ul class="md-nav__list">        <li class="md-nav__item"><a href="#what-is-netmaker" class="md-nav__link">What is Netmaker?</a>        </li>        <li class="md-nav__item"><a href="#how-does-netmaker-work" class="md-nav__link">How Does Netmaker Work?</a>        </li>        <li class="md-nav__item"><a href="#use-cases-for-netmaker" class="md-nav__link">Use Cases for Netmaker</a>        </li></ul>            </nav>        </li>  </ul></nav>              </div>            </div>          </div>                <div class="md-content">          <article class="md-content__inner md-typeset" role="main">              <h1 id="about--page-root">About<a class="headerlink" href="#about--page-root" title="Permalink to this headline">¶</a></h1><a class="reference internal image-reference" href="_images/netmaker-simple.png"><img alt="Netmaker Architecture Diagram" class="align-center" src="_images/netmaker-simple.png" style="width: 60%;"/></a><h2 id="what-is-netmaker">What is Netmaker?<a class="headerlink" href="#what-is-netmaker" title="Permalink to this headline">¶</a></h2><p>Netmaker is a tool for creating and managing virtual overlay networks. If you have at least two machines with internet access which you need to connect with a secure tunnel, Netmaker is for you. If you have thousands of servers spread across multiple locations, data centers, or clouds, Netmaker is also for you. Netmaker connects machines securely, wherever they are.</p><a class="reference internal image-reference" href="_images/mesh-diagram.png"><img alt="WireGuard Mesh" class="align-center" src="_images/mesh-diagram.png" style="width: 50%;"/></a><p>Netmaker takes those machines and creates a flat network so that they can all talk to each other easily and securely.If you’re familiar with AWS, it’s like a VPC but made up of arbitrary computers. From the machine’s perspective, all these other machines are in the same neighborhood, even if they’re spread all over the world.</p><p>Netmaker has many similarities to Tailscale, ZeroTier, and Nebula. What makes Netmaker different is its speed and flexibility. Netmaker is faster because it uses kernel WireGuard. It is more dynamic because the server and agents are fully configurable, which lets you handle all sorts of different use cases.</p><h2 id="how-does-netmaker-work">How Does Netmaker Work?<a class="headerlink" href="#how-does-netmaker-work" title="Permalink to this headline">¶</a></h2><p>Netmaker relies on WireGuard to create tunnels between machines. At its core, Netmaker is managing WireGuard across machines to create sensible networks. Technically, Netmaker is two things:</p><ul class="simple"><li><p>the admin server, called Netmaker</p></li><li><p>the agent, called Netclient</p></li></ul><p>As the network manager, you interact with the server to create and manage networks and devices. The server holds configurations for these networks and devices, which are retrieved by the netclients (agent). The server runs an MQTT (message queue) broker for client-server communication.</p><p>The netclient is installed on any machine you would like to add to a given network, whether that machine is a VM, Server, or IoT device. The netclient subscribes to the server’s MQ broker, and the server tells it how it should configure WireGuard. The client will let the server know when any local changes should be pushed out to the other clients. By doing this across many machines simultaneously, we create a dynamic, fully configurable virtual networks.</p><p>The Netmaker server does not typically route traffic. Otherwise, this would be a hub-and-spoke model, which is very slow. Instead, Netmaker just tells the machines on the network how they can reach each other directly. This is called a <em>full mesh</em> network and is much faster. Even if the server goes down, as long as none of the existing machines change substantially, your network will still run just fine.</p><h2 id="use-cases-for-netmaker">Use Cases for Netmaker<a class="headerlink" href="#use-cases-for-netmaker" title="Permalink to this headline">¶</a></h2><p>There are many use cases for Netmaker. In fact, you could probably be using it right now. This list is not all-encompassing, but provides a sample of how you might want to use Netmaker. Guided setup for many of these use cases can be found in the <a class="reference internal" href="usage.html"><span class="doc">Using Netmaker</span></a> documentation.</p><blockquote><div><ol class="arabic simple" start="0"><li><p>Automate creation of a WireGuard mesh network</p></li><li><p>Create a flat, secure network between cloud environments and data centers</p></li><li><p>Provide secure access to IoT devices, remote servers, and client sites.</p></li><li><p>Secure a home or office network</p></li><li><p>Add a layer of encryption to an existing network</p></li><li><p>Secure site-to-site connections</p></li><li><p>Manage cryptocurrency proof-of-stake machines</p></li><li><p>Create a dynamic and secure Kubernetes underlay network</p></li></ol></div></blockquote>          </article>        </div>      </div>    </main>  </div>  <footer class="md-footer">    <div class="md-footer-nav">      <nav class="md-footer-nav__inner md-grid">                      <a href="index.html" title="Welcome to the Netmaker Documentation"               class="md-flex md-footer-nav__link md-footer-nav__link--prev"               rel="prev">              <div class="md-flex__cell md-flex__cell--shrink">                <i class="md-icon md-icon--arrow-back md-footer-nav__button"></i>              </div>              <div class="md-flex__cell md-flex__cell--stretch md-footer-nav__title">                <span class="md-flex__ellipsis">                  <span                      class="md-footer-nav__direction"> Previous </span> Welcome to the Netmaker Documentation </span>              </div>            </a>                                <a href="architecture.html" title="Architecture"               class="md-flex md-footer-nav__link md-footer-nav__link--next"               rel="next">            <div class="md-flex__cell md-flex__cell--stretch md-footer-nav__title"><span                class="md-flex__ellipsis"> <span                class="md-footer-nav__direction"> Next </span> Architecture </span>            </div>            <div class="md-flex__cell md-flex__cell--shrink"><i                class="md-icon md-icon--arrow-forward md-footer-nav__button"></i>            </div>                  </a>              </nav>    </div>    <div class="md-footer-meta md-typeset">      <div class="md-footer-meta__inner md-grid">        <div class="md-footer-copyright">          <div class="md-footer-copyright__highlight">              © Copyright 2021, Alex Feiszli.                        </div>            Created using            <a href="http://www.sphinx-doc.org/">Sphinx</a> 4.3.0.             and            <a href="https://github.com/bashtage/sphinx-material/">Material for              Sphinx</a>        </div>      </div>    </div>  </footer>  <script src="_static/javascripts/application.js"></script>  <script>app.initialize({version: "1.0.4", url: {base: ".."}})</script>  </body></html>
 |