/docker-network-plugin

docker-network-plugin

Primary LanguageGoOtherNOASSERTION

=================
::Docker plugin::
=================
-------
:Notes:
-------
Currently Docker supports volume and network driver plugins. In the future it will support additional plugin types.
Example Plugins (https://docs.docker.com/engine/extend/plugins/):
  Volume:
    Blockbridge plugin
    Convoy plugin
    Flocker plugin
    GlusterFS plugin
    Horcrux Volume Plugin 
    IPFS Volume Plugin 
    Keywhiz plugin
    Netshare plugin
    OpenStorage Plugin
    Quobyte Volume Plugin
    REX-Ray plugin
    Contiv Volume Plugin
  Network:
    Contiv Networking (https://github.com/contiv/netplugin) 
    Weave Network Plugin (https://github.com/weaveworks/weave/tree/master/plugin)
    Kuryr Network Plugin
    Local Persist Plugin
  Authorization:
    ?? Only in docker v1.10
    ?? https://docs.docker.com/engine/extend/plugins_authorization/
    ?? https://github.com/docker/docker/blob/master/docs/extend/plugins_authorization.md
  IPAM:
    ??
-----
:IRC:
-----
  #docker-network
----------
:Ref Docs:
----------
  https://github.com/docker/docker/blob/master/docs/extend/plugin_api.md
  https://github.com/docker/libnetwork/blob/master/docs/design.md
  https://github.com/docker/libnetwork/blob/master/docs/remote.md
  Remote IPAM: https://github.com/docker/libnetwork/blob/master/docs/ipam.md
----------------------------------
:Configuration for docker plugins:
----------------------------------
mdnp.json file which contains the below info
mdnp.json can be located in "/etc/docker/plugins" or "/usr/lib/docker/plugins"
plugin name would then me "mdnp", since file name is mdnp.json
Order in which docker searchs for plugins: /run/docker/plugins (for .sock), /etc/docker/plugins, /usr/lib/docker/plugins
JSON format of plugin:
    {
      "Name": "plugin-example",
      "Addr": "https://example.com/docker/plugin",
      //"TLSConfig": {
      //  "InsecureSkipVerify": false,
      //  "CAFile": "/usr/shared/docker/certs/example-ca.pem",
      //  "CertFile": "/usr/shared/docker/certs/example-cert.pem",
      //  "KeyFile": "/usr/shared/docker/certs/example-key.pem",
      //}
    }
Plugins should be started before docker and stopped after docker. Use upstart hooks or systemd hooks to manage the dependency.
When upgrading a plugin, you should first stop the Docker daemon, upgrade the plugin, then start Docker again.
Plugins are not activated automatically at Docker daemon startup. Rather, they are activated only lazily, or on-demand, when they are needed.

------
:Goal:
------
Build a remote network plugin.
------------------
:Short term goals:
------------------
Use libnetwork/CNM rather than the comparatively newer CNI model.
No backend network for now; no intelligence.
Discuss the `long term goals` once there is clarity on the project; so this for now, is a toy plugin for all intents & purposes
------------
:How to run:
------------
Cleanup from prev runs: sudo docker network rm mynet && docker network ls
Stop docker: sudo service stop docker
Run the plugin: sudo ./bin/main 2>&1 > mdnp.log; sudo tail -F mdnp.log
Start docker: sudo service start docker
Create the network: sudo docker network create --driver=mdnp mynet
Run a container with custom network driver: docker run --net=mynet krish/test:v1
=-=-=-=
CAVEAT:
=-=-=-=
  The source has a hardcoded value for "veth0" for use by the container.
  This can be bypassed (and should be!) by creating a dynamic veth for every container by using the golang netlink package.
  Workaround for testing:
    Create a veth interface: sudo ip link add type veth
    Should have a veth0 now.
    Configure it: sudo ifconfig veth0 172.16.0.205 netmask 255.255.255.0 up
    Cleaup: sudo ip link del veth1

----------------
:Example output:
----------------
docker exec -it happy_leakey bash
root@e69f0d8ff13d:/# ifconfig    
eth1      Link encap:Ethernet  HWaddr 02:42:ac:13:00:02  
          inet addr:172.19.0.2  Bcast:0.0.0.0  Mask:255.255.0.0
          inet6 addr: fe80::42:acff:fe13:2/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:29 errors:0 dropped:0 overruns:0 frame:0
          TX packets:12 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0 
          RX bytes:4219 (4.2 KB)  TX bytes:928 (928.0 B)

krish-mdnp0 Link encap:Ethernet  HWaddr aa:04:e9:41:14:8c  
          inet addr:172.18.0.2  Bcast:0.0.0.0  Mask:255.255.0.0
          UP BROADCAST MULTICAST  MTU:1500  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000 
          RX bytes:0 (0.0 B)  TX bytes:0 (0.0 B)

lo        Link encap:Local Loopback  
          inet addr:127.0.0.1  Mask:255.0.0.0
          inet6 addr: ::1/128 Scope:Host
          UP LOOPBACK RUNNING  MTU:65536  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0 
          RX bytes:0 (0.0 B)  TX bytes:0 (0.0 B)