[pve-devel] [PATCH v10 pve-network 00/35] add subnet plugin

Alexandre Derumier aderumier at odiso.com
Mon Oct 5 17:08:37 CEST 2020


This patch series add basic subnets managements.
(need pve-cluster V5 patch series)

Subnets will be use for multiple things:
- defined gateway ip on vnets
- enable snat on a subnet
- add cloudnit|dhcp default network configs (gateway, static routes, nameservers,searchdomain,....)
- add ipam management. (ip registrations to external ipam, for vm|ct ip management)
- add dns registration. (reverse dns for subnet, and searchdomain regisration in external dns like powerdns )
- ...


Already implemented:

- gateway option is implemented:

It's currently replace ip management on vnets for layer3 plugins,
through the option "gateway".

If the option gateway is defined, for layer3 plugins (evpn && simple),
the ip will be used for the vnet.

A vnet can have multiple subnets, with multiples ipv4/ipv6.

- ipam
- dns registration


Changelog v2:

- add ipams plugins. Currently netbox && phpipam.
- the subnet && the subnet gateway are registered to ipam
- add/del/find_next_free ip are implemented, so it should be easy to use them in qemu && lxc config.

Changelog v3:

- add an internal ipam plugin

Changelog v4:

- fix pveipam plugin find_free_ip
- detect ipv4/ipv6 in find_free_ip

Changelog v5:

- add vnets add_ip,del_ip,... should be ok for use in lxc/qemuserver

Changelog v6:

- add dns plugins
- internal ipam fixes
- rework vnet-subnet association
- fixes && cleanup

Changelog v7:

- add snat to simple|evpn plugin
- cleanup subnet options
- fix reversedns

Changelog v8:

- move subnet api to /sdn/vnet/<vnet>/subnet
- make ipam non optionnal && use pve ipam as default
- don't allow subnets on vlanaware vnet
- fixes && cleanup

Changelog v9:

- write running config on commit in /etc/pve/sdn/.running-config
  and use it as source for config generation,status

Changelog v10:

- move ipams/dns options from subnets to zone
- add hostname/description to ipam db
- cleanup && bugfix

Alexandre Derumier (35):
  add subnet plugin
  vnets: add subnets
  add subnets verifications hooks
  zones: simple|evpn: add gateway ip from subnets to vnet
  zone: add vnet_update_hook
  vnets: subnets: use cidr
  subnet: fix on_delete_hook
  api2: subnet create: convert cidr to subnetid
  api2: increase version on apply/reload only
  add ipams plugins
  add pve internal ipam plugin
  vnets: find_free_ip : add ipversion detection
  vnets: add add_ip
  vnets: add del_ip + rework add_ip/find_free_ip
  add dns plugin
  Fix vnet gateway for routed setup + /32 pointopoint subnet
  ipam : pveplugin : fix find_next_free_ip
  add vnet to subnets && remove subnetlist from vnet
  zones: evpn|simple: add snat iptables rules
  subnet: disable route option for now and add dns domain format
  dns: fix reverse dns
  subnets: move api to /sdn/vnet/<vnet>/subnets && make vnet option not
    optionnal
  zones: evpn : fix raise exception
  subnet: make ipam not optionnal and use pve ipam as default
  don't allow subnets on vlanware vnet
  generate sdn/.running-config on apply
  api: add running/pending zones/vnets/subnets/controllers
  small bugfixes
  move dns options from subnets to zone
  move ipam option from subnet to zone
  subnets/ipam: allow same subnet on different zones
  vnets: allow duplicate tags in differents zones
  ipam: verify api access  on create/update
  ipam: add hostname/description to ipam db
  update documentation

 PVE/API2/Network/SDN.pm                |  17 ++
 PVE/API2/Network/SDN/Controllers.pm    |  59 ++++-
 PVE/API2/Network/SDN/Dns.pm            | 242 +++++++++++++++++++
 PVE/API2/Network/SDN/Ipams.pm          | 248 ++++++++++++++++++++
 PVE/API2/Network/SDN/Makefile          |   2 +-
 PVE/API2/Network/SDN/Subnets.pm        | 307 +++++++++++++++++++++++++
 PVE/API2/Network/SDN/Vnets.pm          |  82 ++++++-
 PVE/API2/Network/SDN/Zones.pm          | 101 +++++++-
 PVE/Network/SDN.pm                     | 102 ++++++--
 PVE/Network/SDN/Controllers.pm         |  14 +-
 PVE/Network/SDN/Dns.pm                 |  57 +++++
 PVE/Network/SDN/Dns/Makefile           |   8 +
 PVE/Network/SDN/Dns/Plugin.pm          | 118 ++++++++++
 PVE/Network/SDN/Dns/PowerdnsPlugin.pm  | 255 ++++++++++++++++++++
 PVE/Network/SDN/Ipams.pm               |  70 ++++++
 PVE/Network/SDN/Ipams/Makefile         |   8 +
 PVE/Network/SDN/Ipams/NetboxPlugin.pm  | 189 +++++++++++++++
 PVE/Network/SDN/Ipams/PVEPlugin.pm     | 204 ++++++++++++++++
 PVE/Network/SDN/Ipams/PhpIpamPlugin.pm | 217 +++++++++++++++++
 PVE/Network/SDN/Ipams/Plugin.pm        | 131 +++++++++++
 PVE/Network/SDN/Makefile               |   4 +-
 PVE/Network/SDN/SubnetPlugin.pm        | 165 +++++++++++++
 PVE/Network/SDN/Subnets.pm             | 287 +++++++++++++++++++++++
 PVE/Network/SDN/VnetPlugin.pm          |  37 ++-
 PVE/Network/SDN/Vnets.pm               |  92 +++++++-
 PVE/Network/SDN/Zones.pm               |  45 +++-
 PVE/Network/SDN/Zones/EvpnPlugin.pm    |  70 +++++-
 PVE/Network/SDN/Zones/FaucetPlugin.pm  |   4 +
 PVE/Network/SDN/Zones/Plugin.pm        |  11 +-
 PVE/Network/SDN/Zones/QinQPlugin.pm    |  26 ++-
 PVE/Network/SDN/Zones/SimplePlugin.pm  |  73 +++++-
 PVE/Network/SDN/Zones/VlanPlugin.pm    |  28 ++-
 PVE/Network/SDN/Zones/VxlanPlugin.pm   |  30 ++-
 debian/control                         |   3 +
 test/documentation.txt                 |  33 ++-
 test/generateconfig.pl                 |   5 +-
 36 files changed, 3210 insertions(+), 134 deletions(-)
 create mode 100644 PVE/API2/Network/SDN/Dns.pm
 create mode 100644 PVE/API2/Network/SDN/Ipams.pm
 create mode 100644 PVE/API2/Network/SDN/Subnets.pm
 create mode 100644 PVE/Network/SDN/Dns.pm
 create mode 100644 PVE/Network/SDN/Dns/Makefile
 create mode 100644 PVE/Network/SDN/Dns/Plugin.pm
 create mode 100644 PVE/Network/SDN/Dns/PowerdnsPlugin.pm
 create mode 100644 PVE/Network/SDN/Ipams.pm
 create mode 100644 PVE/Network/SDN/Ipams/Makefile
 create mode 100644 PVE/Network/SDN/Ipams/NetboxPlugin.pm
 create mode 100644 PVE/Network/SDN/Ipams/PVEPlugin.pm
 create mode 100644 PVE/Network/SDN/Ipams/PhpIpamPlugin.pm
 create mode 100644 PVE/Network/SDN/Ipams/Plugin.pm
 create mode 100644 PVE/Network/SDN/SubnetPlugin.pm
 create mode 100644 PVE/Network/SDN/Subnets.pm

-- 
2.20.1





More information about the pve-devel mailing list